diff options
| author | David Howells <dhowells@redhat.com> | 2012-09-28 14:31:03 +0930 | 
|---|---|---|
| committer | Rusty Russell <rusty@rustcorp.com.au> | 2012-09-28 14:31:03 +0930 | 
| commit | 786d35d45cc40b2a51a18f73e14e135d47fdced7 (patch) | |
| tree | df18f4dc3f8a333267e74089760043769b3b6184 /arch/mips/include/asm/module.h | |
| parent | 6ede81239e31cfacbb1e2d260530cd80d13cf0db (diff) | |
Make most arch asm/module.h files use asm-generic/module.h
Use the mapping of Elf_[SPE]hdr, Elf_Addr, Elf_Sym, Elf_Dyn, Elf_Rel/Rela,
ELF_R_TYPE() and ELF_R_SYM() to either the 32-bit version or the 64-bit version
into asm-generic/module.h for all arches bar MIPS.
Also, use the generic definition mod_arch_specific where possible.
To this end, I've defined three new config bools:
 (*) HAVE_MOD_ARCH_SPECIFIC
     Arches define this if they don't want to use the empty generic
     mod_arch_specific struct.
 (*) MODULES_USE_ELF_RELA
     Arches define this if their modules can contain RELA records.  This causes
     the Elf_Rela mapping to be emitted and allows apply_relocate_add() to be
     defined by the arch rather than have the core emit an error message.
 (*) MODULES_USE_ELF_REL
     Arches define this if their modules can contain REL records.  This causes
     the Elf_Rel mapping to be emitted and allows apply_relocate() to be
     defined by the arch rather than have the core emit an error message.
Note that it is possible to allow both REL and RELA records: m68k and mips are
two arches that do this.
With this, some arch asm/module.h files can be deleted entirely and replaced
with a generic-y marker in the arch Kbuild file.
Additionally, I have removed the bits from m32r and score that handle the
unsupported type of relocation record as that's now handled centrally.
Signed-off-by: David Howells <dhowells@redhat.com>
Acked-by: Sam Ravnborg <sam@ravnborg.org>
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Diffstat (limited to 'arch/mips/include/asm/module.h')
| -rw-r--r-- | arch/mips/include/asm/module.h | 10 | 
1 files changed, 8 insertions, 2 deletions
diff --git a/arch/mips/include/asm/module.h b/arch/mips/include/asm/module.h index dca8bce8c7ab..26137da1c713 100644 --- a/arch/mips/include/asm/module.h +++ b/arch/mips/include/asm/module.h @@ -35,11 +35,14 @@ typedef struct {  } Elf64_Mips_Rela;  #ifdef CONFIG_32BIT -  #define Elf_Shdr	Elf32_Shdr  #define Elf_Sym		Elf32_Sym  #define Elf_Ehdr	Elf32_Ehdr  #define Elf_Addr	Elf32_Addr +#define Elf_Rel		Elf32_Rel +#define Elf_Rela	Elf32_Rela +#define ELF_R_TYPE(X)	ELF32_R_TYPE(X) +#define ELF_R_SYM(X)	ELF32_R_SYM(X)  #define Elf_Mips_Rel	Elf32_Rel  #define Elf_Mips_Rela	Elf32_Rela @@ -50,11 +53,14 @@ typedef struct {  #endif  #ifdef CONFIG_64BIT -  #define Elf_Shdr	Elf64_Shdr  #define Elf_Sym		Elf64_Sym  #define Elf_Ehdr	Elf64_Ehdr  #define Elf_Addr	Elf64_Addr +#define Elf_Rel		Elf64_Rel +#define Elf_Rela	Elf64_Rela +#define ELF_R_TYPE(X)	ELF64_R_TYPE(X) +#define ELF_R_SYM(X)	ELF64_R_SYM(X)  #define Elf_Mips_Rel	Elf64_Mips_Rel  #define Elf_Mips_Rela	Elf64_Mips_Rela  | 
