92ca52343c
This has the consequence of changing the section name use for head code from ".text.head" to ".head.text". Since this commit changes all users in the architecture, this change should be harmless. Signed-off-by: Tim Abbott <tabbott@mit.edu> Cc: Richard Henderson <rth@twiddle.net> Acked-by: Sam Ravnborg <sam@ravnborg.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
153 lines
2.1 KiB
ArmAsm
153 lines
2.1 KiB
ArmAsm
#include <asm-generic/vmlinux.lds.h>
|
|
#include <asm/page.h>
|
|
|
|
OUTPUT_FORMAT("elf64-alpha")
|
|
OUTPUT_ARCH(alpha)
|
|
ENTRY(__start)
|
|
PHDRS { kernel PT_LOAD; note PT_NOTE; }
|
|
jiffies = jiffies_64;
|
|
SECTIONS
|
|
{
|
|
#ifdef CONFIG_ALPHA_LEGACY_START_ADDRESS
|
|
. = 0xfffffc0000310000;
|
|
#else
|
|
. = 0xfffffc0001010000;
|
|
#endif
|
|
|
|
_text = .; /* Text and read-only data */
|
|
.text : {
|
|
HEAD_TEXT
|
|
TEXT_TEXT
|
|
SCHED_TEXT
|
|
LOCK_TEXT
|
|
*(.fixup)
|
|
*(.gnu.warning)
|
|
} :kernel
|
|
_etext = .; /* End of text section */
|
|
|
|
NOTES :kernel :note
|
|
.dummy : {
|
|
*(.dummy)
|
|
} :kernel
|
|
|
|
RODATA
|
|
|
|
/* Exception table */
|
|
. = ALIGN(16);
|
|
__ex_table : {
|
|
__start___ex_table = .;
|
|
*(__ex_table)
|
|
__stop___ex_table = .;
|
|
}
|
|
|
|
/* Will be freed after init */
|
|
. = ALIGN(PAGE_SIZE);
|
|
/* Init code and data */
|
|
__init_begin = .;
|
|
.init.text : {
|
|
_sinittext = .;
|
|
INIT_TEXT
|
|
_einittext = .;
|
|
}
|
|
.init.data : {
|
|
INIT_DATA
|
|
}
|
|
|
|
. = ALIGN(16);
|
|
.init.setup : {
|
|
__setup_start = .;
|
|
*(.init.setup)
|
|
__setup_end = .;
|
|
}
|
|
|
|
. = ALIGN(8);
|
|
.initcall.init : {
|
|
__initcall_start = .;
|
|
INITCALLS
|
|
__initcall_end = .;
|
|
}
|
|
|
|
#ifdef CONFIG_BLK_DEV_INITRD
|
|
. = ALIGN(PAGE_SIZE);
|
|
.init.ramfs : {
|
|
__initramfs_start = .;
|
|
*(.init.ramfs)
|
|
__initramfs_end = .;
|
|
}
|
|
#endif
|
|
|
|
. = ALIGN(8);
|
|
.con_initcall.init : {
|
|
__con_initcall_start = .;
|
|
*(.con_initcall.init)
|
|
__con_initcall_end = .;
|
|
}
|
|
|
|
. = ALIGN(8);
|
|
SECURITY_INIT
|
|
|
|
PERCPU(PAGE_SIZE)
|
|
|
|
. = ALIGN(2 * PAGE_SIZE);
|
|
__init_end = .;
|
|
/* Freed after init ends here */
|
|
|
|
/* Note 2 page alignment above. */
|
|
.data.init_thread : {
|
|
*(.data.init_thread)
|
|
}
|
|
|
|
. = ALIGN(PAGE_SIZE);
|
|
.data.page_aligned : {
|
|
*(.data.page_aligned)
|
|
}
|
|
|
|
. = ALIGN(64);
|
|
.data.cacheline_aligned : {
|
|
*(.data.cacheline_aligned)
|
|
}
|
|
|
|
_data = .;
|
|
/* Data */
|
|
.data : {
|
|
DATA_DATA
|
|
CONSTRUCTORS
|
|
}
|
|
|
|
.got : {
|
|
*(.got)
|
|
}
|
|
.sdata : {
|
|
*(.sdata)
|
|
}
|
|
_edata = .; /* End of data section */
|
|
|
|
__bss_start = .;
|
|
.sbss : {
|
|
*(.sbss)
|
|
*(.scommon)
|
|
}
|
|
.bss : {
|
|
*(.bss)
|
|
*(COMMON)
|
|
}
|
|
__bss_stop = .;
|
|
_end = .;
|
|
|
|
/* Sections to be discarded */
|
|
/DISCARD/ : {
|
|
EXIT_TEXT
|
|
EXIT_DATA
|
|
*(.exitcall.exit)
|
|
}
|
|
|
|
.mdebug 0 : {
|
|
*(.mdebug)
|
|
}
|
|
.note 0 : {
|
|
*(.note)
|
|
}
|
|
|
|
STABS_DEBUG
|
|
DWARF_DEBUG
|
|
}
|