blob: 9edb662b094a7742a285d180b6e95a9478efac8a [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Scott Woodb2d5ac52015-03-24 13:25:02 -07002/*
3 * (C) Copyright 2013
4 * David Feng <fenghua@phytium.com.cn>
5 *
6 * (C) Copyright 2002
7 * Gary Jennejohn, DENX Software Engineering, <garyj@denx.de>
8 *
9 * (C) Copyright 2010
10 * Texas Instruments, <www.ti.com>
11 * Aneesh V <aneesh@ti.com>
Scott Woodb2d5ac52015-03-24 13:25:02 -070012 */
13
Tom Rini2f41ade2019-01-22 17:09:26 -050014MEMORY { .sram : ORIGIN = IMAGE_TEXT_BASE,
15 LENGTH = IMAGE_MAX_SIZE }
Scott Woodb2d5ac52015-03-24 13:25:02 -070016MEMORY { .sdram : ORIGIN = CONFIG_SPL_BSS_START_ADDR,
17 LENGTH = CONFIG_SPL_BSS_MAX_SIZE }
18
19OUTPUT_FORMAT("elf64-littleaarch64", "elf64-littleaarch64", "elf64-littleaarch64")
20OUTPUT_ARCH(aarch64)
21ENTRY(_start)
22SECTIONS
23{
24 .text : {
25 . = ALIGN(8);
26 *(.__image_copy_start)
27 CPUDIR/start.o (.text*)
28 *(.text*)
29 } >.sram
30
31 .rodata : {
32 . = ALIGN(8);
33 *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*)))
34 } >.sram
35
36 .data : {
37 . = ALIGN(8);
38 *(.data*)
39 } >.sram
40
Peng Fan6aead232020-05-05 20:28:41 +080041#ifdef CONFIG_SPL_RECOVER_DATA_SECTION
42 .data_save : {
43 *(.__data_save_start)
44 . = SIZEOF(.data);
45 *(.__data_save_end)
46 } >.sram
47#endif
48
Scott Woodb2d5ac52015-03-24 13:25:02 -070049 .u_boot_list : {
50 . = ALIGN(8);
51 KEEP(*(SORT(.u_boot_list*)));
52 } >.sram
53
54 .image_copy_end : {
55 . = ALIGN(8);
56 *(.__image_copy_end)
57 } >.sram
58
59 .end : {
60 . = ALIGN(8);
61 *(.__end)
62 } >.sram
63
Masahiro Yamada0ea6cc12016-03-08 20:34:44 +090064 _image_binary_end = .;
65
Michal Simek439edf62017-05-29 10:26:53 +020066 .bss_start (NOLOAD) : {
Scott Woodb2d5ac52015-03-24 13:25:02 -070067 . = ALIGN(8);
68 KEEP(*(.__bss_start));
69 } >.sdram
70
Michal Simek439edf62017-05-29 10:26:53 +020071 .bss (NOLOAD) : {
Scott Woodb2d5ac52015-03-24 13:25:02 -070072 *(.bss*)
73 . = ALIGN(8);
74 } >.sdram
75
Michal Simek439edf62017-05-29 10:26:53 +020076 .bss_end (NOLOAD) : {
Scott Woodb2d5ac52015-03-24 13:25:02 -070077 KEEP(*(.__bss_end));
78 } >.sdram
79
Marek BehĂșn37de1982021-05-20 13:24:20 +020080 /DISCARD/ : { *(.rela*) }
Scott Woodb2d5ac52015-03-24 13:25:02 -070081 /DISCARD/ : { *(.dynsym) }
82 /DISCARD/ : { *(.dynstr*) }
83 /DISCARD/ : { *(.dynamic*) }
84 /DISCARD/ : { *(.plt*) }
85 /DISCARD/ : { *(.interp*) }
86 /DISCARD/ : { *(.gnu*) }
87}