blob: 7768853c543bf095eaabcce79ebca5a013f5fbe5 [file] [log] [blame]
Travis Geiselbrecht1d0df692008-09-01 02:26:09 -07001OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
2OUTPUT_ARCH(arm)
3
4ENTRY(_start)
5SECTIONS
6{
7 . = %MEMBASE%;
8
Ajay Dudanic713ab82011-05-18 19:50:14 -07009 /* text/read-only data */
10 .text.boot : { *(.text.boot) }
11 .text : { *(.text .text.* .glue_7* .gnu.linkonce.t.*) } =0x9090
12
Travis Geiselbrecht1d0df692008-09-01 02:26:09 -070013 .interp : { *(.interp) }
14 .hash : { *(.hash) }
15 .dynsym : { *(.dynsym) }
16 .dynstr : { *(.dynstr) }
17 .rel.text : { *(.rel.text) *(.rel.gnu.linkonce.t*) }
18 .rela.text : { *(.rela.text) *(.rela.gnu.linkonce.t*) }
19 .rel.data : { *(.rel.data) *(.rel.gnu.linkonce.d*) }
20 .rela.data : { *(.rela.data) *(.rela.gnu.linkonce.d*) }
21 .rel.rodata : { *(.rel.rodata) *(.rel.gnu.linkonce.r*) }
22 .rela.rodata : { *(.rela.rodata) *(.rela.gnu.linkonce.r*) }
23 .rel.got : { *(.rel.got) }
24 .rela.got : { *(.rela.got) }
25 .rel.ctors : { *(.rel.ctors) }
26 .rela.ctors : { *(.rela.ctors) }
27 .rel.dtors : { *(.rel.dtors) }
28 .rela.dtors : { *(.rela.dtors) }
29 .rel.init : { *(.rel.init) }
30 .rela.init : { *(.rela.init) }
31 .rel.fini : { *(.rel.fini) }
32 .rela.fini : { *(.rela.fini) }
33 .rel.bss : { *(.rel.bss) }
34 .rela.bss : { *(.rela.bss) }
35 .rel.plt : { *(.rel.plt) }
36 .rela.plt : { *(.rela.plt) }
37 .init : { *(.init) } =0x9090
38 .plt : { *(.plt) }
39
Mayank Grover16087cb2018-04-17 15:14:12 +053040
41 /* Use read/write memory offset for everything except code section */
42 . = %MEMRWOFF% ;
Travis Geiselbrecht1d0df692008-09-01 02:26:09 -070043 .rodata : {
44 *(.rodata .rodata.* .gnu.linkonce.r.*)
45 . = ALIGN(4);
46 __commands_start = .;
47 KEEP (*(.commands))
48 __commands_end = .;
Travis Geiselbrecht68372232009-01-24 21:21:08 -080049 . = ALIGN(4);
50 __apps_start = .;
51 KEEP (*(.apps))
52 __apps_end = .;
Travis Geiselbrecht1d0df692008-09-01 02:26:09 -070053 . = ALIGN(4);
54 __rodata_end = . ;
55 }
56
57 /* writable data */
58 __data_start_rom = .; /* in one segment binaries, the rom data address is on top of the ram data address */
59 __data_start = .;
Brian Swetland52402912009-01-01 10:59:04 -080060 .data : SUBALIGN(4) { *(.data .data.* .gnu.linkonce.d.*) }
Travis Geiselbrecht1d0df692008-09-01 02:26:09 -070061
62 __ctor_list = .;
63 .ctors : { *(.ctors) }
64 __ctor_end = .;
65 __dtor_list = .;
66 .dtors : { *(.dtors) }
67 __dtor_end = .;
68 .got : { *(.got.plt) *(.got) }
69 .dynamic : { *(.dynamic) }
70
71 __data_end = .;
72
73 /* unintialized data (in same segment as writable data) */
74 . = ALIGN(4);
75 __bss_start = .;
76 .bss : { *(.bss .bss.*) }
77
78 . = ALIGN(4);
79 _end = .;
80
81 . = %MEMBASE% + %MEMSIZE%;
82 _end_of_ram = .;
83
84 /* Strip unnecessary stuff */
85 /DISCARD/ : { *(.comment .note .eh_frame) }
86}