mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-31 03:58:17 +00:00 
			
		
		
		
	Refactor linker-generated array code so that symbols which were previously linker-generated are now compiler- generated. This causes relocation records of type R_ARM_ABS32 to become R_ARM_RELATIVE, which makes code which uses LGA able to run before relocation as well as after. Note: this affects more than ARM targets, as linker- lists span possibly all target architectures, notably PowerPC. Conflicts: arch/arm/cpu/arm926ejs/mxs/u-boot-spl.lds arch/arm/cpu/arm926ejs/spear/u-boot-spl.lds arch/arm/cpu/armv7/omap-common/u-boot-spl.lds board/ait/cam_enc_4xx/u-boot-spl.lds board/davinci/da8xxevm/u-boot-spl-da850evm.lds board/davinci/da8xxevm/u-boot-spl-hawk.lds board/vpac270/u-boot-spl.lds Signed-off-by: Albert ARIBAUD <albert.u.boot@aribaud.net>
		
			
				
	
	
		
			138 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2000
 | |
|  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
 | |
|  *
 | |
|  * See file CREDITS for list of people who contributed to this
 | |
|  * project.
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU General Public License as
 | |
|  * published by the Free Software Foundation; either version 2 of
 | |
|  * the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software
 | |
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 | |
|  * MA 02111-1307 USA
 | |
|  */
 | |
| 
 | |
| OUTPUT_ARCH(powerpc)
 | |
| /* Do we need any of these for elf?
 | |
|    __DYNAMIC = 0;    */
 | |
| SECTIONS
 | |
| {
 | |
|   /* Read-only sections, merged into text segment: */
 | |
|   . = + SIZEOF_HEADERS;
 | |
|   .interp : { *(.interp) }
 | |
|   .hash          : { *(.hash)		}
 | |
|   .dynsym        : { *(.dynsym)		}
 | |
|   .dynstr        : { *(.dynstr)		}
 | |
|   .rel.text      : { *(.rel.text)		}
 | |
|   .rela.text     : { *(.rela.text)	}
 | |
|   .rel.data      : { *(.rel.data)		}
 | |
|   .rela.data     : { *(.rela.data)	}
 | |
|   .rel.rodata    : { *(.rel.rodata)	}
 | |
|   .rela.rodata   : { *(.rela.rodata)	}
 | |
|   .rel.got       : { *(.rel.got)		}
 | |
|   .rela.got      : { *(.rela.got)		}
 | |
|   .rel.ctors     : { *(.rel.ctors)	}
 | |
|   .rela.ctors    : { *(.rela.ctors)	}
 | |
|   .rel.dtors     : { *(.rel.dtors)	}
 | |
|   .rela.dtors    : { *(.rela.dtors)	}
 | |
|   .rel.bss       : { *(.rel.bss)		}
 | |
|   .rela.bss      : { *(.rela.bss)		}
 | |
|   .rel.plt       : { *(.rel.plt)		}
 | |
|   .rela.plt      : { *(.rela.plt)		}
 | |
|   .init          : { *(.init)	}
 | |
|   .plt : { *(.plt) }
 | |
|   .text      :
 | |
|   {
 | |
|     /* WARNING - the following is hand-optimized to fit within	*/
 | |
|     /* the sector layout of our flash chips!	XXX FIXME XXX	*/
 | |
| 
 | |
|     mpc8xx/start.o	(.text)
 | |
|     common/dlmalloc.o	(.text)
 | |
|     lib/vsprintf.o	(.text)
 | |
|     lib/crc32.o		(.text)
 | |
|     arch/powerpc/lib/extable.o	(.text)
 | |
| 
 | |
|     common/env_embedded.o(.text)
 | |
| 
 | |
|     *(.text)
 | |
|     *(.got1)
 | |
|   }
 | |
|   _etext = .;
 | |
|   PROVIDE (etext = .);
 | |
|   .rodata    :
 | |
|   {
 | |
|     *(.rodata)
 | |
|     *(.rodata1)
 | |
|     *(.rodata.str1.4)
 | |
|     *(.eh_frame)
 | |
|   }
 | |
|   .fini      : { *(.fini)    } =0
 | |
|   .ctors     : { *(.ctors)   }
 | |
|   .dtors     : { *(.dtors)   }
 | |
| 
 | |
|   /* Read-write section, merged into data segment: */
 | |
|   . = (. + 0x0FFF) & 0xFFFFF000;
 | |
|   _erotext = .;
 | |
|   PROVIDE (erotext = .);
 | |
|   .reloc   :
 | |
|   {
 | |
|     *(.got)
 | |
|     _GOT2_TABLE_ = .;
 | |
|     *(.got2)
 | |
|     _FIXUP_TABLE_ = .;
 | |
|     *(.fixup)
 | |
|   }
 | |
|   __got2_entries = (_FIXUP_TABLE_ - _GOT2_TABLE_) >>2;
 | |
|   __fixup_entries = (. - _FIXUP_TABLE_)>>2;
 | |
| 
 | |
|   .data    :
 | |
|   {
 | |
|     *(.data)
 | |
|     *(.data1)
 | |
|     *(.sdata)
 | |
|     *(.sdata2)
 | |
|     *(.dynamic)
 | |
|     CONSTRUCTORS
 | |
|   }
 | |
|   _edata  =  .;
 | |
|   PROVIDE (edata = .);
 | |
| 
 | |
| 
 | |
|   . = ALIGN(4);
 | |
|   .u_boot_list : {
 | |
| 	KEEP(*(SORT(.u_boot_list*)));
 | |
|   }
 | |
| 
 | |
| 
 | |
|   __start___ex_table = .;
 | |
|   __ex_table : { *(__ex_table) }
 | |
|   __stop___ex_table = .;
 | |
| 
 | |
|   . = ALIGN(4096);
 | |
|   __init_begin = .;
 | |
|   .text.init : { *(.text.init) }
 | |
|   .data.init : { *(.data.init) }
 | |
|   . = ALIGN(4096);
 | |
|   __init_end = .;
 | |
| 
 | |
|   __bss_start = .;
 | |
|   .bss       :
 | |
|   {
 | |
|    *(.sbss) *(.scommon)
 | |
|    *(.dynbss)
 | |
|    *(.bss)
 | |
|    *(COMMON)
 | |
|   }
 | |
|   __bss_end__ = . ;
 | |
|   PROVIDE (end = .);
 | |
| }
 |