OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [newlib-1.17.0/] [libgloss/] [m32c/] [m32c.tmpl] - Blame information for rev 818

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 148 jeremybenn
/*
2
 
3
Copyright (c) 2005,2008 Red Hat Incorporated.
4
All rights reserved.
5
 
6
Redistribution and use in source and binary forms, with or without
7
modification, 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
 
20
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
23
DISCLAIMED.  IN NO EVENT SHALL RED HAT INCORPORATED BE LIABLE FOR ANY
24
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
25
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
27
ON 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
29
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
 
31
*/
32
 
33
/* Default linker script, for normal executables */
34
OUTPUT_FORMAT("elf32-m32c", "elf32-m32c",
35
              "elf32-m32c")
36
OUTPUT_ARCH(m32c)
37
ENTRY(_start)
38
INPUT(-lm32cgloss)
39
/* Do we need any of these for elf?
40
   __DYNAMIC = 0;    */
41
MEMORY {
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
}
47
SECTIONS
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
}

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.