reorder arches into alphabetical order
This commit is contained in:
parent
fa17c4b949
commit
cb1ce7b974
@ -143,6 +143,16 @@ extern int insmod_ng_main( int argc, char **argv);
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* H8/300 */
|
||||||
|
#if defined(__H8300H__) || defined(__H8300S__)
|
||||||
|
#define MATCH_MACHINE(x) (x == EM_H8_300)
|
||||||
|
#define SHT_RELM SHT_RELA
|
||||||
|
#define Elf32_RelM Elf32_Rela
|
||||||
|
#define ELFCLASSM ELFCLASS32
|
||||||
|
#define CONFIG_USE_SINGLE
|
||||||
|
#define SYMBOL_PREFIX "_"
|
||||||
|
#endif
|
||||||
|
|
||||||
/* PA-RISC / HP-PA */
|
/* PA-RISC / HP-PA */
|
||||||
#if defined(__hppa__)
|
#if defined(__hppa__)
|
||||||
#define MATCH_MACHINE(x) (x == EM_PARISC)
|
#define MATCH_MACHINE(x) (x == EM_PARISC)
|
||||||
@ -156,16 +166,6 @@ extern int insmod_ng_main( int argc, char **argv);
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* H8/300 */
|
|
||||||
#if defined(__H8300H__) || defined(__H8300S__)
|
|
||||||
#define MATCH_MACHINE(x) (x == EM_H8_300)
|
|
||||||
#define SHT_RELM SHT_RELA
|
|
||||||
#define Elf32_RelM Elf32_Rela
|
|
||||||
#define ELFCLASSM ELFCLASS32
|
|
||||||
#define CONFIG_USE_SINGLE
|
|
||||||
#define SYMBOL_PREFIX "_"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* x86 */
|
/* x86 */
|
||||||
#if defined(__i386__)
|
#if defined(__i386__)
|
||||||
#ifndef EM_486
|
#ifndef EM_486
|
||||||
@ -868,6 +868,7 @@ arch_apply_relocation(struct obj_file *f,
|
|||||||
switch (ELF_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:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -896,90 +897,46 @@ arch_apply_relocation(struct obj_file *f,
|
|||||||
*loc += v - got;
|
*loc += v - got;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#elif defined(__s390__)
|
#elif defined(__cris__)
|
||||||
case R_390_32:
|
|
||||||
*(unsigned int *) loc += v;
|
case R_CRIS_NONE:
|
||||||
break;
|
|
||||||
case R_390_16:
|
|
||||||
*(unsigned short *) loc += v;
|
|
||||||
break;
|
|
||||||
case R_390_8:
|
|
||||||
*(unsigned char *) loc += v;
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case R_390_PC32:
|
case R_CRIS_32:
|
||||||
*(unsigned int *) loc += v - dot;
|
/* CRIS keeps the relocation value in the r_addend field and
|
||||||
break;
|
* should not use whats in *loc at all
|
||||||
case R_390_PC16DBL:
|
*/
|
||||||
*(unsigned short *) loc += (v - dot) >> 1;
|
|
||||||
break;
|
|
||||||
case R_390_PC16:
|
|
||||||
*(unsigned short *) loc += v - dot;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_390_PLT32:
|
|
||||||
case R_390_PLT16DBL:
|
|
||||||
/* find the plt entry and initialize it. */
|
|
||||||
assert(isym != NULL);
|
|
||||||
pe = (struct arch_single_entry *) &isym->pltent;
|
|
||||||
assert(pe->allocated);
|
|
||||||
if (pe->inited == 0) {
|
|
||||||
ip = (unsigned long *)(ifile->plt->contents + pe->offset);
|
|
||||||
ip[0] = 0x0d105810; /* basr 1,0; lg 1,10(1); br 1 */
|
|
||||||
ip[1] = 0x100607f1;
|
|
||||||
if (ELF_R_TYPE(rel->r_info) == R_390_PLT16DBL)
|
|
||||||
ip[2] = v - 2;
|
|
||||||
else
|
|
||||||
ip[2] = v;
|
|
||||||
pe->inited = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Insert relative distance to target. */
|
|
||||||
v = plt + pe->offset - dot;
|
|
||||||
if (ELF_R_TYPE(rel->r_info) == R_390_PLT32)
|
|
||||||
*(unsigned int *) loc = (unsigned int) v;
|
|
||||||
else if (ELF_R_TYPE(rel->r_info) == R_390_PLT16DBL)
|
|
||||||
*(unsigned short *) loc = (unsigned short) ((v + 2) >> 1);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_390_GLOB_DAT:
|
|
||||||
case R_390_JMP_SLOT:
|
|
||||||
*loc = v;
|
*loc = v;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case R_390_RELATIVE:
|
#elif defined(__H8300H__) || defined(__H8300S__)
|
||||||
*loc += f->baseaddr;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_390_GOTPC:
|
case R_H8_DIR24R8:
|
||||||
assert(got != 0);
|
loc = (ElfW(Addr) *)((ElfW(Addr))loc - 1);
|
||||||
*(unsigned long *) loc += got - dot;
|
*loc = (*loc & 0xff000000) | ((*loc & 0xffffff) + v);
|
||||||
break;
|
break;
|
||||||
|
case R_H8_DIR24A8:
|
||||||
case R_390_GOT12:
|
*loc += v;
|
||||||
case R_390_GOT16:
|
|
||||||
case R_390_GOT32:
|
|
||||||
assert(isym != NULL);
|
|
||||||
assert(got != 0);
|
|
||||||
if (!isym->gotent.inited)
|
|
||||||
{
|
|
||||||
isym->gotent.inited = 1;
|
|
||||||
*(ElfW(Addr) *)(ifile->got->contents + isym->gotent.offset) = v;
|
|
||||||
}
|
|
||||||
if (ELF_R_TYPE(rel->r_info) == R_390_GOT12)
|
|
||||||
*(unsigned short *) loc |= (*(unsigned short *) loc + isym->gotent.offset) & 0xfff;
|
|
||||||
else if (ELF_R_TYPE(rel->r_info) == R_390_GOT16)
|
|
||||||
*(unsigned short *) loc += isym->gotent.offset;
|
|
||||||
else if (ELF_R_TYPE(rel->r_info) == R_390_GOT32)
|
|
||||||
*(unsigned int *) loc += isym->gotent.offset;
|
|
||||||
break;
|
break;
|
||||||
|
case R_H8_DIR32:
|
||||||
#ifndef R_390_GOTOFF32
|
case R_H8_DIR32A16:
|
||||||
#define R_390_GOTOFF32 R_390_GOTOFF
|
*loc += v;
|
||||||
#endif
|
break;
|
||||||
case R_390_GOTOFF32:
|
case R_H8_PCREL16:
|
||||||
assert(got != 0);
|
v -= dot + 2;
|
||||||
*loc += v - got;
|
if ((ElfW(Sword))v > 0x7fff ||
|
||||||
|
(ElfW(Sword))v < -(ElfW(Sword))0x8000)
|
||||||
|
ret = obj_reloc_overflow;
|
||||||
|
else
|
||||||
|
*(unsigned short *)loc = v;
|
||||||
|
break;
|
||||||
|
case R_H8_PCREL8:
|
||||||
|
v -= dot + 1;
|
||||||
|
if ((ElfW(Sword))v > 0x7f ||
|
||||||
|
(ElfW(Sword))v < -(ElfW(Sword))0x80)
|
||||||
|
ret = obj_reloc_overflow;
|
||||||
|
else
|
||||||
|
*(unsigned char *)loc = v;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#elif defined(__i386__)
|
#elif defined(__i386__)
|
||||||
@ -1018,75 +975,6 @@ arch_apply_relocation(struct obj_file *f,
|
|||||||
*loc += v - got;
|
*loc += v - got;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#elif defined(__x86_64__)
|
|
||||||
|
|
||||||
case R_X86_64_NONE:
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_64:
|
|
||||||
*loc += v;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_32:
|
|
||||||
*(unsigned int *) loc += v;
|
|
||||||
if (v > 0xffffffff)
|
|
||||||
{
|
|
||||||
ret = obj_reloc_overflow; /* Kernel module compiled without -mcmodel=kernel. */
|
|
||||||
/* error("Possibly is module compiled without -mcmodel=kernel!"); */
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_32S:
|
|
||||||
*(signed int *) loc += v;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_16:
|
|
||||||
*(unsigned short *) loc += v;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_8:
|
|
||||||
*(unsigned char *) loc += v;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_PC32:
|
|
||||||
*(unsigned int *) loc += v - dot;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_PC16:
|
|
||||||
*(unsigned short *) loc += v - dot;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_PC8:
|
|
||||||
*(unsigned char *) loc += v - dot;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_GLOB_DAT:
|
|
||||||
case R_X86_64_JUMP_SLOT:
|
|
||||||
*loc = v;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_RELATIVE:
|
|
||||||
*loc += f->baseaddr;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case R_X86_64_GOT32:
|
|
||||||
case R_X86_64_GOTPCREL:
|
|
||||||
goto bb_use_got;
|
|
||||||
#if 0
|
|
||||||
assert(isym != NULL);
|
|
||||||
if (!isym->gotent.reloc_done)
|
|
||||||
{
|
|
||||||
isym->gotent.reloc_done = 1;
|
|
||||||
*(Elf64_Addr *)(ifile->got->contents + isym->gotent.offset) = v;
|
|
||||||
}
|
|
||||||
/* XXX are these really correct? */
|
|
||||||
if (ELF64_R_TYPE(rel->r_info) == R_X86_64_GOTPCREL)
|
|
||||||
*(unsigned int *) loc += v + isym->gotent.offset;
|
|
||||||
else
|
|
||||||
*loc += isym->gotent.offset;
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#elif defined(__mc68000__)
|
#elif defined(__mc68000__)
|
||||||
|
|
||||||
case R_68K_NONE:
|
case R_68K_NONE:
|
||||||
@ -1263,6 +1151,93 @@ arch_apply_relocation(struct obj_file *f,
|
|||||||
*loc = v;
|
*loc = v;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
#elif defined(__s390__)
|
||||||
|
|
||||||
|
case R_390_32:
|
||||||
|
*(unsigned int *) loc += v;
|
||||||
|
break;
|
||||||
|
case R_390_16:
|
||||||
|
*(unsigned short *) loc += v;
|
||||||
|
break;
|
||||||
|
case R_390_8:
|
||||||
|
*(unsigned char *) loc += v;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_390_PC32:
|
||||||
|
*(unsigned int *) loc += v - dot;
|
||||||
|
break;
|
||||||
|
case R_390_PC16DBL:
|
||||||
|
*(unsigned short *) loc += (v - dot) >> 1;
|
||||||
|
break;
|
||||||
|
case R_390_PC16:
|
||||||
|
*(unsigned short *) loc += v - dot;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_390_PLT32:
|
||||||
|
case R_390_PLT16DBL:
|
||||||
|
/* find the plt entry and initialize it. */
|
||||||
|
assert(isym != NULL);
|
||||||
|
pe = (struct arch_single_entry *) &isym->pltent;
|
||||||
|
assert(pe->allocated);
|
||||||
|
if (pe->inited == 0) {
|
||||||
|
ip = (unsigned long *)(ifile->plt->contents + pe->offset);
|
||||||
|
ip[0] = 0x0d105810; /* basr 1,0; lg 1,10(1); br 1 */
|
||||||
|
ip[1] = 0x100607f1;
|
||||||
|
if (ELF_R_TYPE(rel->r_info) == R_390_PLT16DBL)
|
||||||
|
ip[2] = v - 2;
|
||||||
|
else
|
||||||
|
ip[2] = v;
|
||||||
|
pe->inited = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Insert relative distance to target. */
|
||||||
|
v = plt + pe->offset - dot;
|
||||||
|
if (ELF_R_TYPE(rel->r_info) == R_390_PLT32)
|
||||||
|
*(unsigned int *) loc = (unsigned int) v;
|
||||||
|
else if (ELF_R_TYPE(rel->r_info) == R_390_PLT16DBL)
|
||||||
|
*(unsigned short *) loc = (unsigned short) ((v + 2) >> 1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_390_GLOB_DAT:
|
||||||
|
case R_390_JMP_SLOT:
|
||||||
|
*loc = v;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_390_RELATIVE:
|
||||||
|
*loc += f->baseaddr;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_390_GOTPC:
|
||||||
|
assert(got != 0);
|
||||||
|
*(unsigned long *) loc += got - dot;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_390_GOT12:
|
||||||
|
case R_390_GOT16:
|
||||||
|
case R_390_GOT32:
|
||||||
|
assert(isym != NULL);
|
||||||
|
assert(got != 0);
|
||||||
|
if (!isym->gotent.inited)
|
||||||
|
{
|
||||||
|
isym->gotent.inited = 1;
|
||||||
|
*(ElfW(Addr) *)(ifile->got->contents + isym->gotent.offset) = v;
|
||||||
|
}
|
||||||
|
if (ELF_R_TYPE(rel->r_info) == R_390_GOT12)
|
||||||
|
*(unsigned short *) loc |= (*(unsigned short *) loc + isym->gotent.offset) & 0xfff;
|
||||||
|
else if (ELF_R_TYPE(rel->r_info) == R_390_GOT16)
|
||||||
|
*(unsigned short *) loc += isym->gotent.offset;
|
||||||
|
else if (ELF_R_TYPE(rel->r_info) == R_390_GOT32)
|
||||||
|
*(unsigned int *) loc += isym->gotent.offset;
|
||||||
|
break;
|
||||||
|
|
||||||
|
# ifndef R_390_GOTOFF32
|
||||||
|
# define R_390_GOTOFF32 R_390_GOTOFF
|
||||||
|
# endif
|
||||||
|
case R_390_GOTOFF32:
|
||||||
|
assert(got != 0);
|
||||||
|
*loc += v - got;
|
||||||
|
break;
|
||||||
|
|
||||||
#elif defined(__sh__)
|
#elif defined(__sh__)
|
||||||
|
|
||||||
case R_SH_NONE:
|
case R_SH_NONE:
|
||||||
@ -1346,14 +1321,9 @@ arch_apply_relocation(struct obj_file *f,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
# endif /* __SH5__ */
|
# endif /* __SH5__ */
|
||||||
#endif /* __sh__ */
|
|
||||||
|
|
||||||
default:
|
#elif defined (__v850e__)
|
||||||
printf("Warning: unhandled reloc %d\n",(int)ELF_R_TYPE(rel->r_info));
|
|
||||||
ret = obj_reloc_unhandled;
|
|
||||||
break;
|
|
||||||
|
|
||||||
#if defined (__v850e__)
|
|
||||||
case R_V850_NONE:
|
case R_V850_NONE:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1369,50 +1339,83 @@ arch_apply_relocation(struct obj_file *f,
|
|||||||
|
|
||||||
case R_V850_22_PCREL:
|
case R_V850_22_PCREL:
|
||||||
goto bb_use_plt;
|
goto bb_use_plt;
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined (__cris__)
|
#elif defined(__x86_64__)
|
||||||
case R_CRIS_NONE:
|
#warning hi
|
||||||
|
case R_X86_64_NONE:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case R_CRIS_32:
|
case R_X86_64_64:
|
||||||
/* CRIS keeps the relocation value in the r_addend field and
|
*loc += v;
|
||||||
* should not use whats in *loc at all
|
break;
|
||||||
*/
|
|
||||||
|
case R_X86_64_32:
|
||||||
|
*(unsigned int *) loc += v;
|
||||||
|
if (v > 0xffffffff)
|
||||||
|
{
|
||||||
|
ret = obj_reloc_overflow; /* Kernel module compiled without -mcmodel=kernel. */
|
||||||
|
/* error("Possibly is module compiled without -mcmodel=kernel!"); */
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_32S:
|
||||||
|
*(signed int *) loc += v;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_16:
|
||||||
|
*(unsigned short *) loc += v;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_8:
|
||||||
|
*(unsigned char *) loc += v;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_PC32:
|
||||||
|
*(unsigned int *) loc += v - dot;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_PC16:
|
||||||
|
*(unsigned short *) loc += v - dot;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_PC8:
|
||||||
|
*(unsigned char *) loc += v - dot;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_GLOB_DAT:
|
||||||
|
case R_X86_64_JUMP_SLOT:
|
||||||
*loc = v;
|
*loc = v;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_RELATIVE:
|
||||||
|
*loc += f->baseaddr;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case R_X86_64_GOT32:
|
||||||
|
case R_X86_64_GOTPCREL:
|
||||||
|
goto bb_use_got;
|
||||||
|
# if 0
|
||||||
|
assert(isym != NULL);
|
||||||
|
if (!isym->gotent.reloc_done)
|
||||||
|
{
|
||||||
|
isym->gotent.reloc_done = 1;
|
||||||
|
*(Elf64_Addr *)(ifile->got->contents + isym->gotent.offset) = v;
|
||||||
|
}
|
||||||
|
/* XXX are these really correct? */
|
||||||
|
if (ELF64_R_TYPE(rel->r_info) == R_X86_64_GOTPCREL)
|
||||||
|
*(unsigned int *) loc += v + isym->gotent.offset;
|
||||||
|
else
|
||||||
|
*loc += isym->gotent.offset;
|
||||||
|
break;
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
#if defined(__H8300H__) || defined(__H8300S__)
|
|
||||||
case R_H8_DIR24R8:
|
|
||||||
loc = (ElfW(Addr) *)((ElfW(Addr))loc - 1);
|
|
||||||
*loc = (*loc & 0xff000000) | ((*loc & 0xffffff) + v);
|
|
||||||
break;
|
|
||||||
case R_H8_DIR24A8:
|
|
||||||
*loc += v;
|
|
||||||
break;
|
|
||||||
case R_H8_DIR32:
|
|
||||||
case R_H8_DIR32A16:
|
|
||||||
*loc += v;
|
|
||||||
break;
|
|
||||||
case R_H8_PCREL16:
|
|
||||||
v -= dot + 2;
|
|
||||||
if ((ElfW(Sword))v > 0x7fff ||
|
|
||||||
(ElfW(Sword))v < -(ElfW(Sword))0x8000)
|
|
||||||
ret = obj_reloc_overflow;
|
|
||||||
else
|
|
||||||
*(unsigned short *)loc = v;
|
|
||||||
break;
|
|
||||||
case R_H8_PCREL8:
|
|
||||||
v -= dot + 1;
|
|
||||||
if ((ElfW(Sword))v > 0x7f ||
|
|
||||||
(ElfW(Sword))v < -(ElfW(Sword))0x80)
|
|
||||||
ret = obj_reloc_overflow;
|
|
||||||
else
|
|
||||||
*(unsigned char *)loc = v;
|
|
||||||
break;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
default:
|
||||||
|
printf("Warning: unhandled reloc %d\n",(int)ELF_R_TYPE(rel->r_info));
|
||||||
|
ret = obj_reloc_unhandled;
|
||||||
|
break;
|
||||||
|
|
||||||
#if defined(CONFIG_USE_PLT_ENTRIES)
|
#if defined(CONFIG_USE_PLT_ENTRIES)
|
||||||
|
|
||||||
bb_use_plt:
|
bb_use_plt:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user