source: trunk/libs/newlib/src/libgloss/m32c/m32c.tmpl @ 514

Last change on this file since 514 was 444, checked in by satin@…, 7 years ago

add newlib,libalmos-mkh, restructure shared_syscalls.h and mini-libc

File size: 7.2 KB
Line 
1/*
2
3Copyright (c) 2005,2008 Red Hat Incorporated.
4All rights reserved.
5
6Redistribution and use in source and binary forms, with or without
7modification, are permitted provided that the following conditions are met:
8
9    Redistributions of source code must retain the above copyright
10    notice, this list of conditions and the following disclaimer.
11
12    Redistributions in binary form must reproduce the above copyright
13    notice, this list of conditions and the following disclaimer in the
14    documentation and/or other materials provided with the distribution.
15
16    The name of Red Hat Incorporated may not be used to endorse
17    or promote products derived from this software without specific
18    prior written permission.
19
20THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
23DISCLAIMED.  IN NO EVENT SHALL RED HAT INCORPORATED BE LIABLE FOR ANY
24DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
25(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
27ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
29SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
31*/
32
33/* Default linker script, for normal executables */
34OUTPUT_FORMAT("elf32-m32c", "elf32-m32c",
35              "elf32-m32c")
36OUTPUT_ARCH(m32c)
37ENTRY(_start)
38INPUT(-lm32cgloss)
39/* Do we need any of these for elf?
40   __DYNAMIC = 0;    */
41MEMORY {
42        RAM (w) : ORIGIN = RAMSTART, LENGTH = RAMSIZE
43        ROM (r) : ORIGIN = ROMSTART, LENGTH = ROMSIZE
44        VEC (r) : ORIGIN = VECSTART, LENGTH = 32
45        RESETVEC (r) : ORIGIN = RESETSTART, LENGTH = 4
46}
47SECTIONS
48{
49  /* There are three cases we care about: First, RW data that must be
50     in the low 64k.  This will always be copied from ROM.  Second, RO
51     data that must be in the low 64k.  This may be copied from ROM if
52     the ROM is above 64k.  Third, anything that does not need to be
53     in the first 64k.  Chips normally only have two memory regions;
54     low ram and either high or low rom.  We map the low rom needs
55     into one of the actual regions.  */
56
57  /* .text goes first so the rom image of ram data will follow it.  */
58  .text           :
59  {
60    *(.text .stub .text.* .gnu.linkonce.t.*)
61    KEEP (*(.text.*personality*))
62    /* .gnu.warning sections are handled specially by elf32.em.  */
63    *(.gnu.warning)
64    *(.interp .hash .dynsym .dynstr .gnu.version*)
65    PROVIDE (__etext = .);
66    PROVIDE (_etext = .);
67    PROVIDE (etext = .);
68    . = ALIGN(2);
69    PROVIDE(__romdatastart = .); /* IF_ROCOPY */
70  } > ROM =0
71
72  /* rodata will either be part of data, or will be in low rom.  So we
73     might be spanning it, or we might not.  This lets us include it
74     in our calculations when appropriate.  */
75
76  .rodata : {
77    . = ALIGN(2);
78    PROVIDE(__datastart = .); /* IF_ROCOPY */
79    *(.plt)
80    KEEP (*(.init))
81    KEEP (*(.fini))
82    *(.rodata .rodata.* .gnu.linkonce.r.*)
83    *(.rodata1)
84    *(.eh_frame_hdr)
85    KEEP (*(.eh_frame))
86    KEEP (*(.gcc_except_table)) *(.gcc_except_table.*)
87    . = ALIGN(2);
88    PROVIDE(__romdatastart = .); /* IF_ROROM */
89  } > LOWROM
90
91  .data : {
92    . = ALIGN(32 / 8);
93    PROVIDE (__datastart = .); /* IF_ROROM */
94    PROVIDE (__preinit_array_start = .);
95    KEEP (*(.preinit_array))
96    PROVIDE (__preinit_array_end = .);
97    PROVIDE (__init_array_start = .);
98    KEEP (*(.init_array))
99    PROVIDE (__init_array_end = .);
100    PROVIDE (__fini_array_start = .);
101    KEEP (*(.fini_array))
102    PROVIDE (__fini_array_end = .);
103
104    /* gcc uses crtbegin.o to find the start of
105       the constructors, so we make sure it is
106       first.  Because this is a wildcard, it
107       doesn't matter if the user does not
108       actually link against crtbegin.o; the
109       linker won't look for a file to match a
110       wildcard.  The wildcard also means that it
111       doesn't matter which directory crtbegin.o
112       is in.  */
113    KEEP (*crtbegin*.o(.ctors))
114    /* We don't want to include the .ctor section from
115       from the crtend.o file until after the sorted ctors.
116       The .ctor section from the crtend file contains the
117       end of ctors marker and it must be last */
118    KEEP (*(EXCLUDE_FILE (*crtend*.o ) .ctors))
119    KEEP (*(SORT(.ctors.*)))
120    KEEP (*(.ctors))
121
122    KEEP (*crtbegin*.o(.dtors))
123    KEEP (*(EXCLUDE_FILE (*crtend*.o ) .dtors))
124    KEEP (*(SORT(.dtors.*)))
125    KEEP (*(.dtors))
126
127    KEEP (*(.jcr))
128    *(.data.rel.ro.local) *(.data.rel.ro*)
129    *(.dynamic)
130
131    *(.data .data.* .gnu.linkonce.d.*)
132    KEEP (*(.gnu.linkonce.d.*personality*))
133    SORT(CONSTRUCTORS)
134    *(.data1)
135    *(.got.plt) *(.got)
136    PROVIDE (__var_vect_start = .);
137    *(.var_vects)
138
139    . = ALIGN(2);
140    _edata = .;
141    PROVIDE (edata = .);
142    PROVIDE (__dataend = .);
143  } > RAM AT>ROM
144
145  /* Note that __romdatacopysize may be ZERO for the simulator, which
146     knows how to intialize RAM directly.  It should ONLY be used for
147     copying data from ROM to RAM; if you need to know the size of the
148     data section, subtract the end symbol from the start symbol.  */
149  /* Note that crt0 assumes this is even; all the start/stop symbols
150     are also assumed word-aligned.  */
151  PROVIDE (__romdatacopysize = SIZEOF(.rodata) + SIZEOF(.data));
152
153  .bss : {
154    . = ALIGN(2);
155    PROVIDE (__bssstart = .);
156    *(.dynbss)
157    *(.bss .bss.* .gnu.linkonce.b.*)
158    *(COMMON)
159    . = ALIGN(2);
160    PROVIDE (__bssend = .);
161    _end = .;
162    PROVIDE (end = .);
163  } > RAM
164  PROVIDE (__bsssize = SIZEOF(.bss));
165
166  .stack (RAMSTART + RAMSIZE - 2) :
167  {
168    PROVIDE (__stack = .);
169    *(.stack)
170  }
171
172  .vec : {
173    *(.vec)
174  } > VEC
175  .resetvec : {
176    *(.resetvec)
177  } > RESETVEC
178
179  /* The rest are all not normally part of the runtime image.  */
180
181  /* Stabs debugging sections.  */
182  .stab          0 : { *(.stab) }
183  .stabstr       0 : { *(.stabstr) }
184  .stab.excl     0 : { *(.stab.excl) }
185  .stab.exclstr  0 : { *(.stab.exclstr) }
186  .stab.index    0 : { *(.stab.index) }
187  .stab.indexstr 0 : { *(.stab.indexstr) }
188  .comment       0 : { *(.comment) }
189  /* DWARF debug sections.
190     Symbols in the DWARF debugging sections are relative to the beginning
191     of the section so we begin them at 0.  */
192  /* DWARF 1 */
193  .debug          0 : { *(.debug) }
194  .line           0 : { *(.line) }
195  /* GNU DWARF 1 extensions */
196  .debug_srcinfo  0 : { *(.debug_srcinfo) }
197  .debug_sfnames  0 : { *(.debug_sfnames) }
198  /* DWARF 1.1 and DWARF 2 */
199  .debug_aranges  0 : { *(.debug_aranges) }
200  .debug_pubnames 0 : { *(.debug_pubnames) }
201  /* DWARF 2 */
202  .debug_info     0 : { *(.debug_info .gnu.linkonce.wi.*) }
203  .debug_abbrev   0 : { *(.debug_abbrev) }
204  .debug_line     0 : { *(.debug_line) }
205  .debug_frame    0 : { *(.debug_frame) }
206  .debug_str      0 : { *(.debug_str) }
207  .debug_loc      0 : { *(.debug_loc) }
208  .debug_macinfo  0 : { *(.debug_macinfo) }
209  /* SGI/MIPS DWARF 2 extensions */
210  .debug_weaknames 0 : { *(.debug_weaknames) }
211  .debug_funcnames 0 : { *(.debug_funcnames) }
212  .debug_typenames 0 : { *(.debug_typenames) }
213  .debug_varnames  0 : { *(.debug_varnames) }
214  /DISCARD/ : { *(.note.GNU-stack) }
215}
Note: See TracBrowser for help on using the repository browser.