X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Fi386%2Freloc.h;h=eaf5aae03527db64176a7788d5115a67c41086a5;hb=7d310ed1d086d9874b7ca40933ff870a8adc75d9;hp=02b5fa0291679416963ac6a7414eacae2ee305ec;hpb=51e2d8310222ddd4d4e895f55c627100d863aa95;p=musl diff --git a/arch/i386/reloc.h b/arch/i386/reloc.h index 02b5fa02..eaf5aae0 100644 --- a/arch/i386/reloc.h +++ b/arch/i386/reloc.h @@ -1,26 +1,33 @@ #include #include -#define IS_COPY(x) ((x)==R_386_COPY) +#define LDSO_ARCH "i386" -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) +static int remap_rel(int type) { switch(type) { case R_386_32: - *reloc_addr += sym_val; - break; + return REL_SYMBOLIC; case R_386_PC32: - *reloc_addr += sym_val - (size_t)reloc_addr; - break; + return REL_OFFSET; case R_386_GLOB_DAT: + return REL_GOT; case R_386_JMP_SLOT: - *reloc_addr = sym_val; - break; + return REL_PLT; case R_386_RELATIVE: - *reloc_addr += (size_t)base_addr; - break; + return REL_RELATIVE; case R_386_COPY: - memcpy(reloc_addr, (void *)sym_val, sym_size); - break; + return REL_COPY; + case R_386_TLS_DTPMOD32: + return REL_DTPMOD; + case R_386_TLS_DTPOFF32: + return REL_DTPOFF; + case R_386_TLS_TPOFF: + return REL_TPOFF; + case R_386_TLS_TPOFF32: + return REL_TPOFF_NEG; + case R_386_TLS_DESC: + return REL_TLSDESC; } + return 0; }