2006-06-08 17:37:39 +00:00
|
|
|
/*
|
|
|
|
* (C) Copyright 2004, Psyent Corporation <www.psyent.com>
|
|
|
|
* Scott McNutt <smcnutt@psyent.com>
|
|
|
|
*
|
2013-10-07 11:07:26 +00:00
|
|
|
* SPDX-License-Identifier: GPL-2.0+
|
2006-06-08 17:37:39 +00:00
|
|
|
*/
|
|
|
|
|
2014-08-28 09:29:06 +00:00
|
|
|
#include <config.h>
|
2006-06-08 17:37:39 +00:00
|
|
|
|
|
|
|
OUTPUT_FORMAT("elf32-littlenios2")
|
|
|
|
OUTPUT_ARCH(nios2)
|
|
|
|
ENTRY(_start)
|
|
|
|
|
|
|
|
SECTIONS
|
|
|
|
{
|
2014-08-28 09:29:06 +00:00
|
|
|
. = CONFIG_SYS_MONITOR_BASE;
|
2006-06-08 17:37:39 +00:00
|
|
|
.text :
|
|
|
|
{
|
2010-04-16 20:12:39 +00:00
|
|
|
arch/nios2/cpu/start.o (.text)
|
2006-06-08 17:37:39 +00:00
|
|
|
*(.text)
|
|
|
|
*(.text.*)
|
|
|
|
*(.gnu.linkonce.t*)
|
2009-02-18 23:22:05 +00:00
|
|
|
*(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*)))
|
2006-06-08 17:37:39 +00:00
|
|
|
*(.gnu.linkonce.r*)
|
|
|
|
}
|
|
|
|
. = ALIGN (4);
|
|
|
|
_etext = .;
|
|
|
|
PROVIDE (etext = .);
|
|
|
|
|
|
|
|
/* CMD TABLE - sandwich this in between text and data so
|
|
|
|
* the initialization code relocates the command table as
|
|
|
|
* well -- admittedly, this is just pure laziness ;-)
|
|
|
|
*/
|
|
|
|
|
2012-10-12 10:27:03 +00:00
|
|
|
. = ALIGN(4);
|
|
|
|
.u_boot_list : {
|
2013-02-25 00:59:00 +00:00
|
|
|
KEEP(*(SORT(.u_boot_list*)));
|
2012-10-12 10:27:03 +00:00
|
|
|
}
|
|
|
|
|
2006-06-08 17:37:39 +00:00
|
|
|
/* INIT DATA sections - "Small" data (see the gcc -G option)
|
|
|
|
* is always gp-relative. Here we make all init data sections
|
|
|
|
* adjacent to simplify the startup code -- and provide
|
|
|
|
* the global pointer for gp-relative access.
|
|
|
|
*/
|
|
|
|
_data = .;
|
|
|
|
.data :
|
|
|
|
{
|
|
|
|
*(.data)
|
|
|
|
*(.data.*)
|
|
|
|
*(.gnu.linkonce.d*)
|
|
|
|
}
|
|
|
|
|
2015-09-06 12:18:10 +00:00
|
|
|
/*
|
|
|
|
* gp - Since we don't use gp for small data with option "-G0",
|
|
|
|
* we will use gp as global data pointer. The _gp location is
|
|
|
|
* not needed.
|
|
|
|
*/
|
2006-06-08 17:37:39 +00:00
|
|
|
|
|
|
|
.sdata :
|
|
|
|
{
|
|
|
|
*(.sdata)
|
|
|
|
*(.sdata.*)
|
|
|
|
*(.gnu.linkonce.s.*)
|
|
|
|
}
|
|
|
|
. = ALIGN(4);
|
|
|
|
|
|
|
|
_edata = .;
|
|
|
|
PROVIDE (edata = .);
|
|
|
|
|
2015-09-06 12:13:34 +00:00
|
|
|
/*
|
|
|
|
* _end - This is end of u-boot.bin image.
|
|
|
|
* dtb will be appended here to make u-boot-dtb.bin
|
|
|
|
*/
|
|
|
|
_end = .;
|
|
|
|
|
2006-06-08 17:37:39 +00:00
|
|
|
/* UNINIT DATA - Small uninitialized data is first so it's
|
|
|
|
* adjacent to sdata and can be referenced via gp. The normal
|
|
|
|
* bss follows. We keep it adjacent to simplify init code.
|
|
|
|
*/
|
|
|
|
__bss_start = .;
|
2008-01-12 19:31:39 +00:00
|
|
|
.sbss (NOLOAD) :
|
2006-06-08 17:37:39 +00:00
|
|
|
{
|
|
|
|
*(.sbss)
|
|
|
|
*(.sbss.*)
|
|
|
|
*(.gnu.linkonce.sb.*)
|
|
|
|
*(.scommon)
|
|
|
|
}
|
|
|
|
. = ALIGN(4);
|
2008-01-12 19:31:39 +00:00
|
|
|
.bss (NOLOAD) :
|
2006-06-08 17:37:39 +00:00
|
|
|
{
|
|
|
|
*(.bss)
|
|
|
|
*(.bss.*)
|
|
|
|
*(.dynbss)
|
|
|
|
*(COMMON)
|
|
|
|
*(.scommon)
|
|
|
|
}
|
|
|
|
. = ALIGN(4);
|
2013-03-14 06:54:53 +00:00
|
|
|
__bss_end = .;
|
2006-06-08 17:37:39 +00:00
|
|
|
PROVIDE (end = .);
|
|
|
|
|
|
|
|
/* DEBUG -- symbol table, string table, etc. etc.
|
|
|
|
*/
|
|
|
|
.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) }
|
|
|
|
.debug 0 : { *(.debug) }
|
|
|
|
.line 0 : { *(.line) }
|
|
|
|
.debug_srcinfo 0 : { *(.debug_srcinfo) }
|
|
|
|
.debug_sfnames 0 : { *(.debug_sfnames) }
|
|
|
|
.debug_aranges 0 : { *(.debug_aranges) }
|
|
|
|
.debug_pubnames 0 : { *(.debug_pubnames) }
|
|
|
|
.debug_info 0 : { *(.debug_info) }
|
|
|
|
.debug_abbrev 0 : { *(.debug_abbrev) }
|
|
|
|
.debug_line 0 : { *(.debug_line) }
|
|
|
|
.debug_frame 0 : { *(.debug_frame) }
|
|
|
|
.debug_str 0 : { *(.debug_str) }
|
|
|
|
.debug_loc 0 : { *(.debug_loc) }
|
|
|
|
.debug_macinfo 0 : { *(.debug_macinfo) }
|
|
|
|
.debug_weaknames 0 : { *(.debug_weaknames) }
|
|
|
|
.debug_funcnames 0 : { *(.debug_funcnames) }
|
|
|
|
.debug_typenames 0 : { *(.debug_typenames) }
|
|
|
|
.debug_varnames 0 : { *(.debug_varnames) }
|
|
|
|
}
|