/* ld script to make ARM Linux kernel * taken from the i386 version by Russell King * Written by Martin Mares */ OUTPUT_ARCH(arm) ENTRY(stext) SECTIONS { . = TEXTADDR; .text : { } /* Set text start address */ __init_begin = .; /* Init code and data */ .text.init : { *(.text.init) } __proc_info_begin = .; .proc.info : { *(.proc.info) } __proc_info_end = .; .data.init : { *(.data.init) } . = ALIGN(16); __setup_start = .; .setup.init : { *(.setup.init) } __setup_end = .; __initcall_start = .; .initcall.init : { *(.initcall.init) } __initcall_end = .; . = ALIGN(4096); __init_end = .; __ebsa285_begin = .; .text.ebsa285 : { *(.text.ebsa285) } .data.ebsa285 : { *(.data.ebsa285) } . = ALIGN(4096); __ebsa285_end = .; __netwinder_begin = .; .text.netwinder : { *(.text.netwinder) } .data.netwinder : { *(.data.netwinder) } . = ALIGN(4096); __netwinder_end = .; _text = .; /* Text and read-only data */ .text.real : { /* Real text segment */ *(.text) *(.fixup) *(.gnu.warning) } .text.lock : { *(.text.lock) } /* out-of-line lock text */ .rodata : { *(.rodata) } .kstrtab : { *(.kstrtab) } . = ALIGN(16); /* Exception table */ __start___ex_table = .; __ex_table : { *(__ex_table) } __stop___ex_table = .; __start___ksymtab = .; /* Kernel symbol table */ __ksymtab : { *(__ksymtab) } __stop___ksymtab = .; .got : { *(.got) } /* Global offset table */ _etext = .; /* End of text section */ . = ALIGN(8192); .data : { /* Data */ *(.init.task) *(.data) CONSTRUCTORS } _edata = .; /* End of data section */ __bss_start = .; /* BSS */ .bss : { *(.bss) } _end = . ; /* Stabs debugging sections. */ .stab 0 : { *(.stab) } .stabstr 0 : { *(.stabstr) } .stab.excl 0 : { *(.stab.excl) } .stab.exclstr 0 : { *(.stab.exclstr) } .stab.index 0 : { *(.stab.index) } .stab.indexstr 0 : { *(.stab.indexstr) } .comment 0 : { *(.comment) } }