blob: a4890739252230df4ebb28cc70a0e79915aa7bd0 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/* ld script to make s390 Linux kernel
2 * Written by Martin Schwidefsky (schwidefsky@de.ibm.com)
3 */
4
5#include <asm-generic/vmlinux.lds.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07006
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -08007#ifndef CONFIG_64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -07008OUTPUT_FORMAT("elf32-s390", "elf32-s390", "elf32-s390")
9OUTPUT_ARCH(s390)
10ENTRY(_start)
11jiffies = jiffies_64 + 4;
12#else
13OUTPUT_FORMAT("elf64-s390", "elf64-s390", "elf64-s390")
14OUTPUT_ARCH(s390:64-bit)
15ENTRY(_start)
16jiffies = jiffies_64;
17#endif
18
19SECTIONS
20{
21 . = 0x00000000;
22 _text = .; /* Text and read-only data */
23 .text : {
24 *(.text)
25 SCHED_TEXT
26 LOCK_TEXT
Michael Grundy4ba069b2006-09-20 15:58:39 +020027 KPROBES_TEXT
Linus Torvalds1da177e2005-04-16 15:20:36 -070028 *(.fixup)
29 *(.gnu.warning)
30 } = 0x0700
31
32 _etext = .; /* End of text section */
33
Linus Torvalds1da177e2005-04-16 15:20:36 -070034 RODATA
35
36#ifdef CONFIG_SHARED_KERNEL
37 . = ALIGN(1048576); /* VM shared segments are 1MB aligned */
Linus Torvalds1da177e2005-04-16 15:20:36 -070038#endif
39
Heiko Carstens162e0062007-02-05 21:18:41 +010040 . = ALIGN(4096);
41 _eshared = .; /* End of shareable data */
42
Hongjie Yangfe355b72007-02-05 21:18:24 +010043 . = ALIGN(16); /* Exception table */
44 __start___ex_table = .;
45 __ex_table : { *(__ex_table) }
46 __stop___ex_table = .;
47
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 .data : { /* Data */
49 *(.data)
50 CONSTRUCTORS
51 }
52
53 . = ALIGN(4096);
54 __nosave_begin = .;
55 .data_nosave : { *(.data.nosave) }
56 . = ALIGN(4096);
57 __nosave_end = .;
58
59 . = ALIGN(4096);
60 .data.page_aligned : { *(.data.idt) }
61
Christian Borntraeger58268b92006-04-27 18:40:24 -070062 . = ALIGN(256);
Linus Torvalds1da177e2005-04-16 15:20:36 -070063 .data.cacheline_aligned : { *(.data.cacheline_aligned) }
64
Christian Borntraeger58268b92006-04-27 18:40:24 -070065 . = ALIGN(256);
66 .data.read_mostly : { *(.data.read_mostly) }
Linus Torvalds1da177e2005-04-16 15:20:36 -070067 _edata = .; /* End of data section */
68
69 . = ALIGN(8192); /* init_task */
70 .data.init_task : { *(.data.init_task) }
71
72 /* will be freed after init */
73 . = ALIGN(4096); /* Init code and data */
74 __init_begin = .;
75 .init.text : {
76 _sinittext = .;
77 *(.init.text)
78 _einittext = .;
79 }
80 .init.data : { *(.init.data) }
81 . = ALIGN(256);
82 __setup_start = .;
83 .init.setup : { *(.init.setup) }
84 __setup_end = .;
85 __initcall_start = .;
86 .initcall.init : {
Andrew Morton61ce1ef2006-10-27 11:41:44 -070087 INITCALLS
Linus Torvalds1da177e2005-04-16 15:20:36 -070088 }
89 __initcall_end = .;
90 __con_initcall_start = .;
91 .con_initcall.init : { *(.con_initcall.init) }
92 __con_initcall_end = .;
93 SECURITY_INIT
94 . = ALIGN(256);
95 __initramfs_start = .;
96 .init.ramfs : { *(.init.initramfs) }
97 . = ALIGN(2);
98 __initramfs_end = .;
99 . = ALIGN(256);
100 __per_cpu_start = .;
101 .data.percpu : { *(.data.percpu) }
102 __per_cpu_end = .;
103 . = ALIGN(4096);
104 __init_end = .;
105 /* freed after init ends here */
106
107 __bss_start = .; /* BSS */
108 .bss : { *(.bss) }
109 . = ALIGN(2);
110 __bss_stop = .;
111
112 _end = . ;
113
114 /* Sections to be discarded */
115 /DISCARD/ : {
Heiko Carstens1375fc12006-09-20 15:59:12 +0200116 *(.exit.text) *(.exit.data) *(.exitcall.exit)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117 }
118
119 /* Stabs debugging sections. */
120 .stab 0 : { *(.stab) }
121 .stabstr 0 : { *(.stabstr) }
122 .stab.excl 0 : { *(.stab.excl) }
123 .stab.exclstr 0 : { *(.stab.exclstr) }
124 .stab.index 0 : { *(.stab.index) }
125 .stab.indexstr 0 : { *(.stab.indexstr) }
126 .comment 0 : { *(.comment) }
127}