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

Subversion Repositories openmsp430

[/] [openmsp430/] [trunk/] [fpga/] [xilinx_diligent_s3board/] [software/] [ta_uart/] [linker.msp430.x] - Blame information for rev 212

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 212 olivier.gi
/* Default linker script, for normal executables */
2
OUTPUT_FORMAT("elf32-msp430")
3
OUTPUT_ARCH("msp430")
4
MEMORY {
5
  sfr              : ORIGIN = 0x0000, LENGTH = 0x0010
6
  peripheral_8bit  : ORIGIN = 0x0010, LENGTH = 0x00f0
7
  peripheral_16bit : ORIGIN = 0x0100, LENGTH = 0x0100
8
  ram (wx)         : ORIGIN = 0x0200, LENGTH = 0x0400
9
  rom (rx)         : ORIGIN = 0xF000, LENGTH = 0x1000-0x20
10
  vectors          : ORIGIN = 0xffe0, LENGTH = 0x0020
11
}
12
REGION_ALIAS("REGION_TEXT", rom);
13
REGION_ALIAS("REGION_DATA", ram);
14
PROVIDE (__info_segment_size = 0x80);
15
__WDTCTL = 0x0120;
16
__MPY    = 0x0130;
17
__MPYS   = 0x0132;
18
__MAC    = 0x0134;
19
__MACS   = 0x0136;
20
__OP2    = 0x0138;
21
__RESLO  = 0x013A;
22
__RESHI  = 0x013C;
23
__SUMEXT = 0x013E;
24
CCTL0    = 0x0162;
25
CCR0     = 0x0172;
26
CCTL1    = 0x0164;
27
CCR1     = 0x0174;
28
TAR      = 0x0170;
29
P1OUT    = 0x0021;
30
 
31
SCCI     = 0x0400;
32
CCIFG    = 0x0001;
33
 
34
SECTIONS
35
{
36
  /* Read-only sections, merged into text segment.  */
37
  .hash            : { *(.hash)          }
38
  .dynsym          : { *(.dynsym)        }
39
  .dynstr          : { *(.dynstr)        }
40
  .gnu.version     : { *(.gnu.version)   }
41
  .gnu.version_d   : { *(.gnu.version_d) }
42
  .gnu.version_r   : { *(.gnu.version_r) }
43
  .rel.init      : { *(.rel.init)  }
44
  .rela.init     : { *(.rela.init) }
45
  .rel.fini      : { *(.rel.fini)  }
46
  .rela.fini     : { *(.rela.fini) }
47
  .rel.text      : { *(.rel.text .rel.text.* .rel.gnu.linkonce.t.*)        }
48
  .rela.text     : { *(.rela.text .rela.text.* .rela.gnu.linkonce.t.*)     }
49
  .rel.rodata    : { *(.rel.rodata .rel.rodata.* .rel.gnu.linkonce.r.*)    }
50
  .rela.rodata   : { *(.rela.rodata .rela.rodata.* .rela.gnu.linkonce.r.*) }
51
  .rel.data      : { *(.rel.data .rel.data.* .rel.gnu.linkonce.d.*)        }
52
  .rela.data     : { *(.rela.data .rela.data.* .rela.gnu.linkonce.d.*)     }
53
  .rel.bss       : { *(.rel.bss .rel.bss.* .rel.gnu.linkonce.b.*)          }
54
  .rela.bss      : { *(.rela.bss .rela.bss.* .rela.gnu.linkonce.b.*)       }
55
  .rel.ctors     : { *(.rel.ctors)  }
56
  .rela.ctors    : { *(.rela.ctors) }
57
  .rel.dtors     : { *(.rel.dtors)  }
58
  .rela.dtors    : { *(.rela.dtors) }
59
  .rel.got       : { *(.rel.got)    }
60
  .rela.got      : { *(.rela.got)   }
61
  .rel.plt       : { *(.rel.plt)    }
62
  .rela.plt      : { *(.rela.plt)   }
63
  /* .any.{text,rodata,data,bss}{,.*} sections are treated as orphans and
64
   * placed in output sections with available space by linker.  Do not list
65
   * them here, or the linker will not consider them orphans. */
66
  .text :
67
  {
68
     . = ALIGN(2);
69
     KEEP(*(.init .init.*))
70
     KEEP(*(.init0))  /* Start here after reset.               */
71
     KEEP(*(.init1))  /* User definable.                       */
72
     KEEP(*(.init2))  /* Initialize stack.                     */
73
     KEEP(*(.init3))  /* Initialize hardware, user definable.  */
74
     KEEP(*(.init4))  /* Copy data to .data, clear bss.        */
75
     KEEP(*(.init5))  /* User definable.                       */
76
     KEEP(*(.init6))  /* C++ constructors.                     */
77
     KEEP(*(.init7))  /* User definable.                       */
78
     KEEP(*(.init8))  /* User definable.                       */
79
     KEEP(*(.init9))  /* Call main().                          */
80
     KEEP(*(.fini9))  /* Falls into here after main(). User definable.  */
81
     KEEP(*(.fini8))  /* User definable.                           */
82
     KEEP(*(.fini7))  /* User definable.                           */
83
     KEEP(*(.fini6))  /* C++ destructors.                          */
84
     KEEP(*(.fini5))  /* User definable.                           */
85
     KEEP(*(.fini4))  /* User definable.                           */
86
     KEEP(*(.fini3))  /* User definable.                           */
87
     KEEP(*(.fini2))  /* User definable.                           */
88
     KEEP(*(.fini1))  /* User definable.                           */
89
     KEEP(*(.fini0))  /* Infinite loop after program termination.  */
90
     KEEP(*(.fini .fini.*))
91
     . = ALIGN(2);
92
     __ctors_start = .;
93
     KEEP(*(.ctors))
94
     __ctors_end = .;
95
     __dtors_start = .;
96
     KEEP(*(.dtors))
97
     __dtors_end = .;
98
     . = ALIGN(2);
99
    *(.text .text.* .gnu.linkonce.t.*)
100
    *(.near.text .near.text.*)
101
  }  > REGION_TEXT
102
  .rodata   :
103
  {
104
     . = ALIGN(2);
105
    *(.rodata .rodata.* .gnu.linkonce.r.*)
106
    *(.near.rodata .near.rodata.*)
107
  }  > REGION_TEXT
108
   . = ALIGN(2);
109
   _etext = .; /* Past last read-only (loadable) segment */
110
  .data   :
111
  {
112
     . = ALIGN(2);
113
     PROVIDE (__data_start = .) ;
114
     PROVIDE (__datastart = .) ;
115
    *(.data .data.* .gnu.linkonce.d.*)
116
    *(.near.data .near.data.*)
117
     . = ALIGN(2);
118
     _edata = .;  /* Past last read-write (loadable) segment */
119
  }  > REGION_DATA AT > REGION_TEXT
120
   __data_load_start = LOADADDR(.data);
121
   __data_size = SIZEOF(.data);
122
  .bss   :
123
  {
124
     __bss_start = .;
125
    *(.bss .bss.*)
126
    *(.near.bss .near.bss.*)
127
    *(COMMON)
128
     . = ALIGN(2);
129
     __bss_end = .;
130
  }  > REGION_DATA
131
   __bss_size = SIZEOF(.bss);
132
  .noinit   :
133
  {
134
     . = ALIGN(2);
135
     __noinit_start = .;
136
    *(.noinit .noinit.*)
137
     . = ALIGN(2);
138
     __noinit_end = .;
139
  }  > REGION_DATA
140
   . = ALIGN(2);
141
   _end = .;   /* Past last write (loadable) segment */
142
 
143
  /* Values placed in the first 32 entries of a 64-entry interrupt vector
144
   * table.  This exists because the FRAM chips place the BSL and JTAG
145
   * passwords at specific offsets that technically fall within the
146
   * interrupt table, but for which no MCU has a corresponding interrupt.
147
   * See https://sourceforge.net/tracker/?func=detail&aid=3554291&group_id=42303&atid=432701 */
148
  PROVIDE(__vte_0 = 0xffff);
149
  PROVIDE(__vte_1 = 0xffff);
150
  PROVIDE(__vte_2 = 0xffff);
151
  PROVIDE(__vte_3 = 0xffff);
152
  PROVIDE(__vte_4 = 0xffff);
153
  PROVIDE(__vte_5 = 0xffff);
154
  PROVIDE(__vte_6 = 0xffff);
155
  PROVIDE(__vte_7 = 0xffff);
156
  PROVIDE(__vte_8 = 0xffff);
157
  PROVIDE(__vte_9 = 0xffff);
158
  PROVIDE(__vte_10 = 0xffff);
159
  PROVIDE(__vte_11 = 0xffff);
160
  PROVIDE(__vte_12 = 0xffff);
161
  PROVIDE(__vte_13 = 0xffff);
162
  PROVIDE(__vte_14 = 0xffff);
163
  PROVIDE(__vte_15 = 0xffff);
164
  PROVIDE(__vte_16 = 0xffff);
165
  PROVIDE(__vte_17 = 0xffff);
166
  PROVIDE(__vte_18 = 0xffff);
167
  PROVIDE(__vte_19 = 0xffff);
168
  PROVIDE(__vte_20 = 0xffff);
169
  PROVIDE(__vte_21 = 0xffff);
170
  PROVIDE(__vte_22 = 0xffff);
171
  PROVIDE(__vte_23 = 0xffff);
172
  PROVIDE(__vte_24 = 0xffff);
173
  PROVIDE(__vte_25 = 0xffff);
174
  PROVIDE(__vte_26 = 0xffff);
175
  PROVIDE(__vte_27 = 0xffff);
176
  PROVIDE(__vte_28 = 0xffff);
177
  PROVIDE(__vte_29 = 0xffff);
178
  PROVIDE(__vte_30 = 0xffff);
179
  PROVIDE(__vte_31 = 0xffff);
180
  .vectors   :
181
  {
182
     __vectors_start = .;
183
    KEEP(*(.vectors*))
184
     _vectors_end = .;
185
  }  > vectors
186
  /* Legacy section, prefer .far.text */
187
   . = ALIGN(2);
188
   _efartext = .; /* Past last read-only (loadable) segment */
189
   . = ALIGN(2);
190
   _far_end = .;   /* Past last write (loadable) segment */
191
  /* Stabs for profiling information*/
192
  .profiler 0 : { *(.profiler) }
193
  /* Stabs debugging sections.  */
194
  .stab 0 : { *(.stab) }
195
  .stabstr 0 : { *(.stabstr) }
196
  .stab.excl 0 : { *(.stab.excl) }
197
  .stab.exclstr 0 : { *(.stab.exclstr) }
198
  .stab.index 0 : { *(.stab.index) }
199
  .stab.indexstr 0 : { *(.stab.indexstr) }
200
  .comment 0 : { *(.comment) }
201
  /* DWARF debug sections.
202
     Symbols in the DWARF debugging sections are relative to the beginning
203
     of the section so we begin them at 0.  */
204
  /* DWARF 1 */
205
  .debug          0 : { *(.debug) }
206
  .line           0 : { *(.line) }
207
  /* GNU DWARF 1 extensions */
208
  .debug_srcinfo  0 : { *(.debug_srcinfo) }
209
  .debug_sfnames  0 : { *(.debug_sfnames) }
210
  /* DWARF 1.1 and DWARF 2 */
211
  .debug_aranges  0 : { *(.debug_aranges) }
212
  .debug_pubnames 0 : { *(.debug_pubnames) }
213
  /* DWARF 2 */
214
  .debug_info     0 : { *(.debug_info) *(.gnu.linkonce.wi.*) }
215
  .debug_abbrev   0 : { *(.debug_abbrev) }
216
  .debug_line     0 : { *(.debug_line) }
217
  .debug_frame    0 : { *(.debug_frame) }
218
  .debug_str      0 : { *(.debug_str) }
219
  .debug_loc      0 : { *(.debug_loc) }
220
  .debug_macinfo  0 : { *(.debug_macinfo) }
221
  /* DWARF 3 */
222
  .debug_pubtypes 0 : { *(.debug_pubtypes) }
223
  .debug_ranges   0 : { *(.debug_ranges) }
224
  /* __stack is the only symbol that the user can override */
225
   PROVIDE (__stack = ORIGIN(ram) + LENGTH(ram));
226
   PROVIDE (__data_start_rom  = _etext) ;
227
   PROVIDE (__data_end_rom    = _etext + SIZEOF (.data)) ;
228
   PROVIDE (__romdatastart    = _etext) ;
229
   PROVIDE (__romdataend      = _etext + SIZEOF (.data)) ;
230
   PROVIDE (__romdatacopysize = SIZEOF(.data));
231
}

powered by: WebSVN 2.1.0

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