blob: a53db23ee092fcbd37f2fa2e16ca5fbc8a583cd7 [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
Heiko Carstens0778dc32008-11-27 11:05:58 +01005#include <asm/thread_info.h>
Sam Ravnborg52480ee2007-10-12 16:11:50 +02006#include <asm/page.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07007#include <asm-generic/vmlinux.lds.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07008
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -08009#ifndef CONFIG_64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -070010OUTPUT_FORMAT("elf32-s390", "elf32-s390", "elf32-s390")
11OUTPUT_ARCH(s390)
12ENTRY(_start)
13jiffies = jiffies_64 + 4;
14#else
15OUTPUT_FORMAT("elf64-s390", "elf64-s390", "elf64-s390")
16OUTPUT_ARCH(s390:64-bit)
17ENTRY(_start)
18jiffies = jiffies_64;
19#endif
20
Martin Schwidefskyea29ee12008-01-26 14:11:21 +010021PHDRS {
22 text PT_LOAD FLAGS(5); /* R_E */
23 data PT_LOAD FLAGS(7); /* RWE */
24 note PT_NOTE FLAGS(0); /* ___ */
25}
26
Linus Torvalds1da177e2005-04-16 15:20:36 -070027SECTIONS
28{
Sam Ravnborge16af092007-10-12 16:11:49 +020029 . = 0x00000000;
30 .text : {
31 _text = .; /* Text and read-only data */
Tim Abbott2133bb82009-04-25 22:11:06 -040032 HEAD_TEXT
33 TEXT_TEXT
Sam Ravnborge16af092007-10-12 16:11:49 +020034 SCHED_TEXT
35 LOCK_TEXT
36 KPROBES_TEXT
Heiko Carstens88dbd202009-06-12 10:26:46 +020037 IRQENTRY_TEXT
Sam Ravnborge16af092007-10-12 16:11:49 +020038 *(.fixup)
39 *(.gnu.warning)
Heiko Carstensa817a612008-02-05 16:50:38 +010040 } :text = 0x0700
Linus Torvalds1da177e2005-04-16 15:20:36 -070041
Sam Ravnborge16af092007-10-12 16:11:49 +020042 _etext = .; /* End of text section */
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
Martin Schwidefskyea29ee12008-01-26 14:11:21 +010044 NOTES :text :note
Martin Schwidefskyea29ee12008-01-26 14:11:21 +010045
Sam Ravnborge16af092007-10-12 16:11:49 +020046 RODATA
Linus Torvalds1da177e2005-04-16 15:20:36 -070047
48#ifdef CONFIG_SHARED_KERNEL
Sam Ravnborg52480ee2007-10-12 16:11:50 +020049 . = ALIGN(0x100000); /* VM shared segments are 1MB aligned */
Linus Torvalds1da177e2005-04-16 15:20:36 -070050#endif
51
Sam Ravnborg52480ee2007-10-12 16:11:50 +020052 . = ALIGN(PAGE_SIZE);
Sam Ravnborge16af092007-10-12 16:11:49 +020053 _eshared = .; /* End of shareable data */
Heiko Carstens162e0062007-02-05 21:18:41 +010054
Sam Ravnborge16af092007-10-12 16:11:49 +020055 . = ALIGN(16); /* Exception table */
56 __ex_table : {
57 __start___ex_table = .;
58 *(__ex_table)
59 __stop___ex_table = .;
Heiko Carstens5453c1a2008-08-25 18:13:26 +020060 } :data
Linus Torvalds1da177e2005-04-16 15:20:36 -070061
Sam Ravnborge16af092007-10-12 16:11:49 +020062 .data : { /* Data */
63 DATA_DATA
64 CONSTRUCTORS
65 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070066
Sam Ravnborg52480ee2007-10-12 16:11:50 +020067 . = ALIGN(PAGE_SIZE);
Sam Ravnborge16af092007-10-12 16:11:49 +020068 .data_nosave : {
69 __nosave_begin = .;
70 *(.data.nosave)
71 }
Sam Ravnborg52480ee2007-10-12 16:11:50 +020072 . = ALIGN(PAGE_SIZE);
Sam Ravnborge16af092007-10-12 16:11:49 +020073 __nosave_end = .;
Linus Torvalds1da177e2005-04-16 15:20:36 -070074
Sam Ravnborg52480ee2007-10-12 16:11:50 +020075 . = ALIGN(PAGE_SIZE);
Sam Ravnborge16af092007-10-12 16:11:49 +020076 .data.page_aligned : {
77 *(.data.idt)
78 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070079
Sam Ravnborg52480ee2007-10-12 16:11:50 +020080 . = ALIGN(0x100);
Sam Ravnborge16af092007-10-12 16:11:49 +020081 .data.cacheline_aligned : {
82 *(.data.cacheline_aligned)
83 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070084
Sam Ravnborg52480ee2007-10-12 16:11:50 +020085 . = ALIGN(0x100);
Sam Ravnborge16af092007-10-12 16:11:49 +020086 .data.read_mostly : {
87 *(.data.read_mostly)
88 }
89 _edata = .; /* End of data section */
Heiko Carstensc0007f12007-04-27 16:01:42 +020090
Heiko Carstens0778dc32008-11-27 11:05:58 +010091 . = ALIGN(THREAD_SIZE); /* init_task */
Sam Ravnborge16af092007-10-12 16:11:49 +020092 .data.init_task : {
93 *(.data.init_task)
94 }
95
96 /* will be freed after init */
Sam Ravnborg52480ee2007-10-12 16:11:50 +020097 . = ALIGN(PAGE_SIZE); /* Init code and data */
Sam Ravnborge16af092007-10-12 16:11:49 +020098 __init_begin = .;
99 .init.text : {
100 _sinittext = .;
Sam Ravnborg01ba2bd2008-01-20 14:15:03 +0100101 INIT_TEXT
Sam Ravnborge16af092007-10-12 16:11:49 +0200102 _einittext = .;
103 }
104 /*
105 * .exit.text is discarded at runtime, not link time,
106 * to deal with references from __bug_table
107 */
108 .exit.text : {
Sam Ravnborg01ba2bd2008-01-20 14:15:03 +0100109 EXIT_TEXT
Sam Ravnborge16af092007-10-12 16:11:49 +0200110 }
111
Christian Borntraeger92e6ecf2009-03-26 15:23:58 +0100112 /* early.c uses stsi, which requires page aligned data. */
113 . = ALIGN(PAGE_SIZE);
Sam Ravnborge16af092007-10-12 16:11:49 +0200114 .init.data : {
Sam Ravnborg01ba2bd2008-01-20 14:15:03 +0100115 INIT_DATA
Sam Ravnborge16af092007-10-12 16:11:49 +0200116 }
Sam Ravnborg52480ee2007-10-12 16:11:50 +0200117 . = ALIGN(0x100);
Sam Ravnborge16af092007-10-12 16:11:49 +0200118 .init.setup : {
119 __setup_start = .;
120 *(.init.setup)
121 __setup_end = .;
122 }
123 .initcall.init : {
124 __initcall_start = .;
125 INITCALLS
126 __initcall_end = .;
127 }
128
129 .con_initcall.init : {
130 __con_initcall_start = .;
131 *(.con_initcall.init)
132 __con_initcall_end = .;
133 }
134 SECURITY_INIT
Jean-Paul Saman67d38222007-02-10 01:44:44 -0800135
136#ifdef CONFIG_BLK_DEV_INITRD
Sam Ravnborg52480ee2007-10-12 16:11:50 +0200137 . = ALIGN(0x100);
Sam Ravnborge16af092007-10-12 16:11:49 +0200138 .init.ramfs : {
139 __initramfs_start = .;
140 *(.init.ramfs)
141 . = ALIGN(2);
142 __initramfs_end = .;
143 }
Jean-Paul Saman67d38222007-02-10 01:44:44 -0800144#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145
Sam Ravnborg52480ee2007-10-12 16:11:50 +0200146 PERCPU(PAGE_SIZE)
147 . = ALIGN(PAGE_SIZE);
Sam Ravnborge16af092007-10-12 16:11:49 +0200148 __init_end = .; /* freed after init ends here */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700149
Sam Ravnborge16af092007-10-12 16:11:49 +0200150 /* BSS */
151 .bss : {
152 __bss_start = .;
153 *(.bss)
154 . = ALIGN(2);
155 __bss_stop = .;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700156 }
157
Sam Ravnborge16af092007-10-12 16:11:49 +0200158 _end = . ;
159
160 /* Sections to be discarded */
161 /DISCARD/ : {
Sam Ravnborg01ba2bd2008-01-20 14:15:03 +0100162 EXIT_DATA
Sam Ravnborge16af092007-10-12 16:11:49 +0200163 *(.exitcall.exit)
164 }
165
166 /* Debugging sections. */
167 STABS_DEBUG
168 DWARF_DEBUG
Linus Torvalds1da177e2005-04-16 15:20:36 -0700169}