 786d35d45c
			
		
	
	
	786d35d45c
	
	
	
		
			
			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>
		
	
			
		
			
				
	
	
		
			41 lines
		
	
	
	
		
			808 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
	
		
			808 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _ASM_M68K_MODULE_H
 | |
| #define _ASM_M68K_MODULE_H
 | |
| 
 | |
| #include <asm-generic/module.h>
 | |
| 
 | |
| enum m68k_fixup_type {
 | |
| 	m68k_fixup_memoffset,
 | |
| 	m68k_fixup_vnode_shift,
 | |
| };
 | |
| 
 | |
| struct m68k_fixup_info {
 | |
| 	enum m68k_fixup_type type;
 | |
| 	void *addr;
 | |
| };
 | |
| 
 | |
| struct mod_arch_specific {
 | |
| 	struct m68k_fixup_info *fixup_start, *fixup_end;
 | |
| };
 | |
| 
 | |
| #ifdef CONFIG_MMU
 | |
| 
 | |
| #define MODULE_ARCH_INIT {				\
 | |
| 	.fixup_start		= __start_fixup,	\
 | |
| 	.fixup_end		= __stop_fixup,		\
 | |
| }
 | |
| 
 | |
| 
 | |
| #define m68k_fixup(type, addr)			\
 | |
| 	"	.section \".m68k_fixup\",\"aw\"\n"	\
 | |
| 	"	.long " #type "," #addr "\n"	\
 | |
| 	"	.previous\n"
 | |
| 
 | |
| #endif /* CONFIG_MMU */
 | |
| 
 | |
| extern struct m68k_fixup_info __start_fixup[], __stop_fixup[];
 | |
| 
 | |
| struct module;
 | |
| extern void module_fixup(struct module *mod, struct m68k_fixup_info *start,
 | |
| 			 struct m68k_fixup_info *end);
 | |
| 
 | |
| #endif /* _ASM_M68K_MODULE_H */
 |