remove all Elf32 hardcodes to make sure the elf handling is 64bit clean

This commit is contained in:
Mike Frysinger 2005-10-02 07:02:16 +00:00
parent 91fbdac6ab
commit 86a4bfb30a

View File

@ -528,6 +528,12 @@ static const int MODUTILS_OBJ_H = 1;
# define ELF64_ST_INFO(bind, type) (((bind) << 4) + ((type) & 0xf)) # define ELF64_ST_INFO(bind, type) (((bind) << 4) + ((type) & 0xf))
#endif #endif
#define ELF_ST_BIND(info) ELFW(ST_BIND)(info)
#define ELF_ST_TYPE(info) ELFW(ST_TYPE)(info)
#define ELF_ST_INFO(bind, type) ELFW(ST_INFO)(bind, type)
#define ELF_R_TYPE(val) ELFW(R_TYPE)(val)
#define ELF_R_SYM(val) ELFW(R_SYM)(val)
struct obj_string_patch; struct obj_string_patch;
struct obj_symbol_patch; struct obj_symbol_patch;
@ -726,8 +732,8 @@ struct arch_single_entry
struct mips_hi16 struct mips_hi16
{ {
struct mips_hi16 *next; struct mips_hi16 *next;
Elf32_Addr *addr; ElfW(Addr) *addr;
Elf32_Addr value; ElfW(Addr) value;
}; };
#endif #endif
@ -859,7 +865,7 @@ arch_apply_relocation(struct obj_file *f,
#endif #endif
#endif #endif
switch (ELF32_R_TYPE(rel->r_info)) { switch (ELF_R_TYPE(rel->r_info)) {
#if defined(__arm__) #if defined(__arm__)
case R_ARM_NONE: case R_ARM_NONE:
@ -921,7 +927,7 @@ arch_apply_relocation(struct obj_file *f,
ip = (unsigned long *)(ifile->plt->contents + pe->offset); ip = (unsigned long *)(ifile->plt->contents + pe->offset);
ip[0] = 0x0d105810; /* basr 1,0; lg 1,10(1); br 1 */ ip[0] = 0x0d105810; /* basr 1,0; lg 1,10(1); br 1 */
ip[1] = 0x100607f1; ip[1] = 0x100607f1;
if (ELF32_R_TYPE(rel->r_info) == R_390_PLT16DBL) if (ELF_R_TYPE(rel->r_info) == R_390_PLT16DBL)
ip[2] = v - 2; ip[2] = v - 2;
else else
ip[2] = v; ip[2] = v;
@ -930,9 +936,9 @@ arch_apply_relocation(struct obj_file *f,
/* Insert relative distance to target. */ /* Insert relative distance to target. */
v = plt + pe->offset - dot; v = plt + pe->offset - dot;
if (ELF32_R_TYPE(rel->r_info) == R_390_PLT32) if (ELF_R_TYPE(rel->r_info) == R_390_PLT32)
*(unsigned int *) loc = (unsigned int) v; *(unsigned int *) loc = (unsigned int) v;
else if (ELF32_R_TYPE(rel->r_info) == R_390_PLT16DBL) else if (ELF_R_TYPE(rel->r_info) == R_390_PLT16DBL)
*(unsigned short *) loc = (unsigned short) ((v + 2) >> 1); *(unsigned short *) loc = (unsigned short) ((v + 2) >> 1);
break; break;
@ -958,13 +964,13 @@ arch_apply_relocation(struct obj_file *f,
if (!isym->gotent.inited) if (!isym->gotent.inited)
{ {
isym->gotent.inited = 1; isym->gotent.inited = 1;
*(Elf32_Addr *)(ifile->got->contents + isym->gotent.offset) = v; *(ElfW(Addr) *)(ifile->got->contents + isym->gotent.offset) = v;
} }
if (ELF32_R_TYPE(rel->r_info) == R_390_GOT12) if (ELF_R_TYPE(rel->r_info) == R_390_GOT12)
*(unsigned short *) loc |= (*(unsigned short *) loc + isym->gotent.offset) & 0xfff; *(unsigned short *) loc |= (*(unsigned short *) loc + isym->gotent.offset) & 0xfff;
else if (ELF32_R_TYPE(rel->r_info) == R_390_GOT16) else if (ELF_R_TYPE(rel->r_info) == R_390_GOT16)
*(unsigned short *) loc += isym->gotent.offset; *(unsigned short *) loc += isym->gotent.offset;
else if (ELF32_R_TYPE(rel->r_info) == R_390_GOT32) else if (ELF_R_TYPE(rel->r_info) == R_390_GOT32)
*(unsigned int *) loc += isym->gotent.offset; *(unsigned int *) loc += isym->gotent.offset;
break; break;
@ -1106,8 +1112,8 @@ arch_apply_relocation(struct obj_file *f,
case R_68K_PC8: case R_68K_PC8:
v -= dot; v -= dot;
if ((Elf32_Sword)v > 0x7f || if ((ElfW(Sword))v > 0x7f ||
(Elf32_Sword)v < -(Elf32_Sword)0x80) { (ElfW(Sword))v < -(ElfW(Sword))0x80) {
ret = obj_reloc_overflow; ret = obj_reloc_overflow;
} }
*(char *)loc = v; *(char *)loc = v;
@ -1115,8 +1121,8 @@ arch_apply_relocation(struct obj_file *f,
case R_68K_PC16: case R_68K_PC16:
v -= dot; v -= dot;
if ((Elf32_Sword)v > 0x7fff || if ((ElfW(Sword))v > 0x7fff ||
(Elf32_Sword)v < -(Elf32_Sword)0x8000) { (ElfW(Sword))v < -(ElfW(Sword))0x8000) {
ret = obj_reloc_overflow; ret = obj_reloc_overflow;
} }
*(short *)loc = v; *(short *)loc = v;
@ -1182,7 +1188,7 @@ arch_apply_relocation(struct obj_file *f,
case R_MIPS_LO16: case R_MIPS_LO16:
{ {
unsigned long insnlo = *loc; unsigned long insnlo = *loc;
Elf32_Addr val, vallo; ElfW(Addr) val, vallo;
/* Sign extend the addend we extract from the lo insn. */ /* Sign extend the addend we extract from the lo insn. */
vallo = ((insnlo & 0xffff) ^ 0x8000) - 0x8000; vallo = ((insnlo & 0xffff) ^ 0x8000) - 0x8000;
@ -1300,9 +1306,9 @@ arch_apply_relocation(struct obj_file *f,
case R_SH_IMM_MEDLOW16: case R_SH_IMM_MEDLOW16:
case R_SH_IMM_LOW16: case R_SH_IMM_LOW16:
{ {
Elf32_Addr word; ElfW(Addr) word;
if (ELF32_R_TYPE(rel->r_info) == R_SH_IMM_MEDLOW16) if (ELF_R_TYPE(rel->r_info) == R_SH_IMM_MEDLOW16)
v >>= 16; v >>= 16;
/* /*
@ -1324,13 +1330,13 @@ arch_apply_relocation(struct obj_file *f,
case R_SH_IMM_MEDLOW16_PCREL: case R_SH_IMM_MEDLOW16_PCREL:
case R_SH_IMM_LOW16_PCREL: case R_SH_IMM_LOW16_PCREL:
{ {
Elf32_Addr word; ElfW(Addr) word;
word = *loc & ~0x3fffc00; word = *loc & ~0x3fffc00;
v -= dot; v -= dot;
if (ELF32_R_TYPE(rel->r_info) == R_SH_IMM_MEDLOW16_PCREL) if (ELF_R_TYPE(rel->r_info) == R_SH_IMM_MEDLOW16_PCREL)
v >>= 16; v >>= 16;
word |= (v & 0xffff) << 10; word |= (v & 0xffff) << 10;
@ -1343,7 +1349,7 @@ arch_apply_relocation(struct obj_file *f,
#endif /* __sh__ */ #endif /* __sh__ */
default: default:
printf("Warning: unhandled reloc %d\n",(int)ELF32_R_TYPE(rel->r_info)); printf("Warning: unhandled reloc %d\n",(int)ELF_R_TYPE(rel->r_info));
ret = obj_reloc_unhandled; ret = obj_reloc_unhandled;
break; break;
@ -1391,16 +1397,16 @@ arch_apply_relocation(struct obj_file *f,
break; break;
case R_H8_PCREL16: case R_H8_PCREL16:
v -= dot + 2; v -= dot + 2;
if ((Elf32_Sword)v > 0x7fff || if ((ElfW(Sword))v > 0x7fff ||
(Elf32_Sword)v < -(Elf32_Sword)0x8000) (ElfW(Sword))v < -(ElfW(Sword))0x8000)
ret = obj_reloc_overflow; ret = obj_reloc_overflow;
else else
*(unsigned short *)loc = v; *(unsigned short *)loc = v;
break; break;
case R_H8_PCREL8: case R_H8_PCREL8:
v -= dot + 1; v -= dot + 1;
if ((Elf32_Sword)v > 0x7f || if ((ElfW(Sword))v > 0x7f ||
(Elf32_Sword)v < -(Elf32_Sword)0x80) (ElfW(Sword))v < -(ElfW(Sword))0x80)
ret = obj_reloc_overflow; ret = obj_reloc_overflow;
else else
*(unsigned char *)loc = v; *(unsigned char *)loc = v;
@ -1453,7 +1459,7 @@ bb_use_plt:
#if defined (__arm__) || defined (__powerpc__) #if defined (__arm__) || defined (__powerpc__)
if ((int)v < -0x02000000 || (int)v >= 0x02000000) if ((int)v < -0x02000000 || (int)v >= 0x02000000)
#elif defined (__v850e__) #elif defined (__v850e__)
if ((Elf32_Sword)v > 0x1fffff || (Elf32_Sword)v < (Elf32_Sword)-0x200000) if ((ElfW(Sword))v > 0x1fffff || (ElfW(Sword))v < (ElfW(Sword))-0x200000)
#endif #endif
/* go via the plt */ /* go via the plt */
v = plt + pe->offset - dot; v = plt + pe->offset - dot;
@ -1610,7 +1616,7 @@ static void arch_create_got(struct obj_file *f)
strtab = (const char *) strsec->contents; strtab = (const char *) strsec->contents;
for (; rel < relend; ++rel) { for (; rel < relend; ++rel) {
extsym = &symtab[ELF32_R_SYM(rel->r_info)]; extsym = &symtab[ELF_R_SYM(rel->r_info)];
#if defined(CONFIG_USE_GOT_ENTRIES) #if defined(CONFIG_USE_GOT_ENTRIES)
got_allocate = 0; got_allocate = 0;
@ -1619,7 +1625,7 @@ static void arch_create_got(struct obj_file *f)
plt_allocate = 0; plt_allocate = 0;
#endif #endif
switch (ELF32_R_TYPE(rel->r_info)) { switch (ELF_R_TYPE(rel->r_info)) {
#if defined(__arm__) #if defined(__arm__)
case R_ARM_PC24: case R_ARM_PC24:
case R_ARM_PLT32: case R_ARM_PLT32:
@ -1818,15 +1824,15 @@ obj_add_symbol(struct obj_file *f, const char *name,
{ {
struct obj_symbol *sym; struct obj_symbol *sym;
unsigned long hash = f->symbol_hash(name) % HASH_BUCKETS; unsigned long hash = f->symbol_hash(name) % HASH_BUCKETS;
int n_type = ELFW(ST_TYPE) (info); int n_type = ELF_ST_TYPE(info);
int n_binding = ELFW(ST_BIND) (info); int n_binding = ELF_ST_BIND(info);
for (sym = f->symtab[hash]; sym; sym = sym->next) for (sym = f->symtab[hash]; sym; sym = sym->next)
if (f->symbol_cmp(sym->name, name) == 0) { if (f->symbol_cmp(sym->name, name) == 0) {
int o_secidx = sym->secidx; int o_secidx = sym->secidx;
int o_info = sym->info; int o_info = sym->info;
int o_type = ELFW(ST_TYPE) (o_info); int o_type = ELF_ST_TYPE(o_info);
int o_binding = ELFW(ST_BIND) (o_info); int o_binding = ELF_ST_BIND(o_info);
/* A redefinition! Is it legal? */ /* A redefinition! Is it legal? */
@ -1887,7 +1893,7 @@ obj_add_symbol(struct obj_file *f, const char *name,
f->symtab[hash] = sym; f->symtab[hash] = sym;
sym->ksymidx = -1; sym->ksymidx = -1;
if (ELFW(ST_BIND)(info) == STB_LOCAL && symidx != -1) { if (ELF_ST_BIND(info) == STB_LOCAL && symidx != -1) {
if (symidx >= f->local_symtab_size) if (symidx >= f->local_symtab_size)
bb_error_msg("local symbol %s with index %ld exceeds local_symtab_size %ld", bb_error_msg("local symbol %s with index %ld exceeds local_symtab_size %ld",
name, (long) symidx, (long) f->local_symtab_size); name, (long) symidx, (long) f->local_symtab_size);
@ -2101,14 +2107,14 @@ add_symbols_from( struct obj_file *f,
#endif /* SYMBOL_PREFIX */ #endif /* SYMBOL_PREFIX */
sym = obj_find_symbol(f, name); sym = obj_find_symbol(f, name);
if (sym && !(ELFW(ST_BIND) (sym->info) == STB_LOCAL)) { if (sym && !(ELF_ST_BIND(sym->info) == STB_LOCAL)) {
#ifdef SYMBOL_PREFIX #ifdef SYMBOL_PREFIX
/* Put NAME_BUF into more permanent storage. */ /* Put NAME_BUF into more permanent storage. */
name = xmalloc (name_size); name = xmalloc (name_size);
strcpy (name, name_buf); strcpy (name, name_buf);
#endif #endif
sym = obj_add_symbol(f, name, -1, sym = obj_add_symbol(f, name, -1,
ELFW(ST_INFO) (STB_GLOBAL, ELF_ST_INFO(STB_GLOBAL,
STT_NOTYPE), STT_NOTYPE),
idx, s->value, 0); idx, s->value, 0);
/* Did our symbol just get installed? If so, mark the /* Did our symbol just get installed? If so, mark the
@ -2569,7 +2575,7 @@ static int new_create_this_module(struct obj_file *f, const char *m_name)
memset(sec->contents, 0, sizeof(struct new_module)); memset(sec->contents, 0, sizeof(struct new_module));
obj_add_symbol(f, SPFX "__this_module", -1, obj_add_symbol(f, SPFX "__this_module", -1,
ELFW(ST_INFO) (STB_LOCAL, STT_OBJECT), sec->idx, 0, ELF_ST_INFO(STB_LOCAL, STT_OBJECT), sec->idx, 0,
sizeof(struct new_module)); sizeof(struct new_module));
obj_string_patch(f, sec->idx, offsetof(struct new_module, name), obj_string_patch(f, sec->idx, offsetof(struct new_module, name),
@ -2658,7 +2664,7 @@ static int new_create_module_ksymtab(struct obj_file *f)
for (nsyms = i = 0; i < HASH_BUCKETS; ++i) { for (nsyms = i = 0; i < HASH_BUCKETS; ++i) {
struct obj_symbol *sym; struct obj_symbol *sym;
for (sym = f->symtab[i]; sym; sym = sym->next) for (sym = f->symtab[i]; sym; sym = sym->next)
if (ELFW(ST_BIND) (sym->info) != STB_LOCAL if (ELF_ST_BIND(sym->info) != STB_LOCAL
&& sym->secidx <= SHN_HIRESERVE && sym->secidx <= SHN_HIRESERVE
&& (sym->secidx >= SHN_LORESERVE && (sym->secidx >= SHN_LORESERVE
|| loaded[sym->secidx])) { || loaded[sym->secidx])) {
@ -2815,7 +2821,7 @@ static int obj_check_undefineds(struct obj_file *f)
struct obj_symbol *sym; struct obj_symbol *sym;
for (sym = f->symtab[i]; sym; sym = sym->next) for (sym = f->symtab[i]; sym; sym = sym->next)
if (sym->secidx == SHN_UNDEF) { if (sym->secidx == SHN_UNDEF) {
if (ELFW(ST_BIND) (sym->info) == STB_WEAK) { if (ELF_ST_BIND(sym->info) == STB_WEAK) {
sym->secidx = SHN_ABS; sym->secidx = SHN_ABS;
sym->value = 0; sym->value = 0;
} else { } else {
@ -3001,12 +3007,12 @@ static int obj_relocate(struct obj_file *f, ElfW(Addr) base)
/* Attempt to find a value to use for this relocation. */ /* Attempt to find a value to use for this relocation. */
symndx = ELFW(R_SYM) (rel->r_info); symndx = ELF_R_SYM(rel->r_info);
if (symndx) { if (symndx) {
/* Note we've already checked for undefined symbols. */ /* Note we've already checked for undefined symbols. */
extsym = &symtab[symndx]; extsym = &symtab[symndx];
if (ELFW(ST_BIND) (extsym->st_info) == STB_LOCAL) { if (ELF_ST_BIND(extsym->st_info) == STB_LOCAL) {
/* Local symbols we look up in the local table to be sure /* Local symbols we look up in the local table to be sure
we get the one that is really intended. */ we get the one that is really intended. */
intsym = f->local_symtab[symndx]; intsym = f->local_symtab[symndx];
@ -3027,7 +3033,7 @@ static int obj_relocate(struct obj_file *f, ElfW(Addr) base)
#if defined(__alpha__) && defined(AXP_BROKEN_GAS) #if defined(__alpha__) && defined(AXP_BROKEN_GAS)
/* Work around a nasty GAS bug, that is fixed as of 2.7.0.9. */ /* Work around a nasty GAS bug, that is fixed as of 2.7.0.9. */
if (!extsym || !extsym->st_name || if (!extsym || !extsym->st_name ||
ELFW(ST_BIND) (extsym->st_info) != STB_LOCAL) ELF_ST_BIND(extsym->st_info) != STB_LOCAL)
#endif #endif
value += rel->r_addend; value += rel->r_addend;
#endif #endif
@ -3049,11 +3055,11 @@ static int obj_relocate(struct obj_file *f, ElfW(Addr) base)
bad_reloc: bad_reloc:
if (extsym) { if (extsym) {
bb_error_msg("%s of type %ld for %s", errmsg, bb_error_msg("%s of type %ld for %s", errmsg,
(long) ELFW(R_TYPE) (rel->r_info), (long) ELF_R_TYPE(rel->r_info),
strtab + extsym->st_name); strtab + extsym->st_name);
} else { } else {
bb_error_msg("%s of type %ld", errmsg, bb_error_msg("%s of type %ld", errmsg,
(long) ELFW(R_TYPE) (rel->r_info)); (long) ELF_R_TYPE(rel->r_info));
} }
ret = 0; ret = 0;
break; break;
@ -3373,7 +3379,7 @@ static void hide_special_symbols(struct obj_file *f)
for (p = specials; *p; ++p) for (p = specials; *p; ++p)
if ((sym = obj_find_symbol(f, *p)) != NULL) if ((sym = obj_find_symbol(f, *p)) != NULL)
sym->info = sym->info =
ELFW(ST_INFO) (STB_LOCAL, ELFW(ST_TYPE) (sym->info)); ELF_ST_INFO(STB_LOCAL, ELF_ST_TYPE(sym->info));
} }
@ -3577,7 +3583,7 @@ add_ksymoops_symbols(struct obj_file *f, const char *filename,
(int)(2*sizeof(statbuf.st_mtime)), statbuf.st_mtime, (int)(2*sizeof(statbuf.st_mtime)), statbuf.st_mtime,
version); version);
sym = obj_add_symbol(f, name, -1, sym = obj_add_symbol(f, name, -1,
ELFW(ST_INFO) (STB_GLOBAL, STT_NOTYPE), ELF_ST_INFO(STB_GLOBAL, STT_NOTYPE),
sec->idx, sec->header.sh_addr, 0); sec->idx, sec->header.sh_addr, 0);
if (use_ksymtab) if (use_ksymtab)
new_add_ksymtab(f, sym); new_add_ksymtab(f, sym);
@ -3595,7 +3601,7 @@ add_ksymoops_symbols(struct obj_file *f, const char *filename,
name = xmalloc(l); name = xmalloc(l);
snprintf(name, l, "%s%s_P%s", snprintf(name, l, "%s%s_P%s",
symprefix, m_name, f->persist); symprefix, m_name, f->persist);
sym = obj_add_symbol(f, name, -1, ELFW(ST_INFO) (STB_GLOBAL, STT_NOTYPE), sym = obj_add_symbol(f, name, -1, ELF_ST_INFO(STB_GLOBAL, STT_NOTYPE),
sec->idx, sec->header.sh_addr, 0); sec->idx, sec->header.sh_addr, 0);
if (use_ksymtab) if (use_ksymtab)
new_add_ksymtab(f, sym); new_add_ksymtab(f, sym);
@ -3617,7 +3623,7 @@ add_ksymoops_symbols(struct obj_file *f, const char *filename,
snprintf(name, l, "%s%s_S%s_L%ld", snprintf(name, l, "%s%s_S%s_L%ld",
symprefix, m_name, sec->name, symprefix, m_name, sec->name,
(long)sec->header.sh_size); (long)sec->header.sh_size);
sym = obj_add_symbol(f, name, -1, ELFW(ST_INFO) (STB_GLOBAL, STT_NOTYPE), sym = obj_add_symbol(f, name, -1, ELF_ST_INFO(STB_GLOBAL, STT_NOTYPE),
sec->idx, sec->header.sh_addr, 0); sec->idx, sec->header.sh_addr, 0);
if (use_ksymtab) if (use_ksymtab)
new_add_ksymtab(f, sym); new_add_ksymtab(f, sym);
@ -3707,7 +3713,7 @@ static void print_load_map(struct obj_file *f)
value = sym->value + sec->header.sh_addr; value = sym->value + sec->header.sh_addr;
} }
if (ELFW(ST_BIND) (sym->info) == STB_LOCAL) if (ELF_ST_BIND(sym->info) == STB_LOCAL)
type = tolower(type); type = tolower(type);
printf("%0*lx %c %s\n", (int) (2 * sizeof(void *)), value, printf("%0*lx %c %s\n", (int) (2 * sizeof(void *)), value,