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