musl/arch/riscv64/reloc.h

23 lines
663 B
C

#if defined __riscv_float_abi_soft
#define RISCV_FP_SUFFIX "-sf"
#elif defined __riscv_float_abi_single
#define RISCV_FP_SUFFIX "-sp"
#elif defined __riscv_float_abi_double
#define RISCV_FP_SUFFIX ""
#endif
#define LDSO_ARCH "riscv64" RISCV_FP_SUFFIX
#define TPOFF_K 0
#define REL_SYMBOLIC R_RISCV_64
#define REL_PLT R_RISCV_JUMP_SLOT
#define REL_RELATIVE R_RISCV_RELATIVE
#define REL_COPY R_RISCV_COPY
#define REL_DTPMOD R_RISCV_TLS_DTPMOD64
#define REL_DTPOFF R_RISCV_TLS_DTPREL64
#define REL_TPOFF R_RISCV_TLS_TPREL64
#define CRTJMP(pc,sp) __asm__ __volatile__( \
"mv sp, %1 ; jr %0" : : "r"(pc), "r"(sp) : "memory" )