mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 18:18:19 +01:00 
			
		
		
		
	Commit 79fd7e649e287228a1445820a72f7dd33baedb96
    MIPS: always keep all sections in u-boot ELF binary.
    Always keep all sections in u-boot ELF binary. Move all unneeded
    sections after _end to avoid allocating space in the final binary.
    Also remove .deadcode section which is now obsolete.
removed section .deadcode because the original symptoms were not
visible anymore. Unfortuneatly the binutils bug still exists.
The size of .rel.dyn section is often bigger than needed for all
entries. But objcopy only allocates space as much as required for all
reloc entries. Thus there is a gap between the last entry and
__rel_dyn_end in u-boot.bin. If u-boot is booted from RAM (e.g. in
SPL scenarios) that area could contain garbage data which could lead
to CPU exceptions during relocation.
Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
Signed-off-by: Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
		
	
			
		
			
				
	
	
		
			129 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2003
 | |
|  * Wolfgang Denk Engineering, <wd@denx.de>
 | |
|  *
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #if defined(CONFIG_64BIT)
 | |
| #define PTR_COUNT_SHIFT	3
 | |
| #else
 | |
| #define PTR_COUNT_SHIFT	2
 | |
| #endif
 | |
| 
 | |
| OUTPUT_ARCH(mips)
 | |
| ENTRY(_start)
 | |
| SECTIONS
 | |
| {
 | |
| 	. = 0x00000000;
 | |
| 
 | |
| 	. = ALIGN(4);
 | |
| 	.text : {
 | |
| 		*(.text*)
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(4);
 | |
| 	.rodata : {
 | |
| 		*(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*)))
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(4);
 | |
| 	.data : {
 | |
| 		*(.data*)
 | |
| 	}
 | |
| 
 | |
| 	. = .;
 | |
| 	_gp = ALIGN(16) + 0x7ff0;
 | |
| 
 | |
| 	.got : {
 | |
| 		*(.got)
 | |
| 	}
 | |
| 
 | |
| 	num_got_entries = SIZEOF(.got) >> PTR_COUNT_SHIFT;
 | |
| 
 | |
| 	. = ALIGN(4);
 | |
| 	.sdata : {
 | |
| 		*(.sdata*)
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(4);
 | |
| 	.u_boot_list : {
 | |
| 		KEEP(*(SORT(.u_boot_list*)));
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(4);
 | |
| 	__image_copy_end = .;
 | |
| 	__init_end = .;
 | |
| 
 | |
| 	.rel.dyn : {
 | |
| 		__rel_dyn_start = .;
 | |
| 		*(.rel.dyn)
 | |
| 		__rel_dyn_end = .;
 | |
| 	}
 | |
| 
 | |
| 	.padding : {
 | |
| 		/*
 | |
| 		 * Workaround for a binutils feature (or bug?).
 | |
| 		 *
 | |
| 		 * The GNU ld from binutils puts the dynamic relocation
 | |
| 		 * entries into the .rel.dyn section. Sometimes it
 | |
| 		 * allocates more dynamic relocation entries than it needs
 | |
| 		 * and the unused slots are set to R_MIPS_NONE entries.
 | |
| 		 *
 | |
| 		 * However the size of the .rel.dyn section in the ELF
 | |
| 		 * section header does not cover the unused entries, so
 | |
| 		 * objcopy removes those during stripping.
 | |
| 		 *
 | |
| 		 * Create a small section here to avoid that.
 | |
| 		 */
 | |
| 		LONG(0xFFFFFFFF)
 | |
| 	}
 | |
| 
 | |
| 	_end = .;
 | |
| 
 | |
| 	.bss __rel_dyn_start (OVERLAY) : {
 | |
| 		__bss_start = .;
 | |
| 		*(.sbss.*)
 | |
| 		*(.bss.*)
 | |
| 		*(COMMON)
 | |
| 		. = ALIGN(4);
 | |
| 		__bss_end = .;
 | |
| 	}
 | |
| 
 | |
| 	.dynsym _end : {
 | |
| 		*(.dynsym)
 | |
| 	}
 | |
| 
 | |
| 	.dynbss : {
 | |
| 		*(.dynbss)
 | |
| 	}
 | |
| 
 | |
| 	.dynstr : {
 | |
| 		*(.dynstr)
 | |
| 	}
 | |
| 
 | |
| 	.dynamic : {
 | |
| 		*(.dynamic)
 | |
| 	}
 | |
| 
 | |
| 	.plt : {
 | |
| 		*(.plt)
 | |
| 	}
 | |
| 
 | |
| 	.interp : {
 | |
| 		*(.interp)
 | |
| 	}
 | |
| 
 | |
| 	.gnu : {
 | |
| 		*(.gnu*)
 | |
| 	}
 | |
| 
 | |
| 	.MIPS.stubs : {
 | |
| 		*(.MIPS.stubs)
 | |
| 	}
 | |
| 
 | |
| 	.hash : {
 | |
| 		*(.hash)
 | |
| 	}
 | |
| }
 |