blob: 963d29f2dc839cb746dc60c39edb779854684e38 [file] [log] [blame]
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +02001/*
2 * January 2004 - Changed to support H4 device
3 * Copyright (c) 2004 Texas Instruments
4 *
5 * (C) Copyright 2002
Detlev Zundelf1b3f2b2009-05-13 10:54:10 +02006 * Gary Jennejohn, DENX Software Engineering, <garyj@denx.de>
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +02007 *
8 * See file CREDITS for list of people who contributed to this
9 * project.
10 *
11 * This program is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU General Public License as
13 * published by the Free Software Foundation; either version 2 of
14 * the License, or (at your option) any later version.
15 *
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with this program; if not, write to the Free Software
23 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
24 * MA 02111-1307 USA
25 */
26
27OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
28OUTPUT_ARCH(arm)
29ENTRY(_start)
30SECTIONS
31{
32 . = 0x00000000;
33
34 . = ALIGN(4);
35 .text :
36 {
Albert ARIBAUDc53687e2013-06-11 14:17:33 +020037 *(.__image_copy_start)
Guennadi Liakhovetski0c8382b2008-04-03 17:04:22 +020038 /* WARNING - the following is hand-optimized to fit within */
39 /* the sector layout of our flash chips! XXX FIXME XXX */
40
Benoît Thébaudeau3954db82013-04-11 09:36:03 +000041 arch/arm/cpu/arm1136/start.o (.text*)
42 board/freescale/mx31ads/libmx31ads.o (.text*)
43 arch/arm/lib/libarm.o (.text*)
44 net/libnet.o (.text*)
45 drivers/mtd/libmtd.o (.text*)
Guennadi Liakhovetski0c8382b2008-04-03 17:04:22 +020046
47 . = DEFINED(env_offset) ? env_offset : .;
Benoît Thébaudeau3954db82013-04-11 09:36:03 +000048 common/env_embedded.o(.text*)
Guennadi Liakhovetski0c8382b2008-04-03 17:04:22 +020049
Benoît Thébaudeau3954db82013-04-11 09:36:03 +000050 *(.text*)
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020051 }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020052 . = ALIGN(4);
Benoît Thébaudeau3954db82013-04-11 09:36:03 +000053 .rodata : { *(.rodata*) }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020054
55 . = ALIGN(4);
Fabio Estevam574cff72011-06-05 06:26:49 +000056 .data : {
Benoît Thébaudeau3954db82013-04-11 09:36:03 +000057 *(.data*)
Fabio Estevam574cff72011-06-05 06:26:49 +000058 }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020059
60 . = ALIGN(4);
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020061
62 . = ALIGN(4);
Marek Vasut607092a2012-10-12 10:27:03 +000063 .u_boot_list : {
Albert ARIBAUDc24895e2013-02-25 00:59:00 +000064 KEEP(*(SORT(.u_boot_list*)));
Marek Vasut607092a2012-10-12 10:27:03 +000065 }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020066
67 . = ALIGN(4);
Fabio Estevam574cff72011-06-05 06:26:49 +000068
Albert ARIBAUDc53687e2013-06-11 14:17:33 +020069 .image_copy_end :
70 {
71 *(.__image_copy_end)
72 }
Stefano Babicb913a3a2012-10-10 21:11:41 +000073
Albert ARIBAUDaf3ff162013-06-11 14:17:34 +020074 .rel_dyn_start :
75 {
76 *(.__rel_dyn_start)
77 }
78
Fabio Estevam574cff72011-06-05 06:26:49 +000079 .rel.dyn : {
Fabio Estevam574cff72011-06-05 06:26:49 +000080 *(.rel*)
Albert ARIBAUDaf3ff162013-06-11 14:17:34 +020081 }
82
83 .rel_dyn_end :
84 {
85 *(.__rel_dyn_end)
Fabio Estevam574cff72011-06-05 06:26:49 +000086 }
87
Fabio Estevam574cff72011-06-05 06:26:49 +000088 _end = .;
89
Albert ARIBAUDba5662d2013-04-11 05:43:21 +000090/*
91 * Compiler-generated __bss_start and __bss_end, see arch/arm/lib/bss.c
92 * __bss_base and __bss_limit are for linker only (overlay ordering)
93 */
94
Albert ARIBAUD436f6322013-02-25 00:58:59 +000095 .bss_start __rel_dyn_start (OVERLAY) : {
96 KEEP(*(.__bss_start));
Albert ARIBAUDba5662d2013-04-11 05:43:21 +000097 __bss_base = .;
Albert ARIBAUD436f6322013-02-25 00:58:59 +000098 }
99
Albert ARIBAUDba5662d2013-04-11 05:43:21 +0000100 .bss __bss_base (OVERLAY) : {
Albert ARIBAUD436f6322013-02-25 00:58:59 +0000101 *(.bss*)
Fabio Estevam574cff72011-06-05 06:26:49 +0000102 . = ALIGN(4);
Albert ARIBAUDba5662d2013-04-11 05:43:21 +0000103 __bss_limit = .;
Albert ARIBAUD436f6322013-02-25 00:58:59 +0000104 }
Albert ARIBAUDba5662d2013-04-11 05:43:21 +0000105 .bss_end __bss_limit (OVERLAY) : {
106 KEEP(*(.__bss_end));
Fabio Estevam574cff72011-06-05 06:26:49 +0000107 }
108
109 /DISCARD/ : { *(.bss*) }
Albert ARIBAUD16915932013-06-11 14:17:31 +0200110 /DISCARD/ : { *(.dynsym) }
Fabio Estevam574cff72011-06-05 06:26:49 +0000111 /DISCARD/ : { *(.dynstr*) }
112 /DISCARD/ : { *(.dynsym*) }
113 /DISCARD/ : { *(.dynamic*) }
114 /DISCARD/ : { *(.hash*) }
115 /DISCARD/ : { *(.plt*) }
116 /DISCARD/ : { *(.interp*) }
117 /DISCARD/ : { *(.gnu*) }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +0200118}