X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Fx86_64%2Freloc.h;h=fac0c0ae3e779132766a158455e8cbb6c037c723;hb=3934f49c01d35565a9b74b3f9b29a913efa7c973;hp=6642fdd48a8cacf380e78b048b70ed1a2895d377;hpb=568b8075a4406ca8cb1f718e74fd0829cb7f0b90;p=musl diff --git a/arch/x86_64/reloc.h b/arch/x86_64/reloc.h index 6642fdd4..fac0c0ae 100644 --- a/arch/x86_64/reloc.h +++ b/arch/x86_64/reloc.h @@ -1,30 +1,20 @@ -#include -#include -#include +#define LDSO_ARCH "x86_64" -#define ETC_LDSO_PATH "/etc/ld-musl-x86_64.path" +#define REL_SYMBOLIC R_X86_64_64 +#define REL_OFFSET32 R_X86_64_PC32 +#define REL_GOT R_X86_64_GLOB_DAT +#define REL_PLT R_X86_64_JUMP_SLOT +#define REL_RELATIVE R_X86_64_RELATIVE +#define REL_COPY R_X86_64_COPY +#define REL_DTPMOD R_X86_64_DTPMOD64 +#define REL_DTPOFF R_X86_64_DTPOFF64 +#define REL_TPOFF R_X86_64_TPOFF64 +#define REL_TLSDESC R_X86_64_TLSDESC -#define IS_COPY(x) ((x)==R_X86_64_COPY) +#define CRTJMP(pc,sp) __asm__ __volatile__( \ + "mov %1,%%rsp ; jmp *%0" : : "r"(pc), "r"(sp) : "memory" ) -static inline void do_single_reloc(size_t *reloc_addr, int type, size_t sym_val, size_t sym_size, unsigned char *base_addr, size_t addend) -{ - switch(type) { - case R_X86_64_GLOB_DAT: - case R_X86_64_JUMP_SLOT: - case R_X86_64_64: - *reloc_addr = sym_val + addend; - break; - case R_X86_64_32: - *(uint32_t *)reloc_addr = sym_val + addend; - break; - case R_X86_64_PC32: - *reloc_addr = sym_val + addend - (size_t)reloc_addr + (size_t)base_addr; - break; - case R_X86_64_RELATIVE: - *reloc_addr = (size_t)base_addr + addend; - break; - case R_X86_64_COPY: - memcpy(reloc_addr, (void *)sym_val, sym_size); - break; - } -} +#define GETFUNCSYM(fp, sym, got) __asm__ ( \ + ".hidden " #sym "\n" \ + " lea " #sym "(%%rip),%0\n" \ + : "=r"(*fp) : : "memory" )