1 #include <asm-generic/vmlinux.lds.h>
3 OUTPUT_FORMAT(ELF_FORMAT)
10 PROVIDE (__executable_start = START);
11 . = START + SIZEOF_HEADERS;
12 .interp : { *(.interp) }
13 /* Used in arch/um/kernel/mem.c. Any memory between START and __binary_start
16 . = ALIGN(4096); /* Init code and data */
27 /* Read-only sections, merged into text segment: */
29 .gnu.hash : { *(.gnu.hash) }
30 .dynsym : { *(.dynsym) }
31 .dynstr : { *(.dynstr) }
32 .gnu.version : { *(.gnu.version) }
33 .gnu.version_d : { *(.gnu.version_d) }
34 .gnu.version_r : { *(.gnu.version_r) }
35 .rel.init : { *(.rel.init) }
36 .rela.init : { *(.rela.init) }
37 .rel.text : { *(.rel.text .rel.text.* .rel.gnu.linkonce.t.*) }
38 .rela.text : { *(.rela.text .rela.text.* .rela.gnu.linkonce.t.*) }
39 .rel.fini : { *(.rel.fini) }
40 .rela.fini : { *(.rela.fini) }
41 .rel.rodata : { *(.rel.rodata .rel.rodata.* .rel.gnu.linkonce.r.*) }
42 .rela.rodata : { *(.rela.rodata .rela.rodata.* .rela.gnu.linkonce.r.*) }
43 .rel.data : { *(.rel.data .rel.data.* .rel.gnu.linkonce.d.*) }
44 .rela.data : { *(.rela.data .rela.data.* .rela.gnu.linkonce.d.*) }
45 .rel.tdata : { *(.rel.tdata .rel.tdata.* .rel.gnu.linkonce.td.*) }
46 .rela.tdata : { *(.rela.tdata .rela.tdata.* .rela.gnu.linkonce.td.*) }
47 .rel.tbss : { *(.rel.tbss .rel.tbss.* .rel.gnu.linkonce.tb.*) }
48 .rela.tbss : { *(.rela.tbss .rela.tbss.* .rela.gnu.linkonce.tb.*) }
49 .rel.ctors : { *(.rel.ctors) }
50 .rela.ctors : { *(.rela.ctors) }
51 .rel.dtors : { *(.rel.dtors) }
52 .rela.dtors : { *(.rela.dtors) }
53 .rel.got : { *(.rel.got) }
54 .rela.got : { *(.rela.got) }
55 .rel.bss : { *(.rel.bss .rel.bss.* .rel.gnu.linkonce.b.*) }
56 .rela.bss : { *(.rela.bss .rela.bss.* .rela.gnu.linkonce.b.*) }
57 .rel.plt : { *(.rel.plt) }
58 .rela.plt : { *(.rela.plt) }
68 *(.stub .text.* .gnu.linkonce.t.*)
69 /* .gnu.warning sections are handled specially by elf32.em. */
73 __syscall_stub_start = .;
75 __syscall_stub_end = .;
82 .kstrtab : { *(.kstrtab) }
84 #include "asm/common.lds.S"
86 init.data : { *(.init.data) }
88 /* Ensure the __preinit_array_start label is properly aligned. We
89 could instead move the label definition inside the section, but
90 the linker would then create the section even if it turns out to
91 be empty, which isn't pretty. */
93 .preinit_array : { *(.preinit_array) }
94 .init_array : { *(.init_array) }
95 .fini_array : { *(.fini_array) }
97 . = ALIGN(KERNEL_STACK_SIZE); /* init_task */
99 *(.data .data.* .gnu.linkonce.d.*)
102 .data1 : { *(.data1) }
103 .tdata : { *(.tdata .tdata.* .gnu.linkonce.td.*) }
104 .tbss : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) }
105 .eh_frame : { KEEP (*(.eh_frame)) }
106 .gcc_except_table : { *(.gcc_except_table) }
107 .dynamic : { *(.dynamic) }
109 /* gcc uses crtbegin.o to find the start of
110 the constructors, so we make sure it is
111 first. Because this is a wildcard, it
112 doesn't matter if the user does not
113 actually link against crtbegin.o; the
114 linker won't look for a file to match a
115 wildcard. The wildcard also means that it
116 doesn't matter which directory crtbegin.o
118 KEEP (*crtbegin.o(.ctors))
119 /* We don't want to include the .ctor section from
120 from the crtend.o file until after the sorted ctors.
121 The .ctor section from the crtend file contains the
122 end of ctors marker and it must be last */
123 KEEP (*(EXCLUDE_FILE (*crtend.o ) .ctors))
124 KEEP (*(SORT(.ctors.*)))
128 KEEP (*crtbegin.o(.dtors))
129 KEEP (*(EXCLUDE_FILE (*crtend.o ) .dtors))
130 KEEP (*(SORT(.dtors.*)))
133 .jcr : { KEEP (*(.jcr)) }
134 .got : { *(.got.plt) *(.got) }
140 *(.bss .bss.* .gnu.linkonce.b.*)
142 /* Align here to ensure that the .bss section occupies space up to
143 _end. Align after .bss to ensure correct alignment even if the
144 .bss section disappears because there are no input sections. */