xref: /openbmc/linux/arch/parisc/kernel/vmlinux.lds.S (revision b78412b8)
1/*    Kernel link layout for various "sections"
2 *
3 *    Copyright (C) 1999-2003 Matthew Wilcox <willy at parisc-linux.org>
4 *    Copyright (C) 2000-2003 Paul Bame <bame at parisc-linux.org>
5 *    Copyright (C) 2000 John Marvin <jsm at parisc-linux.org>
6 *    Copyright (C) 2000 Michael Ang <mang with subcarrier.org>
7 *    Copyright (C) 2002 Randolph Chung <tausq with parisc-linux.org>
8 *    Copyright (C) 2003 James Bottomley <jejb with parisc-linux.org>
9 *    Copyright (C) 2006-2013 Helge Deller <deller@gmx.de>
10 */
11
12/*
13 * Put page table entries (swapper_pg_dir) as the first thing in .bss. This
14 * will ensure that it has .bss alignment (PAGE_SIZE).
15 */
16#define BSS_FIRST_SECTIONS	*(.data..vm0.pmd) \
17				*(.data..vm0.pgd) \
18				*(.data..vm0.pte)
19
20#include <asm-generic/vmlinux.lds.h>
21
22/* needed for the processor specific cache alignment size */
23#include <asm/cache.h>
24#include <asm/page.h>
25#include <asm/asm-offsets.h>
26#include <asm/thread_info.h>
27
28/* ld script to make hppa Linux kernel */
29#ifndef CONFIG_64BIT
30OUTPUT_FORMAT("elf32-hppa-linux")
31OUTPUT_ARCH(hppa)
32#else
33OUTPUT_FORMAT("elf64-hppa-linux")
34OUTPUT_ARCH(hppa:hppa2.0w)
35#endif
36
37ENTRY(parisc_kernel_start)
38#ifndef CONFIG_64BIT
39jiffies = jiffies_64 + 4;
40#else
41jiffies = jiffies_64;
42#endif
43SECTIONS
44{
45	. = KERNEL_BINARY_TEXT_START;
46
47	__init_begin = .;
48	HEAD_TEXT_SECTION
49	INIT_TEXT_SECTION(8)
50
51	. = ALIGN(PAGE_SIZE);
52	INIT_DATA_SECTION(PAGE_SIZE)
53	/* we have to discard exit text and such at runtime, not link time */
54	.exit.text :
55	{
56		EXIT_TEXT
57	}
58	.exit.data :
59	{
60		EXIT_DATA
61	}
62	PERCPU_SECTION(8)
63	. = ALIGN(HUGEPAGE_SIZE);
64	__init_end = .;
65	/* freed after init ends here */
66
67	_text = .;		/* Text and read-only data */
68	_stext = .;
69	.text ALIGN(PAGE_SIZE) : {
70		TEXT_TEXT
71		SCHED_TEXT
72		CPUIDLE_TEXT
73		LOCK_TEXT
74		KPROBES_TEXT
75		IRQENTRY_TEXT
76		SOFTIRQENTRY_TEXT
77		*(.text.do_softirq)
78		*(.text.sys_exit)
79		*(.text.do_sigaltstack)
80		*(.text.do_fork)
81		*(.text.div)
82		*($$*)			/* millicode routines */
83		*(.text.*)
84		*(.fixup)
85		*(.lock.text)		/* out-of-line lock text */
86		*(.gnu.warning)
87	}
88	. = ALIGN(PAGE_SIZE);
89	_etext = .;
90	/* End of text section */
91
92	/* Start of data section */
93	_sdata = .;
94
95	/* Architecturally we need to keep __gp below 0x1000000 and thus
96	 * in front of RO_DATA_SECTION() which stores lots of tracepoint
97	 * and ftrace symbols. */
98#ifdef CONFIG_64BIT
99	. = ALIGN(16);
100	/* Linkage tables */
101	.opd : {
102		*(.opd)
103	} PROVIDE (__gp = .);
104	.plt : {
105		*(.plt)
106	}
107	.dlt : {
108		*(.dlt)
109	}
110#endif
111
112	RO_DATA_SECTION(8)
113
114	/* RO because of BUILDTIME_EXTABLE_SORT */
115	EXCEPTION_TABLE(8)
116	NOTES
117
118	/* unwind info */
119	.PARISC.unwind : {
120		__start___unwind = .;
121		*(.PARISC.unwind)
122		__stop___unwind = .;
123	}
124
125	/* writeable */
126	/* Make sure this is page aligned so
127	 * that we can properly leave these
128	 * as writable
129	 */
130	. = ALIGN(HUGEPAGE_SIZE);
131	data_start = .;
132
133	/* Data */
134	RW_DATA_SECTION(L1_CACHE_BYTES, PAGE_SIZE, PAGE_SIZE)
135
136	/* PA-RISC locks requires 16-byte alignment */
137	. = ALIGN(16);
138	.data..lock_aligned : {
139		*(.data..lock_aligned)
140	}
141
142	/* End of data section */
143	_edata = .;
144
145	/* BSS */
146	BSS_SECTION(PAGE_SIZE, PAGE_SIZE, PAGE_SIZE)
147
148	. = ALIGN(HUGEPAGE_SIZE);
149	_end = . ;
150
151	STABS_DEBUG
152	.note 0 : { *(.note) }
153
154	/* Sections to be discarded */
155	DISCARDS
156	/DISCARD/ : {
157#ifdef CONFIG_64BIT
158		/* temporary hack until binutils is fixed to not emit these
159	 	 * for static binaries
160		 */
161		*(.interp)
162		*(.dynsym)
163		*(.dynstr)
164		*(.dynamic)
165		*(.hash)
166		*(.gnu.hash)
167#endif
168	}
169}
170