1 1.2.16.2 matt /* $NetBSD: kern.ldscript.Xen,v 1.2.16.2 2008/01/09 01:44:51 matt Exp $ */ 2 1.2.16.2 matt 3 1.2.16.2 matt OUTPUT_FORMAT("elf64-x86-64", "elf64-x86-64", 4 1.2.16.2 matt "elf64-x86-64") 5 1.2.16.2 matt OUTPUT_ARCH(i386:x86-64) 6 1.2.16.2 matt ENTRY(_start) 7 1.2.16.2 matt SECTIONS 8 1.2.16.2 matt { 9 1.2.16.2 matt /* Read-only sections, merged into text segment: */ 10 1.2.16.2 matt .text : 11 1.2.16.2 matt AT (ADDR(.text)) 12 1.2.16.2 matt { 13 1.2.16.2 matt *(.text) 14 1.2.16.2 matt *(.text.*) 15 1.2.16.2 matt *(.stub) 16 1.2.16.2 matt *(.rodata) 17 1.2.16.2 matt } =0 18 1.2.16.2 matt _etext = . ; 19 1.2.16.2 matt PROVIDE (etext = .) ; 20 1.2.16.2 matt 21 1.2.16.2 matt /* Adjust the address for the data segment. We want to adjust up to 22 1.2.16.2 matt the same address within the page on the next page up. */ 23 1.2.16.2 matt . = ALIGN(0x100000) + (. & (0x100000 - 1)); 24 1.2.16.2 matt __data_start = . ; 25 1.2.16.2 matt .data : 26 1.2.16.2 matt AT (LOADADDR(.text) + (ADDR(.data) - ADDR(.text))) 27 1.2.16.2 matt { 28 1.2.16.2 matt *(.data) 29 1.2.16.2 matt *(.data.*) 30 1.2.16.2 matt } 31 1.2.16.2 matt _edata = . ; 32 1.2.16.2 matt PROVIDE (edata = .) ; 33 1.2.16.2 matt __bss_start = . ; 34 1.2.16.2 matt .bss : 35 1.2.16.2 matt AT (LOADADDR(.text) + (ADDR(.bss) - ADDR(.text))) 36 1.2.16.2 matt { 37 1.2.16.2 matt *(.bss) 38 1.2.16.2 matt *(.bss.*) 39 1.2.16.2 matt *(COMMON) 40 1.2.16.2 matt . = ALIGN(64 / 8); 41 1.2.16.2 matt } 42 1.2.16.2 matt . = ALIGN(64 / 8); 43 1.2.16.2 matt _end = . ; 44 1.2.16.2 matt PROVIDE (end = .) ; 45 1.2.16.2 matt .note.netbsd.ident : 46 1.2.16.2 matt { 47 1.2.16.2 matt KEEP(*(.note.netbsd.ident)); 48 1.2.16.2 matt } 49 1.2.16.2 matt } 50