xref: /aosp_15_r20/external/musl/arch/loongarch64/reloc.h (revision c9945492fdd68bbe62686c5b452b4dc1be3f8453)
1 #ifdef __loongarch_soft_float
2 #define FP_SUFFIX "-sf"
3 #elif defined __loongarch_single_float
4 #define FP_SUFFIX "-sp"
5 #else
6 #define FP_SUFFIX ""
7 #endif
8 
9 #define LDSO_ARCH "loongarch64" FP_SUFFIX
10 
11 #define TPOFF_K         0
12 
13 #define REL_PLT         R_LARCH_JUMP_SLOT
14 #define REL_COPY        R_LARCH_COPY
15 #define REL_DTPMOD      R_LARCH_TLS_DTPMOD64
16 #define REL_DTPOFF      R_LARCH_TLS_DTPREL64
17 #define REL_TPOFF       R_LARCH_TLS_TPREL64
18 #define REL_RELATIVE    R_LARCH_RELATIVE
19 #define REL_SYMBOLIC    R_LARCH_64
20 
21 #define CRTJMP(pc,sp) __asm__ __volatile__( \
22 	"move $sp, %1 ; jr %0" : : "r"(pc), "r"(sp) : "memory" )
23 
24 #define GETFUNCSYM(fp, sym, got) __asm__ ( \
25 	".hidden " #sym "\n" \
26 	".align 8 \n" \
27 	"	la.local $t1, "#sym" \n" \
28 	"	move %0, $t1 \n" \
29 	: "=r"(*(fp)) : : "memory" )
30