blob: 3ff38713f01f6fb2ed8ad062965bf65d7087a3a5 [file] [log] [blame]
wdenk3bac3512003-03-12 10:41:04 +00001/*
2**=====================================================================
3**
4** Copyright (C) 2000, 2001, 2002, 2003
5** The LEOX team <team@leox.org>, http://www.leox.org
6**
7** LEOX.org is about the development of free hardware and software resources
8** for system on chip.
9**
10** Description: U-Boot port on the LEOX's ELPT860 CPU board
11** ~~~~~~~~~~~
12**
13**=====================================================================
14**
15** This program is free software; you can redistribute it and/or
16** modify it under the terms of the GNU General Public License as
17** published by the Free Software Foundation; either version 2 of
18** the License, or (at your option) any later version.
19**
20** This program is distributed in the hope that it will be useful,
21** but WITHOUT ANY WARRANTY; without even the implied warranty of
22** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23** GNU General Public License for more details.
24**
25** You should have received a copy of the GNU General Public License
26** along with this program; if not, write to the Free Software
27** Foundation, Inc., 59 Temple Place, Suite 330, Boston,
28** MA 02111-1307 USA
29**
30**=====================================================================
31*/
32
33OUTPUT_ARCH(powerpc)
Wolfgang Denkcd0402a2010-11-20 15:07:45 +010034
wdenk3bac3512003-03-12 10:41:04 +000035SECTIONS
36{
37 /* Read-only sections, merged into text segment: */
38 . = + SIZEOF_HEADERS;
wdenk3bac3512003-03-12 10:41:04 +000039 .text :
40 {
41 /* WARNING - the following is hand-optimized to fit within */
42 /* the sector layout of our flash chips! XXX FIXME XXX */
43
Wolfgang Denkcd0402a2010-11-20 15:07:45 +010044 arch/powerpc/cpu/mpc8xx/start.o (.text*)
45 arch/powerpc/cpu/mpc8xx/traps.o (.text*)
46 common/libcommon.o (.text*)
47 arch/powerpc/cpu/mpc8xx/libmpc8xx.o (.text*)
48 board/LEOX/elpt860/libelpt860.o (.text*)
49 arch/powerpc/lib/libpowerpc.o (.text*)
50/* drivers/rtc/librtc.o (.text*) */
wdenk3bac3512003-03-12 10:41:04 +000051
52 . = env_offset;
Wolfgang Denkcd0402a2010-11-20 15:07:45 +010053 common/env_embedded.o (.text*)
wdenk3bac3512003-03-12 10:41:04 +000054
Wolfgang Denkcd0402a2010-11-20 15:07:45 +010055 *(.text*)
wdenk3bac3512003-03-12 10:41:04 +000056 }
57 _etext = .;
58 PROVIDE (etext = .);
59 .rodata :
60 {
Trent Piephof62fb992009-02-18 15:22:05 -080061 *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*)))
wdenk3bac3512003-03-12 10:41:04 +000062 }
wdenk3bac3512003-03-12 10:41:04 +000063
64 /* Read-write section, merged into data segment: */
65 . = (. + 0x00FF) & 0xFFFFFF00;
66 _erotext = .;
67 PROVIDE (erotext = .);
68 .reloc :
69 {
wdenk3bac3512003-03-12 10:41:04 +000070 _GOT2_TABLE_ = .;
Wolfgang Denkcd0402a2010-11-20 15:07:45 +010071 KEEP(*(.got2))
Joakim Tjernlund9d8fbd12011-04-20 14:22:59 +020072 KEEP(*(.got))
73 PROVIDE(_GLOBAL_OFFSET_TABLE_ = . + 4);
wdenk3bac3512003-03-12 10:41:04 +000074 _FIXUP_TABLE_ = .;
Wolfgang Denkcd0402a2010-11-20 15:07:45 +010075 KEEP(*(.fixup))
wdenk3bac3512003-03-12 10:41:04 +000076 }
Joakim Tjernlund9d8fbd12011-04-20 14:22:59 +020077 __got2_entries = ((_GLOBAL_OFFSET_TABLE_ - _GOT2_TABLE_) >> 2) - 1;
wdenk3bac3512003-03-12 10:41:04 +000078 __fixup_entries = (. - _FIXUP_TABLE_)>>2;
79
80 .data :
81 {
Wolfgang Denkcd0402a2010-11-20 15:07:45 +010082 *(.data*)
83 *(.sdata*)
wdenk3bac3512003-03-12 10:41:04 +000084 }
85 _edata = .;
86 PROVIDE (edata = .);
87
Wolfgang Denk807d5d72005-08-31 12:28:00 +020088 . = .;
wdenk8bde7f72003-06-27 21:31:46 +000089
Marek Vasut55675142012-10-12 10:27:03 +000090 . = ALIGN(4);
91 .u_boot_list : {
Albert ARIBAUDef123c52013-02-25 00:59:00 +000092 KEEP(*(SORT(.u_boot_list*)));
Marek Vasut55675142012-10-12 10:27:03 +000093 }
94
Wolfgang Denk807d5d72005-08-31 12:28:00 +020095 . = .;
wdenk3bac3512003-03-12 10:41:04 +000096 __start___ex_table = .;
97 __ex_table : { *(__ex_table) }
98 __stop___ex_table = .;
99
100 . = ALIGN(256);
101 __init_begin = .;
102 .text.init : { *(.text.init) }
103 .data.init : { *(.data.init) }
104 . = ALIGN(256);
105 __init_end = .;
106
107 __bss_start = .;
Wolfgang Denk64134f02008-01-12 20:31:39 +0100108 .bss (NOLOAD) :
wdenk3bac3512003-03-12 10:41:04 +0000109 {
Wolfgang Denkcd0402a2010-11-20 15:07:45 +0100110 *(.bss*)
111 *(.sbss*)
wdenk3bac3512003-03-12 10:41:04 +0000112 *(COMMON)
Selvamuthukumar9b827cf2008-10-16 22:54:03 +0530113 . = ALIGN(4);
wdenk3bac3512003-03-12 10:41:04 +0000114 }
Po-Yu Chuang44c6e652011-03-01 22:59:59 +0000115 __bss_end__ = . ;
wdenk3bac3512003-03-12 10:41:04 +0000116 PROVIDE (end = .);
117}