xref: /aosp_15_r20/external/musl/arch/sh/reloc.h (revision c9945492fdd68bbe62686c5b452b4dc1be3f8453)
1*c9945492SAndroid Build Coastguard Worker #if __BYTE_ORDER == __BIG_ENDIAN
2*c9945492SAndroid Build Coastguard Worker #define ENDIAN_SUFFIX "eb"
3*c9945492SAndroid Build Coastguard Worker #else
4*c9945492SAndroid Build Coastguard Worker #define ENDIAN_SUFFIX ""
5*c9945492SAndroid Build Coastguard Worker #endif
6*c9945492SAndroid Build Coastguard Worker 
7*c9945492SAndroid Build Coastguard Worker #if __SH_FPU_ANY__ || __SH4__
8*c9945492SAndroid Build Coastguard Worker #define FP_SUFFIX ""
9*c9945492SAndroid Build Coastguard Worker #else
10*c9945492SAndroid Build Coastguard Worker #define FP_SUFFIX "-nofpu"
11*c9945492SAndroid Build Coastguard Worker #endif
12*c9945492SAndroid Build Coastguard Worker 
13*c9945492SAndroid Build Coastguard Worker #if __SH_FDPIC__
14*c9945492SAndroid Build Coastguard Worker #define ABI_SUFFIX "-fdpic"
15*c9945492SAndroid Build Coastguard Worker #else
16*c9945492SAndroid Build Coastguard Worker #define ABI_SUFFIX ""
17*c9945492SAndroid Build Coastguard Worker #endif
18*c9945492SAndroid Build Coastguard Worker 
19*c9945492SAndroid Build Coastguard Worker #define LDSO_ARCH "sh" ENDIAN_SUFFIX FP_SUFFIX ABI_SUFFIX
20*c9945492SAndroid Build Coastguard Worker 
21*c9945492SAndroid Build Coastguard Worker #define TPOFF_K 0
22*c9945492SAndroid Build Coastguard Worker 
23*c9945492SAndroid Build Coastguard Worker #define REL_SYMBOLIC    R_SH_DIR32
24*c9945492SAndroid Build Coastguard Worker #define REL_OFFSET      R_SH_REL32
25*c9945492SAndroid Build Coastguard Worker #define REL_GOT         R_SH_GLOB_DAT
26*c9945492SAndroid Build Coastguard Worker #define REL_PLT         R_SH_JMP_SLOT
27*c9945492SAndroid Build Coastguard Worker #define REL_RELATIVE    R_SH_RELATIVE
28*c9945492SAndroid Build Coastguard Worker #define REL_COPY        R_SH_COPY
29*c9945492SAndroid Build Coastguard Worker #define REL_DTPMOD      R_SH_TLS_DTPMOD32
30*c9945492SAndroid Build Coastguard Worker #define REL_DTPOFF      R_SH_TLS_DTPOFF32
31*c9945492SAndroid Build Coastguard Worker #define REL_TPOFF       R_SH_TLS_TPOFF32
32*c9945492SAndroid Build Coastguard Worker 
33*c9945492SAndroid Build Coastguard Worker #define DL_NOMMU_SUPPORT 1
34*c9945492SAndroid Build Coastguard Worker 
35*c9945492SAndroid Build Coastguard Worker #if __SH_FDPIC__
36*c9945492SAndroid Build Coastguard Worker #define REL_FUNCDESC    R_SH_FUNCDESC
37*c9945492SAndroid Build Coastguard Worker #define REL_FUNCDESC_VAL R_SH_FUNCDESC_VALUE
38*c9945492SAndroid Build Coastguard Worker #undef  REL_RELATIVE
39*c9945492SAndroid Build Coastguard Worker #define DL_FDPIC 1
40*c9945492SAndroid Build Coastguard Worker #define FDPIC_CONSTDISP_FLAG 0x100
41*c9945492SAndroid Build Coastguard Worker #define CRTJMP(pc,sp) do { \
42*c9945492SAndroid Build Coastguard Worker 	register size_t r8 __asm__("r8") = ((size_t *)(sp))[-2]; \
43*c9945492SAndroid Build Coastguard Worker 	__asm__ __volatile__( "jmp @%0 ; mov %1,r15" \
44*c9945492SAndroid Build Coastguard Worker 	: : "r"(pc), "r"(sp), "r"(r8) : "memory" ); } while(0)
45*c9945492SAndroid Build Coastguard Worker #define GETFUNCSYM(fp, sym, got) __asm__ ( \
46*c9945492SAndroid Build Coastguard Worker 	"mov.l 1f,%0 ; add %1,%0 ; bra 2f ; nop ; .align 2 \n" \
47*c9945492SAndroid Build Coastguard Worker 	"1:	.long " #sym "@GOTOFFFUNCDESC \n2:" \
48*c9945492SAndroid Build Coastguard Worker 	: "=&r"(*fp) : "r"(got) : "memory" )
49*c9945492SAndroid Build Coastguard Worker #else
50*c9945492SAndroid Build Coastguard Worker #define CRTJMP(pc,sp) __asm__ __volatile__( \
51*c9945492SAndroid Build Coastguard Worker 	"jmp @%0 ; mov %1,r15" : : "r"(pc), "r"(sp) : "memory" )
52*c9945492SAndroid Build Coastguard Worker #endif
53