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

Subversion Repositories openmsp430

[/] [openmsp430/] [trunk/] [core/] [sim/] [rtl_sim/] [src/] [ldscript_example.x] - Blame information for rev 145

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

Line No. Rev Author Line
1 115 olivier.gi
/* Default linker script, for normal executables */
2 145 olivier.gi
OUTPUT_FORMAT("elf32-msp430")
3 142 olivier.gi
OUTPUT_ARCH("msp430")
4 145 olivier.gi
MEMORY {
5
  sfr              : ORIGIN = 0x0000, LENGTH = 0x0010
6
  peripheral_8bit  : ORIGIN = 0x0010, LENGTH = 0x00f0
7
  peripheral_16bit : ORIGIN = 0x0100, LENGTH = 0x0100
8
 
9
  ram (wx)         : ORIGIN = 0x0200, LENGTH = 128
10
  rom (rx)         : ORIGIN = 0xf800, LENGTH = 2048-32
11
 
12
  vectors          : ORIGIN = 0xffe0, LENGTH = 32
13
 
14
  /* Remaining banks are absent */
15
  bsl              : ORIGIN = 0x0000, LENGTH = 0x0000
16
  infomem          : ORIGIN = 0x0000, LENGTH = 0x0000
17
  infob            : ORIGIN = 0x0000, LENGTH = 0x0000
18
  infoa            : ORIGIN = 0x0000, LENGTH = 0x0000
19
  infoc            : ORIGIN = 0x0000, LENGTH = 0x0000
20
  infod            : ORIGIN = 0x0000, LENGTH = 0x0000
21
  ram2 (wx)        : ORIGIN = 0x0000, LENGTH = 0x0000
22
  ram_mirror (wx)  : ORIGIN = 0x0000, LENGTH = 0x0000
23
  usbram (wx)      : ORIGIN = 0x0000, LENGTH = 0x0000
24
  far_rom          : ORIGIN = 0x00000000, LENGTH = 0x00000000
25 115 olivier.gi
}
26 145 olivier.gi
REGION_ALIAS("REGION_TEXT", rom);
27
REGION_ALIAS("REGION_DATA", ram);
28
REGION_ALIAS("REGION_FAR_ROM", far_rom);
29 142 olivier.gi
__WDTCTL = 0x0120;
30 145 olivier.gi
__MPY    = 0x0130;
31
__MPYS   = 0x0132;
32
__MAC    = 0x0134;
33
__MACS   = 0x0136;
34
__OP2    = 0x0138;
35
__RESLO  = 0x013A;
36
__RESHI  = 0x013C;
37
__SUMEXT = 0x013E;
38 142 olivier.gi
 
39 115 olivier.gi
SECTIONS
40
{
41
  /* Read-only sections, merged into text segment.  */
42 145 olivier.gi
  .hash            : { *(.hash)          }
43
  .dynsym          : { *(.dynsym)        }
44
  .dynstr          : { *(.dynstr)        }
45
  .gnu.version     : { *(.gnu.version)   }
46
  .gnu.version_d   : { *(.gnu.version_d) }
47
  .gnu.version_r   : { *(.gnu.version_r) }
48
  .rel.init      : { *(.rel.init)  }
49 115 olivier.gi
  .rela.init     : { *(.rela.init) }
50 145 olivier.gi
  .rel.fini      : { *(.rel.fini)  }
51 115 olivier.gi
  .rela.fini     : { *(.rela.fini) }
52 145 olivier.gi
  .rel.text      : { *(.rel.text .rel.text.* .rel.gnu.linkonce.t.*)        }
53
  .rela.text     : { *(.rela.text .rela.text.* .rela.gnu.linkonce.t.*)     }
54
  .rel.rodata    : { *(.rel.rodata .rel.rodata.* .rel.gnu.linkonce.r.*)    }
55
  .rela.rodata   : { *(.rela.rodata .rela.rodata.* .rela.gnu.linkonce.r.*) }
56
  .rel.data      : { *(.rel.data .rel.data.* .rel.gnu.linkonce.d.*)        }
57
  .rela.data     : { *(.rela.data .rela.data.* .rela.gnu.linkonce.d.*)     }
58
  .rel.bss       : { *(.rel.bss .rel.bss.* .rel.gnu.linkonce.b.*)          }
59
  .rela.bss      : { *(.rela.bss .rela.bss.* .rela.gnu.linkonce.b.*)       }
60
  .rel.ctors     : { *(.rel.ctors)  }
61
  .rela.ctors    : { *(.rela.ctors) }
62
  .rel.dtors     : { *(.rel.dtors)  }
63
  .rela.dtors    : { *(.rela.dtors) }
64
  .rel.got       : { *(.rel.got)    }
65
  .rela.got      : { *(.rela.got)   }
66
  .rel.plt       : { *(.rel.plt)    }
67
  .rela.plt      : { *(.rela.plt)   }
68 115 olivier.gi
  .text :
69
  {
70 145 olivier.gi
     . = ALIGN(2);
71
     KEEP(*(.init .init.*))
72
     KEEP(*(.init0))  /* Start here after reset.               */
73
     KEEP(*(.init1))  /* User definable.                       */
74
     KEEP(*(.init2))  /* Initialize stack.                     */
75
     KEEP(*(.init3))  /* Initialize hardware, user definable.  */
76
     KEEP(*(.init4))  /* Copy data to .data, clear bss.        */
77
     KEEP(*(.init5))  /* User definable.                       */
78
     KEEP(*(.init6))  /* C++ constructors.                     */
79
     KEEP(*(.init7))  /* User definable.                       */
80
     KEEP(*(.init8))  /* User definable.                       */
81
     KEEP(*(.init9))  /* Call main().                          */
82
     KEEP(*(.fini9))  /* Falls into here after main(). User definable.  */
83
     KEEP(*(.fini8))  /* User definable.                           */
84
     KEEP(*(.fini7))  /* User definable.                           */
85
     KEEP(*(.fini6))  /* C++ destructors.                          */
86
     KEEP(*(.fini5))  /* User definable.                           */
87
     KEEP(*(.fini4))  /* User definable.                           */
88
     KEEP(*(.fini3))  /* User definable.                           */
89
     KEEP(*(.fini2))  /* User definable.                           */
90
     KEEP(*(.fini1))  /* User definable.                           */
91
     KEEP(*(.fini0))  /* Infinite loop after program termination.  */
92
     KEEP(*(.fini .fini.*))
93
     . = ALIGN(2);
94 115 olivier.gi
     __ctors_start = . ;
95 145 olivier.gi
     KEEP(*(.ctors))
96 115 olivier.gi
     __ctors_end = . ;
97
     __dtors_start = . ;
98 145 olivier.gi
     KEEP(*(.dtors))
99 115 olivier.gi
     __dtors_end = . ;
100 145 olivier.gi
     . = ALIGN(2);
101
    *(.text .text.* .gnu.linkonce.t.*)
102
     . = ALIGN(2);
103
  }  > REGION_TEXT
104
  .rodata   :
105 115 olivier.gi
  {
106 145 olivier.gi
     . = ALIGN(2);
107
    *(.rodata .rodata.* .gnu.linkonce.r.*)
108
     . = ALIGN(2);
109
  }  > REGION_TEXT
110
   _etext = .; /* Past last read-only (loadable) segment */
111
  .data   :
112
  {
113
     . = ALIGN(2);
114 115 olivier.gi
     PROVIDE (__data_start = .) ;
115 145 olivier.gi
    *(.data .data.* .gnu.linkonce.d.*)
116
     . = ALIGN(2);
117
     _edata = . ;  /* Past last read-write (loadable) segment */
118
  }  > REGION_DATA AT > REGION_TEXT
119
   PROVIDE (__data_load_start = LOADADDR(.data) );
120
   PROVIDE (__data_size = SIZEOF(.data) );
121
  .bss   :
122 115 olivier.gi
  {
123
     PROVIDE (__bss_start = .) ;
124 145 olivier.gi
    *(.bss .bss.*)
125 115 olivier.gi
    *(COMMON)
126 145 olivier.gi
     . = ALIGN(2);
127 115 olivier.gi
     PROVIDE (__bss_end = .) ;
128 145 olivier.gi
  }  > REGION_DATA
129
   PROVIDE (__bss_size = SIZEOF(.bss) );
130
  .noinit   :
131 115 olivier.gi
  {
132
     PROVIDE (__noinit_start = .) ;
133 145 olivier.gi
    *(.noinit .noinit.*)
134
     . = ALIGN(2);
135 115 olivier.gi
     PROVIDE (__noinit_end = .) ;
136 145 olivier.gi
  }  > REGION_DATA
137
   . = ALIGN(2);
138
   _end = . ;   /* Past last write (loadable) segment */
139
  .infomem   :
140
  {
141
    *(.infomem)
142
     . = ALIGN(2);
143
    *(.infomem.*)
144
  }  > infomem
145
  .infomemnobits   :
146
  {
147
    *(.infomemnobits)
148
     . = ALIGN(2);
149
    *(.infomemnobits.*)
150
  }  > infomem
151
  .infoa   :
152
  {
153
    *(.infoa .infoa.*)
154
  }  > infoa
155
  .infob   :
156
  {
157
    *(.infob .infob.*)
158
  }  > infob
159
  .infoc   :
160
  {
161
    *(.infoc .infoc.*)
162
  }  > infoc
163
  .infod   :
164
  {
165
    *(.infod .infod.*)
166
  }  > infod
167 115 olivier.gi
  .vectors  :
168
  {
169
     PROVIDE (__vectors_start = .) ;
170 145 olivier.gi
    KEEP(*(.vectors*))
171 115 olivier.gi
     _vectors_end = . ;
172
  }  > vectors
173 145 olivier.gi
  .fartext :
174
  {
175
     . = ALIGN(2);
176
    *(.fartext)
177
     . = ALIGN(2);
178
    *(.fartext.*)
179
     _efartext = .;
180
  }  > REGION_FAR_ROM
181
  /* Stabs for profiling information*/
182
  .profiler 0 : { *(.profiler) }
183 115 olivier.gi
  /* Stabs debugging sections.  */
184
  .stab 0 : { *(.stab) }
185
  .stabstr 0 : { *(.stabstr) }
186
  .stab.excl 0 : { *(.stab.excl) }
187
  .stab.exclstr 0 : { *(.stab.exclstr) }
188
  .stab.index 0 : { *(.stab.index) }
189
  .stab.indexstr 0 : { *(.stab.indexstr) }
190
  .comment 0 : { *(.comment) }
191
  /* DWARF debug sections.
192
     Symbols in the DWARF debugging sections are relative to the beginning
193
     of the section so we begin them at 0.  */
194
  /* DWARF 1 */
195
  .debug          0 : { *(.debug) }
196
  .line           0 : { *(.line) }
197
  /* GNU DWARF 1 extensions */
198
  .debug_srcinfo  0 : { *(.debug_srcinfo) }
199
  .debug_sfnames  0 : { *(.debug_sfnames) }
200
  /* DWARF 1.1 and DWARF 2 */
201
  .debug_aranges  0 : { *(.debug_aranges) }
202
  .debug_pubnames 0 : { *(.debug_pubnames) }
203
  /* DWARF 2 */
204
  .debug_info     0 : { *(.debug_info) *(.gnu.linkonce.wi.*) }
205
  .debug_abbrev   0 : { *(.debug_abbrev) }
206
  .debug_line     0 : { *(.debug_line) }
207
  .debug_frame    0 : { *(.debug_frame) }
208
  .debug_str      0 : { *(.debug_str) }
209
  .debug_loc      0 : { *(.debug_loc) }
210
  .debug_macinfo  0 : { *(.debug_macinfo) }
211 145 olivier.gi
  /* DWARF 3 */
212
  .debug_pubtypes 0 : { *(.debug_pubtypes) }
213
  .debug_ranges   0 : { *(.debug_ranges) }
214
   PROVIDE (__stack = ORIGIN(ram) + LENGTH(ram));
215
   PROVIDE (__data_start_rom = _etext);
216
   PROVIDE (__data_end_rom   = _etext + SIZEOF (.data));
217 115 olivier.gi
}

powered by: WebSVN 2.1.0

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