Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'libgloss/msp430/msp430xl-sim.ld')
-rw-r--r--libgloss/msp430/msp430xl-sim.ld96
1 files changed, 32 insertions, 64 deletions
diff --git a/libgloss/msp430/msp430xl-sim.ld b/libgloss/msp430/msp430xl-sim.ld
index 31ff85a70..322a490f4 100644
--- a/libgloss/msp430/msp430xl-sim.ld
+++ b/libgloss/msp430/msp430xl-sim.ld
@@ -1,4 +1,4 @@
-/* Copyright (c) 2013-2014 Red Hat, Inc. All rights reserved.
+/* Copyright (c) 2013 Red Hat, Inc. All rights reserved.
This copyrighted material is made available to anyone wishing to use, modify,
copy, or redistribute it subject to the terms and conditions of the BSD
@@ -8,20 +8,24 @@
is available at http://www.opensource.org/licenses. Any Red Hat trademarks that
are incorporated in the source code or documentation are not subject to the BSD
License and may only be used or replicated with the express permission of
- Red Hat, Inc. */
+ Red Hat, Inc.
-/* Default linker script, for large MSP430X executables. */
+*/
+/* Default linker script, for normal executables */
OUTPUT_ARCH(msp430)
ENTRY(_start)
+/* Do we need any of these for elf?
+ __DYNAMIC = 0; */
+
INCLUDE intr_vectors.ld
-MEMORY
-{
- RAM (w) : ORIGIN = 0x00200, LENGTH = 0x01e00
- ROM (rx) : ORIGIN = 0x02000, LENGTH = 0x0df00
- HIFRAM (rxw) : ORIGIN = 0x10000, LENGTH = 0x80000
+MEMORY {
+ RAM (rx) : ORIGIN = 0x00200, LENGTH = 0x0ee00
+ LOWROM (w) : ORIGIN = 0x0f000, LENGTH = 0x00800
+ ROM (w) : ORIGIN = 0x10000, LENGTH = 0x80000
+ RESETVEC (w) : ORIGIN = 0x0fffe, LENGTH = 0x00002
}
SECTIONS
@@ -29,22 +33,13 @@ SECTIONS
.resetvec :
{
*(.resetvec)
- } > VECT31
+ } > RESETVEC
- .upper.rodata :
- {
- . = ALIGN(2);
- *(.upper.rodata.* .upper.rodata)
- } > HIFRAM
-
- .rodata :
- {
+ .rodata : {
. = ALIGN(2);
*(.plt)
- *(.lower.rodata.* .lower.rodata)
*(.rodata .rodata.* .gnu.linkonce.r.* .const .const:*)
*(.rodata1)
-
*(.eh_frame_hdr)
KEEP (*(.eh_frame))
KEEP (*(.gcc_except_table)) *(.gcc_except_table.*)
@@ -83,19 +78,10 @@ SECTIONS
KEEP (*(.dtors))
} > ROM
- .upper.data :
- {
- . = ALIGN(2);
- *(.upper.data.* .upper.data)
- } > HIFRAM
-
- .data :
- {
+ .data : {
. = ALIGN(2);
PROVIDE (__datastart = .);
- *(.lower.data.* .lower.data)
- . = ALIGN(2);
KEEP (*(.jcr))
*(.data.rel.ro.local) *(.data.rel.ro*)
*(.dynamic)
@@ -113,30 +99,19 @@ SECTIONS
*(.sdata .sdata.* .gnu.linkonce.s.* D_2 D_1)
. = ALIGN(2);
-
_edata = .;
PROVIDE (edata = .);
PROVIDE (__dataend = .);
- } > RAM
+ } > RAM AT>ROM
/* Note that crt0 assumes this is a multiple of two; all the
start/stop symbols are also assumed word-aligned. */
PROVIDE(__romdatastart = LOADADDR(.data));
PROVIDE (__romdatacopysize = SIZEOF(.data));
- .upper.bss :
- {
- . = ALIGN(2);
- PROVIDE (__high_bssstart = .);
- *(.upper.bss.* .upper.bss)
- PROVIDE (__high_bssend = .);
- } > HIFRAM
-
- .bss :
- {
+ .bss : {
. = ALIGN(2);
PROVIDE (__bssstart = .);
- *(.lower.bss.* .lower.bss)
*(.dynbss)
*(.sbss .sbss.*)
*(.bss .bss.* .gnu.linkonce.b.*)
@@ -146,8 +121,7 @@ SECTIONS
PROVIDE (__bsssize = SIZEOF(.bss));
/* This section contains data that is not initialised at startup. */
- .noinit (NOLOAD) :
- {
+ .noinit : {
. = ALIGN(2);
PROVIDE (__noinit_start = .);
*(.noinit)
@@ -159,34 +133,28 @@ SECTIONS
_end = .;
PROVIDE (end = .);
- .stack (ORIGIN (HIFRAM) + LENGTH(HIFRAM)) :
+ .stack (ORIGIN (RAM) + LENGTH(RAM)) :
{
PROVIDE (__stack = .);
*(.stack)
}
- /* This is just for crt0.S and interrupt handlers. */
- .lowtext :
+ /* This is just for crt0.S */
+ .lowtext :
{
PROVIDE (_start = .);
. = ALIGN(2);
- KEEP (*(SORT(.crt_*)))
+ KEEP (*(.crt_init))
+ KEEP (*(.crt_bss))
+ KEEP (*(.crt_movedata))
+ KEEP (*(.crt_main))
KEEP (*(.lowtext))
- } > ROM
-
- .upper.text :
- {
- . = ALIGN(2);
- *(.upper.text.* .upper.text)
- } > HIFRAM
+ } > LOWROM
- .text :
+ .text :
{
. = ALIGN(2);
- *(.lower.text.* .lower.text)
- . = ALIGN(2);
*(.text .stub .text.* .gnu.linkonce.t.* .text:*)
-
KEEP (*(.text.*personality*))
/* .gnu.warning sections are handled specially by elf32.em. */
*(.gnu.warning)
@@ -220,16 +188,16 @@ SECTIONS
/* DWARF debug sections.
Symbols in the DWARF debugging sections are relative to the beginning
of the section so we begin them at 0. */
- /* DWARF 1. */
+ /* DWARF 1 */
.debug 0 : { *(.debug) }
.line 0 : { *(.line) }
- /* GNU DWARF 1 extensions. */
+ /* GNU DWARF 1 extensions */
.debug_srcinfo 0 : { *(.debug_srcinfo) }
.debug_sfnames 0 : { *(.debug_sfnames) }
- /* DWARF 1.1 and DWARF 2. */
+ /* DWARF 1.1 and DWARF 2 */
.debug_aranges 0 : { *(.debug_aranges) }
.debug_pubnames 0 : { *(.debug_pubnames) }
- /* DWARF 2. */
+ /* DWARF 2 */
.debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) }
.debug_abbrev 0 : { *(.debug_abbrev) }
.debug_line 0 : { *(.debug_line .debug_line.* .debug_line_end ) }
@@ -237,7 +205,7 @@ SECTIONS
.debug_str 0 : { *(.debug_str) }
.debug_loc 0 : { *(.debug_loc) }
.debug_macinfo 0 : { *(.debug_macinfo) }
- /* SGI/MIPS DWARF 2 extensions. */
+ /* SGI/MIPS DWARF 2 extensions */
.debug_weaknames 0 : { *(.debug_weaknames) }
.debug_funcnames 0 : { *(.debug_funcnames) }
.debug_typenames 0 : { *(.debug_typenames) }