Linux Audio

Check our new training course

Linux debugging, profiling, tracing and performance analysis training

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