1*cf2f2c56Smiod#!/bin/sh
2*cf2f2c56Smiod
3*cf2f2c56SmiodHEAP_SECTION_MSP430=" "
4*cf2f2c56SmiodHEAP_MEMORY_MSP430=" "
5*cf2f2c56Smiod
6*cf2f2c56Smiodif test ${GOT_HEAP_MSP-0} -ne 0
7*cf2f2c56Smiodthen
8*cf2f2c56SmiodHEAP_SECTION_MSP430=".heap ${RELOCATING-0} :
9*cf2f2c56Smiod  {
10*cf2f2c56Smiod    ${RELOCATING+ PROVIDE (__heap_data_start = .) ; }
11*cf2f2c56Smiod    *(.heap*)
12*cf2f2c56Smiod    ${RELOCATING+ PROVIDE (_heap_data_end = .) ; }
13*cf2f2c56Smiod    ${RELOCATING+. = ALIGN(2);}
14*cf2f2c56Smiod    ${RELOCATING+ PROVIDE (__heap_bottom = .) ; }
15*cf2f2c56Smiod    ${RELOCATING+ PROVIDE (__heap_top = ${HEAP_START} + ${HEAP_LENGTH}) ; }
16*cf2f2c56Smiod  } ${RELOCATING+ > heap}"
17*cf2f2c56SmiodHEAP_MEMORY_MSP430="heap(rwx) 		: ORIGIN = $HEAP_START,	LENGTH = $HEAP_LENGTH"
18*cf2f2c56Smiodfi
19*cf2f2c56Smiod
20*cf2f2c56Smiod
21d2201f2fSdrahncat <<EOF
22d2201f2fSdrahnOUTPUT_FORMAT("${OUTPUT_FORMAT}","${OUTPUT_FORMAT}","${OUTPUT_FORMAT}")
23d2201f2fSdrahnOUTPUT_ARCH(${ARCH})
24d2201f2fSdrahn
25d2201f2fSdrahnMEMORY
26d2201f2fSdrahn{
27d2201f2fSdrahn  text   (rx)   	: ORIGIN = $ROM_START,  LENGTH = $ROM_SIZE
28d2201f2fSdrahn  data   (rwx)  	: ORIGIN = $RAM_START, 	LENGTH = $RAM_SIZE
29d2201f2fSdrahn  vectors (rw)  	: ORIGIN = 0xffe0,      LENGTH = 0x20
30d2201f2fSdrahn  bootloader(rx)	: ORIGIN = 0x0c00,	LENGTH = 1K
31d2201f2fSdrahn  infomem(rx)		: ORIGIN = 0x1000,	LENGTH = 256
32d2201f2fSdrahn  infomemnobits(rx)	: ORIGIN = 0x1000,      LENGTH = 256
33*cf2f2c56Smiod  ${HEAP_MEMORY_MSP430}
34d2201f2fSdrahn}
35d2201f2fSdrahn
36d2201f2fSdrahnSECTIONS
37d2201f2fSdrahn{
38d2201f2fSdrahn  /* Read-only sections, merged into text segment.  */
39d2201f2fSdrahn  ${TEXT_DYNAMIC+${DYNAMIC}}
40d2201f2fSdrahn  .hash        ${RELOCATING-0} : { *(.hash)             }
41d2201f2fSdrahn  .dynsym      ${RELOCATING-0} : { *(.dynsym)           }
42d2201f2fSdrahn  .dynstr      ${RELOCATING-0} : { *(.dynstr)           }
43d2201f2fSdrahn  .gnu.version ${RELOCATING-0} : { *(.gnu.version)      }
44d2201f2fSdrahn  .gnu.version_d ${RELOCATING-0} : { *(.gnu.version_d)  }
45d2201f2fSdrahn  .gnu.version_r ${RELOCATING-0} : { *(.gnu.version_r)  }
46d2201f2fSdrahn
47d2201f2fSdrahn  .rel.init    ${RELOCATING-0} : { *(.rel.init) }
48d2201f2fSdrahn  .rela.init   ${RELOCATING-0} : { *(.rela.init) }
49d2201f2fSdrahn  .rel.text    ${RELOCATING-0} :
50d2201f2fSdrahn    {
51d2201f2fSdrahn      *(.rel.text)
52d2201f2fSdrahn      ${RELOCATING+*(.rel.text.*)}
53d2201f2fSdrahn      ${RELOCATING+*(.rel.gnu.linkonce.t*)}
54d2201f2fSdrahn    }
55d2201f2fSdrahn  .rela.text   ${RELOCATING-0} :
56d2201f2fSdrahn    {
57d2201f2fSdrahn      *(.rela.text)
58d2201f2fSdrahn      ${RELOCATING+*(.rela.text.*)}
59d2201f2fSdrahn      ${RELOCATING+*(.rela.gnu.linkonce.t*)}
60d2201f2fSdrahn    }
61d2201f2fSdrahn  .rel.fini    ${RELOCATING-0} : { *(.rel.fini) }
62d2201f2fSdrahn  .rela.fini   ${RELOCATING-0} : { *(.rela.fini) }
63d2201f2fSdrahn  .rel.rodata  ${RELOCATING-0} :
64d2201f2fSdrahn    {
65d2201f2fSdrahn      *(.rel.rodata)
66d2201f2fSdrahn      ${RELOCATING+*(.rel.rodata.*)}
67d2201f2fSdrahn      ${RELOCATING+*(.rel.gnu.linkonce.r*)}
68d2201f2fSdrahn    }
69d2201f2fSdrahn  .rela.rodata ${RELOCATING-0} :
70d2201f2fSdrahn    {
71d2201f2fSdrahn      *(.rela.rodata)
72d2201f2fSdrahn      ${RELOCATING+*(.rela.rodata.*)}
73d2201f2fSdrahn      ${RELOCATING+*(.rela.gnu.linkonce.r*)}
74d2201f2fSdrahn    }
75d2201f2fSdrahn  .rel.data    ${RELOCATING-0} :
76d2201f2fSdrahn    {
77d2201f2fSdrahn      *(.rel.data)
78d2201f2fSdrahn      ${RELOCATING+*(.rel.data.*)}
79d2201f2fSdrahn      ${RELOCATING+*(.rel.gnu.linkonce.d*)}
80d2201f2fSdrahn    }
81d2201f2fSdrahn  .rela.data   ${RELOCATING-0} :
82d2201f2fSdrahn    {
83d2201f2fSdrahn      *(.rela.data)
84d2201f2fSdrahn      ${RELOCATING+*(.rela.data.*)}
85d2201f2fSdrahn      ${RELOCATING+*(.rela.gnu.linkonce.d*)}
86d2201f2fSdrahn    }
87d2201f2fSdrahn  .rel.ctors   ${RELOCATING-0} : { *(.rel.ctors)        }
88d2201f2fSdrahn  .rela.ctors  ${RELOCATING-0} : { *(.rela.ctors)       }
89d2201f2fSdrahn  .rel.dtors   ${RELOCATING-0} : { *(.rel.dtors)        }
90d2201f2fSdrahn  .rela.dtors  ${RELOCATING-0} : { *(.rela.dtors)       }
91d2201f2fSdrahn  .rel.got     ${RELOCATING-0} : { *(.rel.got)          }
92d2201f2fSdrahn  .rela.got    ${RELOCATING-0} : { *(.rela.got)         }
93d2201f2fSdrahn  .rel.bss     ${RELOCATING-0} : { *(.rel.bss)          }
94d2201f2fSdrahn  .rela.bss    ${RELOCATING-0} : { *(.rela.bss)         }
95d2201f2fSdrahn  .rel.plt     ${RELOCATING-0} : { *(.rel.plt)          }
96d2201f2fSdrahn  .rela.plt    ${RELOCATING-0} : { *(.rela.plt)         }
97d2201f2fSdrahn
98d2201f2fSdrahn  /* Internal text space.  */
99d2201f2fSdrahn  .text :
100d2201f2fSdrahn  {
101d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
102d2201f2fSdrahn    *(.init)
103d2201f2fSdrahn    *(.init0)  /* Start here after reset.  */
104d2201f2fSdrahn    *(.init1)
105d2201f2fSdrahn    *(.init2)  /* Copy data loop  */
106d2201f2fSdrahn    *(.init3)
107d2201f2fSdrahn    *(.init4)  /* Clear bss  */
108d2201f2fSdrahn    *(.init5)
109d2201f2fSdrahn    *(.init6)  /* C++ constructors.  */
110d2201f2fSdrahn    *(.init7)
111d2201f2fSdrahn    *(.init8)
112d2201f2fSdrahn    *(.init9)  /* Call main().  */
113d2201f2fSdrahn
114d2201f2fSdrahn    ${CONSTRUCTING+ __ctors_start = . ; }
115d2201f2fSdrahn    ${CONSTRUCTING+ *(.ctors) }
116d2201f2fSdrahn    ${CONSTRUCTING+ __ctors_end = . ; }
117d2201f2fSdrahn    ${CONSTRUCTING+ __dtors_start = . ; }
118d2201f2fSdrahn    ${CONSTRUCTING+ *(.dtors) }
119d2201f2fSdrahn    ${CONSTRUCTING+ __dtors_end = . ; }
120d2201f2fSdrahn
121d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
122d2201f2fSdrahn    *(.text)
123d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
124d2201f2fSdrahn    *(.text.*)
125d2201f2fSdrahn
126d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
127d2201f2fSdrahn    *(.fini9)  /*   */
128d2201f2fSdrahn    *(.fini8)
129d2201f2fSdrahn    *(.fini7)
130d2201f2fSdrahn    *(.fini6)  /* C++ destructors.  */
131d2201f2fSdrahn    *(.fini5)
132d2201f2fSdrahn    *(.fini4)
133d2201f2fSdrahn    *(.fini3)
134d2201f2fSdrahn    *(.fini2)
135d2201f2fSdrahn    *(.fini1)
136d2201f2fSdrahn    *(.fini0)  /* Infinite loop after program termination.  */
137d2201f2fSdrahn    *(.fini)
138d2201f2fSdrahn
139*cf2f2c56Smiod    _etext = .;
140d2201f2fSdrahn  } ${RELOCATING+ > text}
141d2201f2fSdrahn
142d2201f2fSdrahn  .data ${RELOCATING-0} : ${RELOCATING+AT (ADDR (.text) + SIZEOF (.text))}
143d2201f2fSdrahn  {  
144d2201f2fSdrahn    ${RELOCATING+ PROVIDE (__data_start = .) ; }
145d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
146d2201f2fSdrahn    *(.data)
147d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
148d2201f2fSdrahn    *(.gnu.linkonce.d*)
149d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
150d2201f2fSdrahn    ${RELOCATING+ _edata = . ; }
151d2201f2fSdrahn  } ${RELOCATING+ > data}
152d2201f2fSdrahn  
153d2201f2fSdrahn  /* Bootloader.  */
154d2201f2fSdrahn  .bootloader ${RELOCATING-0} :
155d2201f2fSdrahn  {
156d2201f2fSdrahn    ${RELOCATING+ PROVIDE (__boot_start = .) ; }
157d2201f2fSdrahn    *(.bootloader)
158d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
159d2201f2fSdrahn    *(.bootloader.*)
160d2201f2fSdrahn  } ${RELOCATING+ > bootloader}
161d2201f2fSdrahn  
162d2201f2fSdrahn  /* Information memory.  */
163d2201f2fSdrahn  .infomem ${RELOCATING-0} :
164d2201f2fSdrahn  {
165d2201f2fSdrahn    *(.infomem)
166d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
167d2201f2fSdrahn    *(.infomem.*)
168d2201f2fSdrahn  } ${RELOCATING+ > infomem}
169d2201f2fSdrahn
170d2201f2fSdrahn  /* Information memory (not loaded into MPU).  */
171d2201f2fSdrahn  .infomemnobits ${RELOCATING-0} :
172d2201f2fSdrahn  {
173d2201f2fSdrahn    *(.infomemnobits)
174d2201f2fSdrahn    ${RELOCATING+. = ALIGN(2);}
175d2201f2fSdrahn    *(.infomemnobits.*)
176d2201f2fSdrahn  } ${RELOCATING+ > infomemnobits}
177d2201f2fSdrahn
178d2201f2fSdrahn  .bss ${RELOCATING+ SIZEOF(.data) + ADDR(.data)} :
179d2201f2fSdrahn  {
180d2201f2fSdrahn    ${RELOCATING+ PROVIDE (__bss_start = .) ; }
181d2201f2fSdrahn    *(.bss)
182d2201f2fSdrahn    *(COMMON)
183d2201f2fSdrahn    ${RELOCATING+ PROVIDE (__bss_end = .) ; }
184d2201f2fSdrahn    ${RELOCATING+ _end = . ;  }
185d2201f2fSdrahn  } ${RELOCATING+ > data}
186d2201f2fSdrahn
187d2201f2fSdrahn  .noinit ${RELOCATING+ SIZEOF(.bss) + ADDR(.bss)} :
188d2201f2fSdrahn  {
189d2201f2fSdrahn    ${RELOCATING+ PROVIDE (__noinit_start = .) ; }
190d2201f2fSdrahn    *(.noinit)
191d2201f2fSdrahn    *(COMMON)
192d2201f2fSdrahn    ${RELOCATING+ PROVIDE (__noinit_end = .) ; }
193d2201f2fSdrahn    ${RELOCATING+ _end = . ;  }
194d2201f2fSdrahn  } ${RELOCATING+ > data}
195d2201f2fSdrahn
196d2201f2fSdrahn  .vectors ${RELOCATING-0}:
197d2201f2fSdrahn  {
198d2201f2fSdrahn    ${RELOCATING+ PROVIDE (__vectors_start = .) ; }
199d2201f2fSdrahn    *(.vectors*)
200d2201f2fSdrahn    ${RELOCATING+ _vectors_end = . ; }
201d2201f2fSdrahn  } ${RELOCATING+ > vectors}
202d2201f2fSdrahn
203*cf2f2c56Smiod  ${HEAP_SECTION_MSP430}
204d2201f2fSdrahn
205d2201f2fSdrahn  /* Stabs debugging sections.  */
206d2201f2fSdrahn  .stab 0 : { *(.stab) } 
207d2201f2fSdrahn  .stabstr 0 : { *(.stabstr) }
208d2201f2fSdrahn  .stab.excl 0 : { *(.stab.excl) }
209d2201f2fSdrahn  .stab.exclstr 0 : { *(.stab.exclstr) }
210d2201f2fSdrahn  .stab.index 0 : { *(.stab.index) }
211d2201f2fSdrahn  .stab.indexstr 0 : { *(.stab.indexstr) }
212d2201f2fSdrahn  .comment 0 : { *(.comment) }
213d2201f2fSdrahn 
214d2201f2fSdrahn  /* DWARF debug sections.
215d2201f2fSdrahn     Symbols in the DWARF debugging sections are relative to the beginning
216d2201f2fSdrahn     of the section so we begin them at 0.  */
217d2201f2fSdrahn
218d2201f2fSdrahn  /* DWARF 1 */
219d2201f2fSdrahn  .debug          0 : { *(.debug) }
220d2201f2fSdrahn  .line           0 : { *(.line) }
221d2201f2fSdrahn
222d2201f2fSdrahn  /* GNU DWARF 1 extensions */
223d2201f2fSdrahn  .debug_srcinfo  0 : { *(.debug_srcinfo) }
224d2201f2fSdrahn  .debug_sfnames  0 : { *(.debug_sfnames) }
225d2201f2fSdrahn
226d2201f2fSdrahn  /* DWARF 1.1 and DWARF 2 */
227d2201f2fSdrahn  .debug_aranges  0 : { *(.debug_aranges) }
228d2201f2fSdrahn  .debug_pubnames 0 : { *(.debug_pubnames) }
229d2201f2fSdrahn
230d2201f2fSdrahn  /* DWARF 2 */
231d2201f2fSdrahn  .debug_info     0 : { *(.debug_info) *(.gnu.linkonce.wi.*) }
232d2201f2fSdrahn  .debug_abbrev   0 : { *(.debug_abbrev) }
233d2201f2fSdrahn  .debug_line     0 : { *(.debug_line) }
234d2201f2fSdrahn  .debug_frame    0 : { *(.debug_frame) }
235d2201f2fSdrahn  .debug_str      0 : { *(.debug_str) }
236d2201f2fSdrahn  .debug_loc      0 : { *(.debug_loc) }
237d2201f2fSdrahn  .debug_macinfo  0 : { *(.debug_macinfo) }
238d2201f2fSdrahn
239d2201f2fSdrahn  PROVIDE (__stack = ${STACK}) ;
240d2201f2fSdrahn  PROVIDE (__data_start_rom = _etext) ;
241d2201f2fSdrahn  PROVIDE (__data_end_rom   = _etext + SIZEOF (.data)) ;
242d2201f2fSdrahn  PROVIDE (__noinit_start_rom = _etext + SIZEOF (.data)) ;
243d2201f2fSdrahn  PROVIDE (__noinit_end_rom = _etext + SIZEOF (.data) + SIZEOF (.noinit)) ;
244*cf2f2c56Smiod  PROVIDE (__subdevice_has_heap = ${GOT_HEAP_MSP-0}) ;
245d2201f2fSdrahn}
246d2201f2fSdrahnEOF
247