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 */
28 /* Read-only sections, merged into text segment: */
30 .gnu.hash : { *(.gnu.hash) }
31 .dynsym : { *(.dynsym) }
32 .dynstr : { *(.dynstr) }
33 .gnu.version : { *(.gnu.version) }
34 .gnu.version_d : { *(.gnu.version_d) }
35 .gnu.version_r : { *(.gnu.version_r) }
36 .rel.init : { *(.rel.init) }
37 .rela.init : { *(.rela.init) }
38 .rel.text : { *(.rel.text .rel.text.* .rel.gnu.linkonce.t.*) }
39 .rela.text : { *(.rela.text .rela.text.* .rela.gnu.linkonce.t.*) }
40 .rel.fini : { *(.rel.fini) }
41 .rela.fini : { *(.rela.fini) }
42 .rel.rodata : { *(.rel.rodata .rel.rodata.* .rel.gnu.linkonce.r.*) }
43 .rela.rodata : { *(.rela.rodata .rela.rodata.* .rela.gnu.linkonce.r.*) }
44 .rel.data : { *(.rel.data .rel.data.* .rel.gnu.linkonce.d.*) }
45 .rela.data : { *(.rela.data .rela.data.* .rela.gnu.linkonce.d.*) }
46 .rel.tdata : { *(.rel.tdata .rel.tdata.* .rel.gnu.linkonce.td.*) }
47 .rela.tdata : { *(.rela.tdata .rela.tdata.* .rela.gnu.linkonce.td.*) }
48 .rel.tbss : { *(.rel.tbss .rel.tbss.* .rel.gnu.linkonce.tb.*) }
49 .rela.tbss : { *(.rela.tbss .rela.tbss.* .rela.gnu.linkonce.tb.*) }
50 .rel.ctors : { *(.rel.ctors) }
51 .rela.ctors : { *(.rela.ctors) }
52 .rel.dtors : { *(.rel.dtors) }
53 .rela.dtors : { *(.rela.dtors) }
54 .rel.got : { *(.rel.got) }
55 .rela.got : { *(.rela.got) }
56 .rel.bss : { *(.rel.bss .rel.bss.* .rel.gnu.linkonce.b.*) }
57 .rela.bss : { *(.rela.bss .rela.bss.* .rela.gnu.linkonce.b.*) }
58 .rel.plt : { *(.rel.plt) }
59 .rela.plt : { *(.rela.plt) }
69 *(.stub .text.* .gnu.linkonce.t.*)
70 /* .gnu.warning sections are handled specially by elf32.em. */
77 __syscall_stub_start = .;
79 __syscall_stub_end = .;
85 .kstrtab : { *(.kstrtab) }
87 #include "asm/common.lds.S"
89 init.data : { *(.init.data) }
91 /* Ensure the __preinit_array_start label is properly aligned. We
92 could instead move the label definition inside the section, but
93 the linker would then create the section even if it turns out to
94 be empty, which isn't pretty. */
96 .preinit_array : { *(.preinit_array) }
97 .init_array : { *(.init_array) }
98 .fini_array : { *(.fini_array) }
100 . = ALIGN(KERNEL_STACK_SIZE); /* init_task */
102 . = ALIGN(KERNEL_STACK_SIZE);
103 *(.data.init_irqstack)
105 *(.data.* .gnu.linkonce.d.*)
108 .data1 : { *(.data1) }
109 .tdata : { *(.tdata .tdata.* .gnu.linkonce.td.*) }
110 .tbss : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) }
111 .eh_frame : { KEEP (*(.eh_frame)) }
112 .gcc_except_table : { *(.gcc_except_table) }
113 .dynamic : { *(.dynamic) }
115 /* gcc uses crtbegin.o to find the start of
116 the constructors, so we make sure it is
117 first. Because this is a wildcard, it
118 doesn't matter if the user does not
119 actually link against crtbegin.o; the
120 linker won't look for a file to match a
121 wildcard. The wildcard also means that it
122 doesn't matter which directory crtbegin.o
124 KEEP (*crtbegin.o(.ctors))
125 /* We don't want to include the .ctor section from
126 from the crtend.o file until after the sorted ctors.
127 The .ctor section from the crtend file contains the
128 end of ctors marker and it must be last */
129 KEEP (*(EXCLUDE_FILE (*crtend.o ) .ctors))
130 KEEP (*(SORT(.ctors.*)))
134 KEEP (*crtbegin.o(.dtors))
135 KEEP (*(EXCLUDE_FILE (*crtend.o ) .dtors))
136 KEEP (*(SORT(.dtors.*)))
139 .jcr : { KEEP (*(.jcr)) }
140 .got : { *(.got.plt) *(.got) }
146 *(.bss .bss.* .gnu.linkonce.b.*)
148 /* Align here to ensure that the .bss section occupies space up to
149 _end. Align after .bss to ensure correct alignment even if the
150 .bss section disappears because there are no input sections. */