1c5c7a7c3SSteve Kipisz/* 2c5c7a7c3SSteve Kipisz * Copyright (c) 2004-2008 Texas Instruments 3c5c7a7c3SSteve Kipisz * 4c5c7a7c3SSteve Kipisz * (C) Copyright 2002 5c5c7a7c3SSteve Kipisz * Gary Jennejohn, DENX Software Engineering, <garyj@denx.de> 6c5c7a7c3SSteve Kipisz * 7c5c7a7c3SSteve Kipisz * See file CREDITS for list of people who contributed to this 8c5c7a7c3SSteve Kipisz * project. 9c5c7a7c3SSteve Kipisz * 10c5c7a7c3SSteve Kipisz * This program is free software; you can redistribute it and/or 11c5c7a7c3SSteve Kipisz * modify it under the terms of the GNU General Public License as 12c5c7a7c3SSteve Kipisz * published by the Free Software Foundation; either version 2 of 13c5c7a7c3SSteve Kipisz * the License, or (at your option) any later version. 14c5c7a7c3SSteve Kipisz * 15c5c7a7c3SSteve Kipisz * This program is distributed in the hope that it will be useful, 16c5c7a7c3SSteve Kipisz * but WITHOUT ANY WARRANTY; without even the implied warranty of 17c5c7a7c3SSteve Kipisz * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18c5c7a7c3SSteve Kipisz * GNU General Public License for more details. 19c5c7a7c3SSteve Kipisz * 20c5c7a7c3SSteve Kipisz * You should have received a copy of the GNU General Public License 21c5c7a7c3SSteve Kipisz * along with this program; if not, write to the Free Software 22c5c7a7c3SSteve Kipisz * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 23c5c7a7c3SSteve Kipisz * MA 02111-1307 USA 24c5c7a7c3SSteve Kipisz */ 25c5c7a7c3SSteve Kipisz 26c5c7a7c3SSteve KipiszOUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm") 27c5c7a7c3SSteve KipiszOUTPUT_ARCH(arm) 28c5c7a7c3SSteve KipiszENTRY(_start) 29c5c7a7c3SSteve KipiszSECTIONS 30c5c7a7c3SSteve Kipisz{ 31c5c7a7c3SSteve Kipisz . = 0x00000000; 32c5c7a7c3SSteve Kipisz 33c5c7a7c3SSteve Kipisz . = ALIGN(4); 34c5c7a7c3SSteve Kipisz .text : 35c5c7a7c3SSteve Kipisz { 36c5c7a7c3SSteve Kipisz *(.__image_copy_start) 37c5c7a7c3SSteve Kipisz CPUDIR/start.o (.text*) 38*e2906a59SMasahiro Yamada board/ti/am335x/built-in.o (.text*) 39c5c7a7c3SSteve Kipisz *(.text*) 40c5c7a7c3SSteve Kipisz } 41c5c7a7c3SSteve Kipisz 42c5c7a7c3SSteve Kipisz . = ALIGN(4); 43c5c7a7c3SSteve Kipisz .rodata : { *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*))) } 44c5c7a7c3SSteve Kipisz 45c5c7a7c3SSteve Kipisz . = ALIGN(4); 46c5c7a7c3SSteve Kipisz .data : { 47c5c7a7c3SSteve Kipisz *(.data*) 48c5c7a7c3SSteve Kipisz } 49c5c7a7c3SSteve Kipisz 50c5c7a7c3SSteve Kipisz . = ALIGN(4); 51c5c7a7c3SSteve Kipisz 52c5c7a7c3SSteve Kipisz . = .; 53c5c7a7c3SSteve Kipisz 54c5c7a7c3SSteve Kipisz . = ALIGN(4); 55c5c7a7c3SSteve Kipisz .u_boot_list : { 56c5c7a7c3SSteve Kipisz KEEP(*(SORT(.u_boot_list*))); 57c5c7a7c3SSteve Kipisz } 58c5c7a7c3SSteve Kipisz 59c5c7a7c3SSteve Kipisz . = ALIGN(4); 60c5c7a7c3SSteve Kipisz 61c5c7a7c3SSteve Kipisz .image_copy_end : 62c5c7a7c3SSteve Kipisz { 63c5c7a7c3SSteve Kipisz *(.__image_copy_end) 64c5c7a7c3SSteve Kipisz } 65c5c7a7c3SSteve Kipisz 66c5c7a7c3SSteve Kipisz .rel_dyn_start : 67c5c7a7c3SSteve Kipisz { 68c5c7a7c3SSteve Kipisz *(.__rel_dyn_start) 69c5c7a7c3SSteve Kipisz } 70c5c7a7c3SSteve Kipisz 71c5c7a7c3SSteve Kipisz .rel.dyn : { 72c5c7a7c3SSteve Kipisz *(.rel*) 73c5c7a7c3SSteve Kipisz } 74c5c7a7c3SSteve Kipisz 75c5c7a7c3SSteve Kipisz .rel_dyn_end : 76c5c7a7c3SSteve Kipisz { 77c5c7a7c3SSteve Kipisz *(.__rel_dyn_end) 78c5c7a7c3SSteve Kipisz } 79c5c7a7c3SSteve Kipisz 80c5c7a7c3SSteve Kipisz _end = .; 81c5c7a7c3SSteve Kipisz 82c5c7a7c3SSteve Kipisz /* 83c5c7a7c3SSteve Kipisz * Deprecated: this MMU section is used by pxa at present but 84c5c7a7c3SSteve Kipisz * should not be used by new boards/CPUs. 85c5c7a7c3SSteve Kipisz */ 86c5c7a7c3SSteve Kipisz . = ALIGN(4096); 87c5c7a7c3SSteve Kipisz .mmutable : { 88c5c7a7c3SSteve Kipisz *(.mmutable) 89c5c7a7c3SSteve Kipisz } 90c5c7a7c3SSteve Kipisz 91c5c7a7c3SSteve Kipisz/* 92c5c7a7c3SSteve Kipisz * Compiler-generated __bss_start and __bss_end, see arch/arm/lib/bss.c 93c5c7a7c3SSteve Kipisz * __bss_base and __bss_limit are for linker only (overlay ordering) 94c5c7a7c3SSteve Kipisz */ 95c5c7a7c3SSteve Kipisz 96c5c7a7c3SSteve Kipisz .bss_start __rel_dyn_start (OVERLAY) : { 97c5c7a7c3SSteve Kipisz KEEP(*(.__bss_start)); 98c5c7a7c3SSteve Kipisz __bss_base = .; 99c5c7a7c3SSteve Kipisz } 100c5c7a7c3SSteve Kipisz 101c5c7a7c3SSteve Kipisz .bss __bss_base (OVERLAY) : { 102c5c7a7c3SSteve Kipisz *(.bss*) 103c5c7a7c3SSteve Kipisz . = ALIGN(4); 104c5c7a7c3SSteve Kipisz __bss_limit = .; 105c5c7a7c3SSteve Kipisz } 106c5c7a7c3SSteve Kipisz 107c5c7a7c3SSteve Kipisz .bss_end __bss_limit (OVERLAY) : { 108c5c7a7c3SSteve Kipisz KEEP(*(.__bss_end)); 109c5c7a7c3SSteve Kipisz } 110c5c7a7c3SSteve Kipisz 111c5c7a7c3SSteve Kipisz /DISCARD/ : { *(.dynsym) } 112c5c7a7c3SSteve Kipisz /DISCARD/ : { *(.dynstr*) } 113c5c7a7c3SSteve Kipisz /DISCARD/ : { *(.dynamic*) } 114c5c7a7c3SSteve Kipisz /DISCARD/ : { *(.plt*) } 115c5c7a7c3SSteve Kipisz /DISCARD/ : { *(.interp*) } 116c5c7a7c3SSteve Kipisz /DISCARD/ : { *(.gnu*) } 117c5c7a7c3SSteve Kipisz} 118