1/* 2 * Copyright 2006, 2007 Freescale Semiconductor, Inc. 3 * 4 * See file CREDITS for list of people who contributed to this 5 * project. 6 * 7 * This program is free software; you can redistribute it and/or 8 * modify it under the terms of the GNU General Public License as 9 * published by the Free Software Foundation; either version 2 of 10 * the License, or (at your option) any later version. 11 * 12 * This program is distributed in the hope that it will be useful, 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15 * GNU General Public License for more details. 16 * 17 * You should have received a copy of the GNU General Public License 18 * along with this program; if not, write to the Free Software 19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 20 * MA 02111-1307 USA 21 */ 22 23OUTPUT_ARCH(powerpc) 24 25SECTIONS 26{ 27 28 /* Read-only sections, merged into text segment: */ 29 .interp : { *(.interp) } 30 .hash : { *(.hash) } 31 .dynsym : { *(.dynsym) } 32 .dynstr : { *(.dynstr) } 33 .rel.text : { *(.rel.text) } 34 .rela.text : { *(.rela.text) } 35 .rel.data : { *(.rel.data) } 36 .rela.data : { *(.rela.data) } 37 .rel.rodata : { *(.rel.rodata) } 38 .rela.rodata : { *(.rela.rodata) } 39 .rel.got : { *(.rel.got) } 40 .rela.got : { *(.rela.got) } 41 .rel.ctors : { *(.rel.ctors) } 42 .rela.ctors : { *(.rela.ctors) } 43 .rel.dtors : { *(.rel.dtors) } 44 .rela.dtors : { *(.rela.dtors) } 45 .rel.bss : { *(.rel.bss) } 46 .rela.bss : { *(.rela.bss) } 47 .rel.plt : { *(.rel.plt) } 48 .rela.plt : { *(.rela.plt) } 49 .init : { *(.init) } 50 .plt : { *(.plt) } 51 .text : 52 { 53 arch/powerpc/cpu/mpc86xx/start.o (.text) 54 arch/powerpc/cpu/mpc86xx/traps.o (.text) 55 arch/powerpc/cpu/mpc86xx/interrupts.o (.text) 56 arch/powerpc/cpu/mpc86xx/cpu_init.o (.text) 57 arch/powerpc/cpu/mpc86xx/cpu.o (.text) 58 arch/powerpc/cpu/mpc86xx/speed.o (.text) 59 common/dlmalloc.o (.text) 60 lib/crc32.o (.text) 61 arch/powerpc/lib/extable.o (.text) 62 lib/zlib.o (.text) 63 *(.text*) 64 } 65 _etext = .; 66 PROVIDE (etext = .); 67 .rodata : 68 { 69 *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*))) 70 } 71 72 /* Read-write section, merged into data segment: */ 73 . = (. + 0x00FF) & 0xFFFFFF00; 74 _erotext = .; 75 PROVIDE (erotext = .); 76 .reloc : 77 { 78 KEEP(*(.got)) 79 _GOT2_TABLE_ = .; 80 KEEP(*(.got2)) 81 _FIXUP_TABLE_ = .; 82 KEEP(*(.fixup)) 83 } 84 __got2_entries = (_FIXUP_TABLE_ - _GOT2_TABLE_) >> 2; 85 __fixup_entries = (. - _FIXUP_TABLE_) >> 2; 86 87 .data : 88 { 89 *(.data*) 90 *(.sdata*) 91 } 92 _edata = .; 93 PROVIDE (edata = .); 94 95 . = .; 96 __u_boot_cmd_start = .; 97 .u_boot_cmd : { *(.u_boot_cmd) } 98 __u_boot_cmd_end = .; 99 100 . = .; 101 __start___ex_table = .; 102 __ex_table : { *(__ex_table) } 103 __stop___ex_table = .; 104 105 . = ALIGN(256); 106 __init_begin = .; 107 .text.init : { *(.text.init) } 108 .data.init : { *(.data.init) } 109 . = ALIGN(256); 110 __init_end = .; 111 112 __bss_start = .; 113 .bss (NOLOAD) : 114 { 115 *(.sbss*) 116 *(.bss*) 117 *(COMMON) 118 . = ALIGN(4); 119 } 120 _end = . ; 121 PROVIDE (end = .); 122} 123