diff options
author | Rich Felker <dalias@aerifal.cx> | 2015-04-24 12:09:01 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2015-04-24 13:05:21 -0400 |
commit | 1fb0878ebc037ee2ad9e31e5873b6c7f95b22c1c (patch) | |
tree | a08b023a3275045976a07d68fd31d99fc8eedc59 /arch/sh | |
parent | a658afbf94a41108d2e01bbc4113011b792b3bad (diff) | |
download | musl-1fb0878ebc037ee2ad9e31e5873b6c7f95b22c1c.tar.gz musl-1fb0878ebc037ee2ad9e31e5873b6c7f95b22c1c.tar.xz musl-1fb0878ebc037ee2ad9e31e5873b6c7f95b22c1c.zip |
fix ldso name for sh-nofpu subarch
previously it was using the same name as the default ABI with hard float (floating point args and return value in registers). the test __SH_FPU_ANY__ || __SH4__ matches what's used in the configure script already, and seems correct under casual review against gcc's config/sh.h, but may need tweaks. the logic for predefined macros for sh, and what they all mean, is very complex. eventually this should be documented in comments here. configure already rejects "half-hard" configurations on sh where double=float since these do not conform to Annex F and are not suitable for musl, so these do not need to be considered here.
Diffstat (limited to 'arch/sh')
-rw-r--r-- | arch/sh/reloc.h | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/arch/sh/reloc.h b/arch/sh/reloc.h index 61192ffe..77da6508 100644 --- a/arch/sh/reloc.h +++ b/arch/sh/reloc.h @@ -6,7 +6,13 @@ #define ENDIAN_SUFFIX "" #endif -#define LDSO_ARCH "sh" ENDIAN_SUFFIX +#if __SH_FPU_ANY__ || __SH4__ +#define FP_SUFFIX "" +#else +#define FP_SUFFIX "-nofpu" +#endif + +#define LDSO_ARCH "sh" ENDIAN_SUFFIX FP_SUFFIX #define TPOFF_K 8 |