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