blob: 91ffdbefd1310729cae71094b1c12b875fc1389e [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 {
Guennadi Liakhovetski0c8382b2008-04-03 17:04:22 +020037 /* WARNING - the following is hand-optimized to fit within */
38 /* the sector layout of our flash chips! XXX FIXME XXX */
39
Peter Tyserf7c67372010-04-12 22:28:11 -050040 arch/arm/cpu/arm1136/start.o (.text)
Sebastien Carliera8d426f2010-11-05 15:48:07 +010041 board/freescale/mx31ads/libmx31ads.o (.text)
42 arch/arm/lib/libarm.o (.text)
43 net/libnet.o (.text)
44 drivers/mtd/libmtd.o (.text)
Guennadi Liakhovetski0c8382b2008-04-03 17:04:22 +020045
46 . = DEFINED(env_offset) ? env_offset : .;
Jean-Christophe PLAGNIOL-VILLARD4436c1e2008-09-10 22:48:01 +020047 common/env_embedded.o(.text)
Guennadi Liakhovetski0c8382b2008-04-03 17:04:22 +020048
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020049 *(.text)
50 }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020051 . = ALIGN(4);
Fabio Estevam574cff72011-06-05 06:26:49 +000052 .rodata : { *(.rodata) }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020053
54 . = ALIGN(4);
Fabio Estevam574cff72011-06-05 06:26:49 +000055 .data : {
56 *(.data)
57 }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020058
59 . = ALIGN(4);
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020060 __u_boot_cmd_start = .;
61 .u_boot_cmd : { *(.u_boot_cmd) }
62 __u_boot_cmd_end = .;
63
64 . = ALIGN(4);
Fabio Estevam574cff72011-06-05 06:26:49 +000065
Stefano Babicb913a3a2012-10-10 21:11:41 +000066 __image_copy_end = .;
67
Fabio Estevam574cff72011-06-05 06:26:49 +000068 .rel.dyn : {
69 __rel_dyn_start = .;
70 *(.rel*)
71 __rel_dyn_end = .;
72 }
73
74 .dynsym : {
75 __dynsym_start = .;
76 *(.dynsym)
77 }
78
79 _end = .;
80
81 .bss __rel_dyn_start (OVERLAY) : {
82 __bss_start = .;
83 *(.bss)
84 . = ALIGN(4);
85 __bss_end__ = .;
86 }
87
88 /DISCARD/ : { *(.bss*) }
89 /DISCARD/ : { *(.dynstr*) }
90 /DISCARD/ : { *(.dynsym*) }
91 /DISCARD/ : { *(.dynamic*) }
92 /DISCARD/ : { *(.hash*) }
93 /DISCARD/ : { *(.plt*) }
94 /DISCARD/ : { *(.interp*) }
95 /DISCARD/ : { *(.gnu*) }
Guennadi Liakhovetski3b26c6b2008-04-14 10:53:12 +020096}