The official mbed C/C SDK provides the software platform and libraries to build your applications.

Fork of mbed by mbed official

Committer:
Kojto
Date:
Wed Apr 29 10:16:23 2015 +0100
Revision:
98:8ab26030e058
Release 98 of the mbed library

Changes:
- Silabs new targets (Giant, Zero, Happy, Leopard, Wonder Geckos)
- Asynchronous SPI, I2C, Serial
- LowPower classes
- Nordic - nordic SDK v8.0 update
- Teensy - gcc arm fix for startup
- Nucleo F411 - usb freq fix

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Kojto 98:8ab26030e058 1 /* Linker script for Silicon Labs EFM32HG devices */
Kojto 98:8ab26030e058 2 /* */
Kojto 98:8ab26030e058 3 /* This file is subject to the license terms as defined in ARM's */
Kojto 98:8ab26030e058 4 /* CMSIS END USER LICENSE AGREEMENT.pdf, governing the use of */
Kojto 98:8ab26030e058 5 /* Example Code. */
Kojto 98:8ab26030e058 6 /* */
Kojto 98:8ab26030e058 7 /* Silicon Laboratories, Inc. 2015 */
Kojto 98:8ab26030e058 8 /* */
Kojto 98:8ab26030e058 9 /* Version 3.20.12 */
Kojto 98:8ab26030e058 10 /* */
Kojto 98:8ab26030e058 11 MEMORY
Kojto 98:8ab26030e058 12 {
Kojto 98:8ab26030e058 13 FLASH (rx) : ORIGIN = 0x00000000, LENGTH = 65536
Kojto 98:8ab26030e058 14 RAM (rwx) : ORIGIN = 0x20000000, LENGTH = 8192
Kojto 98:8ab26030e058 15 }
Kojto 98:8ab26030e058 16
Kojto 98:8ab26030e058 17 /* MBED: mbed needs to be able to dynamically set the interrupt vector table.
Kojto 98:8ab26030e058 18 * We make room for the table at the very beginning of RAM, i.e. at
Kojto 98:8ab26030e058 19 * 0x20000000. We need (16+20) * sizeof(uint32_t) = 144 bytes for EFM32HG */
Kojto 98:8ab26030e058 20 __vector_size = 0x90;
Kojto 98:8ab26030e058 21
Kojto 98:8ab26030e058 22 /* Linker script to place sections and symbol values. Should be used together
Kojto 98:8ab26030e058 23 * with other linker script that defines memory regions FLASH and RAM.
Kojto 98:8ab26030e058 24 * It references following symbols, which must be defined in code:
Kojto 98:8ab26030e058 25 * Reset_Handler : Entry of reset handler
Kojto 98:8ab26030e058 26 *
Kojto 98:8ab26030e058 27 * It defines following symbols, which code can use without definition:
Kojto 98:8ab26030e058 28 * __exidx_start
Kojto 98:8ab26030e058 29 * __exidx_end
Kojto 98:8ab26030e058 30 * __etext
Kojto 98:8ab26030e058 31 * __data_start__
Kojto 98:8ab26030e058 32 * __preinit_array_start
Kojto 98:8ab26030e058 33 * __preinit_array_end
Kojto 98:8ab26030e058 34 * __init_array_start
Kojto 98:8ab26030e058 35 * __init_array_end
Kojto 98:8ab26030e058 36 * __fini_array_start
Kojto 98:8ab26030e058 37 * __fini_array_end
Kojto 98:8ab26030e058 38 * __data_end__
Kojto 98:8ab26030e058 39 * __bss_start__
Kojto 98:8ab26030e058 40 * __bss_end__
Kojto 98:8ab26030e058 41 * __end__
Kojto 98:8ab26030e058 42 * end
Kojto 98:8ab26030e058 43 * __HeapLimit
Kojto 98:8ab26030e058 44 * __StackLimit
Kojto 98:8ab26030e058 45 * __StackTop
Kojto 98:8ab26030e058 46 * __stack
Kojto 98:8ab26030e058 47 */
Kojto 98:8ab26030e058 48 ENTRY(Reset_Handler)
Kojto 98:8ab26030e058 49
Kojto 98:8ab26030e058 50 SECTIONS
Kojto 98:8ab26030e058 51 {
Kojto 98:8ab26030e058 52 .text :
Kojto 98:8ab26030e058 53 {
Kojto 98:8ab26030e058 54 KEEP(*(.isr_vector))
Kojto 98:8ab26030e058 55 *(.text*)
Kojto 98:8ab26030e058 56
Kojto 98:8ab26030e058 57 KEEP(*(.init))
Kojto 98:8ab26030e058 58 KEEP(*(.fini))
Kojto 98:8ab26030e058 59
Kojto 98:8ab26030e058 60 /* .ctors */
Kojto 98:8ab26030e058 61 *crtbegin.o(.ctors)
Kojto 98:8ab26030e058 62 *crtbegin?.o(.ctors)
Kojto 98:8ab26030e058 63 *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
Kojto 98:8ab26030e058 64 *(SORT(.ctors.*))
Kojto 98:8ab26030e058 65 *(.ctors)
Kojto 98:8ab26030e058 66
Kojto 98:8ab26030e058 67 /* .dtors */
Kojto 98:8ab26030e058 68 *crtbegin.o(.dtors)
Kojto 98:8ab26030e058 69 *crtbegin?.o(.dtors)
Kojto 98:8ab26030e058 70 *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
Kojto 98:8ab26030e058 71 *(SORT(.dtors.*))
Kojto 98:8ab26030e058 72 *(.dtors)
Kojto 98:8ab26030e058 73
Kojto 98:8ab26030e058 74 *(.rodata*)
Kojto 98:8ab26030e058 75
Kojto 98:8ab26030e058 76 KEEP(*(.eh_frame*))
Kojto 98:8ab26030e058 77 } > FLASH
Kojto 98:8ab26030e058 78
Kojto 98:8ab26030e058 79 .ARM.extab :
Kojto 98:8ab26030e058 80 {
Kojto 98:8ab26030e058 81 *(.ARM.extab* .gnu.linkonce.armextab.*)
Kojto 98:8ab26030e058 82 } > FLASH
Kojto 98:8ab26030e058 83
Kojto 98:8ab26030e058 84 __exidx_start = .;
Kojto 98:8ab26030e058 85 .ARM.exidx :
Kojto 98:8ab26030e058 86 {
Kojto 98:8ab26030e058 87 *(.ARM.exidx* .gnu.linkonce.armexidx.*)
Kojto 98:8ab26030e058 88 } > FLASH
Kojto 98:8ab26030e058 89 __exidx_end = .;
Kojto 98:8ab26030e058 90
Kojto 98:8ab26030e058 91 __etext = .;
Kojto 98:8ab26030e058 92
Kojto 98:8ab26030e058 93 .data : AT (__etext)
Kojto 98:8ab26030e058 94 {
Kojto 98:8ab26030e058 95 __data_start__ = .;
Kojto 98:8ab26030e058 96 *("dma")
Kojto 98:8ab26030e058 97 PROVIDE( __start_vector_table__ = .);
Kojto 98:8ab26030e058 98 . += __vector_size;
Kojto 98:8ab26030e058 99 PROVIDE( __end_vector_table__ = .);
Kojto 98:8ab26030e058 100 *(vtable)
Kojto 98:8ab26030e058 101 *(.data*)
Kojto 98:8ab26030e058 102 . = ALIGN (4);
Kojto 98:8ab26030e058 103 *(.ram)
Kojto 98:8ab26030e058 104
Kojto 98:8ab26030e058 105 . = ALIGN(4);
Kojto 98:8ab26030e058 106 /* preinit data */
Kojto 98:8ab26030e058 107 PROVIDE_HIDDEN (__preinit_array_start = .);
Kojto 98:8ab26030e058 108 KEEP(*(.preinit_array))
Kojto 98:8ab26030e058 109 PROVIDE_HIDDEN (__preinit_array_end = .);
Kojto 98:8ab26030e058 110
Kojto 98:8ab26030e058 111 . = ALIGN(4);
Kojto 98:8ab26030e058 112 /* init data */
Kojto 98:8ab26030e058 113 PROVIDE_HIDDEN (__init_array_start = .);
Kojto 98:8ab26030e058 114 KEEP(*(SORT(.init_array.*)))
Kojto 98:8ab26030e058 115 KEEP(*(.init_array))
Kojto 98:8ab26030e058 116 PROVIDE_HIDDEN (__init_array_end = .);
Kojto 98:8ab26030e058 117
Kojto 98:8ab26030e058 118 . = ALIGN(4);
Kojto 98:8ab26030e058 119 /* finit data */
Kojto 98:8ab26030e058 120 PROVIDE_HIDDEN (__fini_array_start = .);
Kojto 98:8ab26030e058 121 KEEP(*(SORT(.fini_array.*)))
Kojto 98:8ab26030e058 122 KEEP(*(.fini_array))
Kojto 98:8ab26030e058 123 PROVIDE_HIDDEN (__fini_array_end = .);
Kojto 98:8ab26030e058 124
Kojto 98:8ab26030e058 125 . = ALIGN(4);
Kojto 98:8ab26030e058 126 /* All data end */
Kojto 98:8ab26030e058 127 __data_end__ = .;
Kojto 98:8ab26030e058 128
Kojto 98:8ab26030e058 129 } > RAM
Kojto 98:8ab26030e058 130
Kojto 98:8ab26030e058 131 .bss :
Kojto 98:8ab26030e058 132 {
Kojto 98:8ab26030e058 133 __bss_start__ = .;
Kojto 98:8ab26030e058 134 *(.bss*)
Kojto 98:8ab26030e058 135 *(COMMON)
Kojto 98:8ab26030e058 136 __bss_end__ = .;
Kojto 98:8ab26030e058 137 } > RAM
Kojto 98:8ab26030e058 138
Kojto 98:8ab26030e058 139 .heap :
Kojto 98:8ab26030e058 140 {
Kojto 98:8ab26030e058 141 __end__ = .;
Kojto 98:8ab26030e058 142 end = __end__;
Kojto 98:8ab26030e058 143 _end = __end__;
Kojto 98:8ab26030e058 144 *(.heap*)
Kojto 98:8ab26030e058 145 __HeapLimit = .;
Kojto 98:8ab26030e058 146 } > RAM
Kojto 98:8ab26030e058 147
Kojto 98:8ab26030e058 148 /* .stack_dummy section doesn't contains any symbols. It is only
Kojto 98:8ab26030e058 149 * used for linker to calculate size of stack sections, and assign
Kojto 98:8ab26030e058 150 * values to stack symbols later */
Kojto 98:8ab26030e058 151 .stack_dummy :
Kojto 98:8ab26030e058 152 {
Kojto 98:8ab26030e058 153 *(.stack)
Kojto 98:8ab26030e058 154 } > RAM
Kojto 98:8ab26030e058 155
Kojto 98:8ab26030e058 156 /* Set stack top to end of RAM, and stack limit move down by
Kojto 98:8ab26030e058 157 * size of stack_dummy section */
Kojto 98:8ab26030e058 158 __StackTop = ORIGIN(RAM) + LENGTH(RAM);
Kojto 98:8ab26030e058 159 __StackLimit = __StackTop - SIZEOF(.stack_dummy);
Kojto 98:8ab26030e058 160 PROVIDE(__stack = __StackTop);
Kojto 98:8ab26030e058 161
Kojto 98:8ab26030e058 162 /* Check if data + heap + stack exceeds RAM limit */
Kojto 98:8ab26030e058 163 ASSERT(__StackLimit >= __HeapLimit, "region RAM overflowed with stack")
Kojto 98:8ab26030e058 164
Kojto 98:8ab26030e058 165 /* Check if FLASH usage exceeds FLASH size */
Kojto 98:8ab26030e058 166 ASSERT( LENGTH(FLASH) >= (__etext + SIZEOF(.data)), "FLASH memory overflowed !")
Kojto 98:8ab26030e058 167 }