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