]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/blame - arch/s390/kernel/vmlinux.lds.S
arch/tile: adopt the new nmi_backtrace framework
[mirror_ubuntu-focal-kernel.git] / arch / s390 / kernel / vmlinux.lds.S
CommitLineData
1da177e4
LT
1/* ld script to make s390 Linux kernel
2 * Written by Martin Schwidefsky (schwidefsky@de.ibm.com)
3 */
4
0778dc3a 5#include <asm/thread_info.h>
52480ee5 6#include <asm/page.h>
0ccb32c9
HC
7
8/*
9 * Put .bss..swapper_pg_dir as the first thing in .bss. This will
10 * make sure it has 16k alignment.
11 */
12#define BSS_FIRST_SECTIONS *(.bss..swapper_pg_dir)
13
d07a980c
HC
14/* Handle ro_after_init data on our own. */
15#define RO_AFTER_INIT_DATA
16
1da177e4 17#include <asm-generic/vmlinux.lds.h>
1da177e4 18
1da177e4
LT
19OUTPUT_FORMAT("elf64-s390", "elf64-s390", "elf64-s390")
20OUTPUT_ARCH(s390:64-bit)
e0a15d5b 21ENTRY(startup)
1da177e4 22jiffies = jiffies_64;
1da177e4 23
ea29ee16
MS
24PHDRS {
25 text PT_LOAD FLAGS(5); /* R_E */
26 data PT_LOAD FLAGS(7); /* RWE */
27 note PT_NOTE FLAGS(0); /* ___ */
28}
29
1da177e4
LT
30SECTIONS
31{
e16af09d
SR
32 . = 0x00000000;
33 .text : {
34 _text = .; /* Text and read-only data */
2133bb8d
TA
35 HEAD_TEXT
36 TEXT_TEXT
e16af09d
SR
37 SCHED_TEXT
38 LOCK_TEXT
39 KPROBES_TEXT
88dbd203 40 IRQENTRY_TEXT
be7635e7 41 SOFTIRQENTRY_TEXT
e16af09d
SR
42 *(.fixup)
43 *(.gnu.warning)
a817a61f 44 } :text = 0x0700
1da177e4 45
e16af09d 46 _etext = .; /* End of text section */
1da177e4 47
ea29ee16 48 NOTES :text :note
ea29ee16 49
7a2512b7
MS
50 .dummy : { *(.dummy) } :data
51
56280b1b 52 RO_DATA_SECTION(PAGE_SIZE)
1da177e4
LT
53
54#ifdef CONFIG_SHARED_KERNEL
52480ee5 55 . = ALIGN(0x100000); /* VM shared segments are 1MB aligned */
162e006e 56#endif
1da177e4 57
52480ee5 58 . = ALIGN(PAGE_SIZE);
e16af09d 59 _eshared = .; /* End of shareable data */
dfcc3e6a 60 _sdata = .; /* Start of data section */
e16af09d 61
d07a980c
HC
62 . = ALIGN(PAGE_SIZE);
63 __start_ro_after_init = .;
64 .data..ro_after_init : {
65 *(.data..ro_after_init)
66 }
67 EXCEPTION_TABLE(16)
68 . = ALIGN(PAGE_SIZE);
69 __end_ro_after_init = .;
e16af09d 70
04a95f6d 71 RW_DATA_SECTION(0x100, PAGE_SIZE, THREAD_SIZE)
e16af09d 72
e16af09d
SR
73 _edata = .; /* End of data section */
74
e16af09d 75 /* will be freed after init */
52480ee5 76 . = ALIGN(PAGE_SIZE); /* Init code and data */
e16af09d 77 __init_begin = .;
04a95f6d
NE
78
79 INIT_TEXT_SECTION(PAGE_SIZE)
80
e16af09d
SR
81 /*
82 * .exit.text is discarded at runtime, not link time,
83 * to deal with references from __bug_table
84 */
85 .exit.text : {
01ba2bdc 86 EXIT_TEXT
e16af09d
SR
87 }
88
a4e69245
HC
89 .exit.data : {
90 EXIT_DATA
91 }
92
92e6ecf3
CB
93 /* early.c uses stsi, which requires page aligned data. */
94 . = ALIGN(PAGE_SIZE);
04a95f6d 95 INIT_DATA_SECTION(0x100)
e16af09d 96
0415b00d 97 PERCPU_SECTION(0x100)
52480ee5 98 . = ALIGN(PAGE_SIZE);
e16af09d
SR
99 __init_end = .; /* freed after init ends here */
100
0ccb32c9 101 BSS_SECTION(PAGE_SIZE, 4 * PAGE_SIZE, PAGE_SIZE)
e16af09d
SR
102
103 _end = . ;
104
e16af09d
SR
105 /* Debugging sections. */
106 STABS_DEBUG
107 DWARF_DEBUG
023bf6f1
TH
108
109 /* Sections to be discarded */
110 DISCARDS
1da177e4 111}