24a1632cb3
- reduce differences between amd64 and i386. notably, share pmap.c between them. it makes several i386 pmap improvements available to amd64, including tlb shootdown reduction and bug fixes from Stephan Uphoff. - implement deferred pmap switching for amd64. - remove LARGEPAGES option. always use large pages if available. also, make it work on amd64.
57 lines
1.1 KiB
Plaintext
57 lines
1.1 KiB
Plaintext
/* $NetBSD: kern.ldscript.2MB,v 1.2 2007/10/18 15:28:33 yamt Exp $ */
|
|
|
|
OUTPUT_FORMAT("elf64-x86-64", "elf64-x86-64",
|
|
"elf64-x86-64")
|
|
OUTPUT_ARCH(i386:x86-64)
|
|
ENTRY(_start)
|
|
SECTIONS
|
|
{
|
|
/* Read-only sections, merged into text segment: */
|
|
.text :
|
|
AT (ADDR(.text))
|
|
{
|
|
*(.text)
|
|
*(.text.*)
|
|
*(.stub)
|
|
} =0
|
|
_etext = . ;
|
|
PROVIDE (etext = .) ;
|
|
|
|
.rodata :
|
|
AT (LOADADDR(.text) + (ADDR(.rodata) - ADDR(.text)))
|
|
{
|
|
*(.rodata)
|
|
*(.rodata.*)
|
|
}
|
|
|
|
/* Adjust the address for the data segment. We push the data segment
|
|
up to the next 2MB boundary so that we can map the text with large
|
|
pages. */
|
|
. = ALIGN(0x200000);
|
|
__data_start = . ;
|
|
.data :
|
|
AT (LOADADDR(.text) + (ADDR(.data) - ADDR(.text)))
|
|
{
|
|
*(.data)
|
|
*(.data.*)
|
|
}
|
|
_edata = . ;
|
|
PROVIDE (edata = .) ;
|
|
__bss_start = . ;
|
|
.bss :
|
|
AT (LOADADDR(.text) + (ADDR(.bss) - ADDR(.text)))
|
|
{
|
|
*(.bss)
|
|
*(.bss.*)
|
|
*(COMMON)
|
|
. = ALIGN(64 / 8);
|
|
}
|
|
. = ALIGN(64 / 8);
|
|
_end = . ;
|
|
PROVIDE (end = .) ;
|
|
.note.netbsd.ident :
|
|
{
|
|
KEEP(*(.note.netbsd.ident));
|
|
}
|
|
}
|