blob: 44b990ee7ff5cb548aba07923e08e1a3ef6e77b4 [file] [log] [blame]
Michael Schwingen6c3297e2008-01-16 19:51:55 +01001/*
2 * (C) Copyright 2000
3 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4 *
5 * See file CREDITS for list of people who contributed to this
6 * project.
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of
11 * the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21 * MA 02111-1307 USA
22 */
23
24OUTPUT_FORMAT ("elf32-bigarm", "elf32-bigarm", "elf32-bigarm")
25OUTPUT_ARCH (arm)
26ENTRY (_start)
27SECTIONS
28{
29 . = 0x00000000;
30
31 . = ALIGN (4);
32 .text : {
Michael Schwingenb2a70b52011-05-23 00:00:06 +020033 arch/arm/cpu/ixp/start.o(.text*)
34 net/libnet.o(.text*)
35 board/actux3/libactux3.o(.text*)
36 arch/arm/cpu/ixp/libixp.o(.text*)
Tom Rinia8381c92012-10-17 10:18:29 +000037 drivers/input/libinput.o(.text*)
Michael Schwingen6c3297e2008-01-16 19:51:55 +010038
39 . = env_offset;
Michael Schwingenb2a70b52011-05-23 00:00:06 +020040 common/env_embedded.o(.ppcenv)
41 *(.text*)
Michael Schwingen6c3297e2008-01-16 19:51:55 +010042 }
43
Michael Schwingenb2a70b52011-05-23 00:00:06 +020044 . = ALIGN(4);
Michael Schwingen6c3297e2008-01-16 19:51:55 +010045 .rodata : {
Trent Piepho4438e5e2009-02-18 15:22:05 -080046 *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*)))
Michael Schwingen6c3297e2008-01-16 19:51:55 +010047 }
Michael Schwingenb2a70b52011-05-23 00:00:06 +020048 . = ALIGN(4);
Michael Schwingen6c3297e2008-01-16 19:51:55 +010049 .data : {
Michael Schwingenb2a70b52011-05-23 00:00:06 +020050 *(.data*)
Michael Schwingen6c3297e2008-01-16 19:51:55 +010051 }
Michael Schwingenb2a70b52011-05-23 00:00:06 +020052 . = ALIGN(4);
Michael Schwingen6c3297e2008-01-16 19:51:55 +010053 .got : {
54 *(.got)
55 }
Michael Schwingen6c3297e2008-01-16 19:51:55 +010056 . =.;
Michael Schwingen6c3297e2008-01-16 19:51:55 +010057
Marek Vasut607092a2012-10-12 10:27:03 +000058 . = ALIGN(4);
59 .u_boot_list : {
Albert ARIBAUDc24895e2013-02-25 00:59:00 +000060 KEEP(*(SORT(.u_boot_list*)));
Marek Vasut607092a2012-10-12 10:27:03 +000061 }
62
Michael Schwingen6c3297e2008-01-16 19:51:55 +010063 . = ALIGN (4);
Benoît Thébaudeau03bae032013-04-11 09:35:46 +000064
65 __image_copy_end = .;
66
Michael Schwingenb2a70b52011-05-23 00:00:06 +020067 .rel.dyn : {
68 __rel_dyn_start = .;
69 *(.rel*)
70 __rel_dyn_end = .;
71 }
72
73 .dynsym : {
74 __dynsym_start = .;
75 *(.dynsym)
76 }
77
Albert ARIBAUD436f6322013-02-25 00:58:59 +000078 _end = .;
79
Albert ARIBAUDba5662d2013-04-11 05:43:21 +000080/*
81 * Compiler-generated __bss_start and __bss_end, see arch/arm/lib/bss.c
82 * __bss_base and __bss_limit are for linker only (overlay ordering)
83 */
84
Albert ARIBAUD436f6322013-02-25 00:58:59 +000085 .bss_start __rel_dyn_start (OVERLAY) : {
86 KEEP(*(.__bss_start));
Albert ARIBAUDba5662d2013-04-11 05:43:21 +000087 __bss_base = .;
Albert ARIBAUD436f6322013-02-25 00:58:59 +000088 }
89
Albert ARIBAUDba5662d2013-04-11 05:43:21 +000090 .bss __bss_base (OVERLAY) : {
Michael Schwingenb2a70b52011-05-23 00:00:06 +020091 *(.bss*)
92 . = ALIGN(4);
Albert ARIBAUDba5662d2013-04-11 05:43:21 +000093 __bss_limit = .;
Michael Schwingen6c3297e2008-01-16 19:51:55 +010094 }
Albert ARIBAUDba5662d2013-04-11 05:43:21 +000095 .bss_end __bss_limit (OVERLAY) : {
96 KEEP(*(.__bss_end));
Michael Schwingen6c3297e2008-01-16 19:51:55 +010097 }
Albert ARIBAUD436f6322013-02-25 00:58:59 +000098
Michael Schwingenb2a70b52011-05-23 00:00:06 +020099 /DISCARD/ : { *(.dynstr*) }
100 /DISCARD/ : { *(.dynamic*) }
101 /DISCARD/ : { *(.plt*) }
102 /DISCARD/ : { *(.interp*) }
103 /DISCARD/ : { *(.gnu*) }
Michael Schwingen6c3297e2008-01-16 19:51:55 +0100104}