OSDN Git Service

Add protected symbols support for all architectures
[uclinux-h8/uClibc.git] / ldso / ldso / i386 / elfinterp.c
index a01c1d0..0017c23 100644 (file)
@@ -168,16 +168,19 @@ _dl_do_reloc(struct elf_resolve *tpnt, struct dyn_elf *scope,
 #if defined (__SUPPORT_LD_DEBUG__)
        unsigned long old_val;
 #endif
+       struct symbol_ref sym_ref;
 
        reloc_addr = (unsigned long *)(intptr_t)(tpnt->loadaddr + (unsigned long)rpnt->r_offset);
        reloc_type = ELF32_R_TYPE(rpnt->r_info);
        symtab_index = ELF32_R_SYM(rpnt->r_info);
        symbol_addr = 0;
+       sym_ref.sym = &symtab[symtab_index];
+       sym_ref.tpnt = NULL;
        symname = strtab + symtab[symtab_index].st_name;
 
        if (symtab_index) {
                symbol_addr = (unsigned long)_dl_find_hash(symname, scope, tpnt,
-                                                          elf_machine_type_class(reloc_type), &tls_tpnt);
+                                                          elf_machine_type_class(reloc_type), &sym_ref);
 
                /*
                 * We want to allow undefined references to weak symbols - this
@@ -187,6 +190,7 @@ _dl_do_reloc(struct elf_resolve *tpnt, struct dyn_elf *scope,
                if (unlikely(!symbol_addr && (ELF_ST_TYPE(symtab[symtab_index].st_info) != STT_TLS)
                                        && ELF32_ST_BIND(symtab[symtab_index].st_info) != STB_WEAK))
                        return 1;
+               tls_tpnt = sym_ref.tpnt;
        } else {
                symbol_addr = symtab[symtab_index].st_value;
                tls_tpnt = tpnt;