meh

Fork of mbed by mbed official

Committer:
ricardobtez
Date:
Tue Apr 05 23:51:21 2016 +0000
Revision:
118:16969dd821af
Parent:
90:cb3d968589d8
dgdgr

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Kojto 90:cb3d968589d8 1 /* Linker script for STM32F407 */
Kojto 90:cb3d968589d8 2
Kojto 90:cb3d968589d8 3 /* Linker script to configure memory regions. */
Kojto 90:cb3d968589d8 4 MEMORY
Kojto 90:cb3d968589d8 5 {
Kojto 90:cb3d968589d8 6 FLASH (rx) : ORIGIN = 0x08000000, LENGTH = 512K
Kojto 90:cb3d968589d8 7 /* CCM (rwx) : ORIGIN = 0x10000000, LENGTH = 64K */
Kojto 90:cb3d968589d8 8 RAM (rwx) : ORIGIN = 0x20000194, LENGTH = 96k - 0x194
Kojto 90:cb3d968589d8 9 }
Kojto 90:cb3d968589d8 10
Kojto 90:cb3d968589d8 11 /* Linker script to place sections and symbol values. Should be used together
Kojto 90:cb3d968589d8 12 * with other linker script that defines memory regions FLASH and RAM.
Kojto 90:cb3d968589d8 13 * It references following symbols, which must be defined in code:
Kojto 90:cb3d968589d8 14 * Reset_Handler : Entry of reset handler
Kojto 90:cb3d968589d8 15 *
Kojto 90:cb3d968589d8 16 * It defines following symbols, which code can use without definition:
Kojto 90:cb3d968589d8 17 * __exidx_start
Kojto 90:cb3d968589d8 18 * __exidx_end
Kojto 90:cb3d968589d8 19 * __etext
Kojto 90:cb3d968589d8 20 * __data_start__
Kojto 90:cb3d968589d8 21 * __preinit_array_start
Kojto 90:cb3d968589d8 22 * __preinit_array_end
Kojto 90:cb3d968589d8 23 * __init_array_start
Kojto 90:cb3d968589d8 24 * __init_array_end
Kojto 90:cb3d968589d8 25 * __fini_array_start
Kojto 90:cb3d968589d8 26 * __fini_array_end
Kojto 90:cb3d968589d8 27 * __data_end__
Kojto 90:cb3d968589d8 28 * __bss_start__
Kojto 90:cb3d968589d8 29 * __bss_end__
Kojto 90:cb3d968589d8 30 * __end__
Kojto 90:cb3d968589d8 31 * end
Kojto 90:cb3d968589d8 32 * __HeapLimit
Kojto 90:cb3d968589d8 33 * __StackLimit
Kojto 90:cb3d968589d8 34 * __StackTop
Kojto 90:cb3d968589d8 35 * __stack
Kojto 90:cb3d968589d8 36 */
Kojto 90:cb3d968589d8 37 ENTRY(Reset_Handler)
Kojto 90:cb3d968589d8 38
Kojto 90:cb3d968589d8 39 SECTIONS
Kojto 90:cb3d968589d8 40 {
Kojto 90:cb3d968589d8 41 .text :
Kojto 90:cb3d968589d8 42 {
Kojto 90:cb3d968589d8 43 KEEP(*(.isr_vector))
Kojto 90:cb3d968589d8 44 *(.text*)
Kojto 90:cb3d968589d8 45
Kojto 90:cb3d968589d8 46 KEEP(*(.init))
Kojto 90:cb3d968589d8 47 KEEP(*(.fini))
Kojto 90:cb3d968589d8 48
Kojto 90:cb3d968589d8 49 /* .ctors */
Kojto 90:cb3d968589d8 50 *crtbegin.o(.ctors)
Kojto 90:cb3d968589d8 51 *crtbegin?.o(.ctors)
Kojto 90:cb3d968589d8 52 *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
Kojto 90:cb3d968589d8 53 *(SORT(.ctors.*))
Kojto 90:cb3d968589d8 54 *(.ctors)
Kojto 90:cb3d968589d8 55
Kojto 90:cb3d968589d8 56 /* .dtors */
Kojto 90:cb3d968589d8 57 *crtbegin.o(.dtors)
Kojto 90:cb3d968589d8 58 *crtbegin?.o(.dtors)
Kojto 90:cb3d968589d8 59 *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
Kojto 90:cb3d968589d8 60 *(SORT(.dtors.*))
Kojto 90:cb3d968589d8 61 *(.dtors)
Kojto 90:cb3d968589d8 62
Kojto 90:cb3d968589d8 63 *(.rodata*)
Kojto 90:cb3d968589d8 64
Kojto 90:cb3d968589d8 65 KEEP(*(.eh_frame*))
Kojto 90:cb3d968589d8 66 } > FLASH
Kojto 90:cb3d968589d8 67
Kojto 90:cb3d968589d8 68 .ARM.extab :
Kojto 90:cb3d968589d8 69 {
Kojto 90:cb3d968589d8 70 *(.ARM.extab* .gnu.linkonce.armextab.*)
Kojto 90:cb3d968589d8 71 } > FLASH
Kojto 90:cb3d968589d8 72
Kojto 90:cb3d968589d8 73 __exidx_start = .;
Kojto 90:cb3d968589d8 74 .ARM.exidx :
Kojto 90:cb3d968589d8 75 {
Kojto 90:cb3d968589d8 76 *(.ARM.exidx* .gnu.linkonce.armexidx.*)
Kojto 90:cb3d968589d8 77 } > FLASH
Kojto 90:cb3d968589d8 78 __exidx_end = .;
Kojto 90:cb3d968589d8 79
Kojto 90:cb3d968589d8 80 __etext = .;
Kojto 90:cb3d968589d8 81
Kojto 90:cb3d968589d8 82 .data : AT (__etext)
Kojto 90:cb3d968589d8 83 {
Kojto 90:cb3d968589d8 84 __data_start__ = .;
Kojto 90:cb3d968589d8 85 *(vtable)
Kojto 90:cb3d968589d8 86 *(.data*)
Kojto 90:cb3d968589d8 87
Kojto 90:cb3d968589d8 88 . = ALIGN(4);
Kojto 90:cb3d968589d8 89 /* preinit data */
Kojto 90:cb3d968589d8 90 PROVIDE_HIDDEN (__preinit_array_start = .);
Kojto 90:cb3d968589d8 91 KEEP(*(.preinit_array))
Kojto 90:cb3d968589d8 92 PROVIDE_HIDDEN (__preinit_array_end = .);
Kojto 90:cb3d968589d8 93
Kojto 90:cb3d968589d8 94 . = ALIGN(4);
Kojto 90:cb3d968589d8 95 /* init data */
Kojto 90:cb3d968589d8 96 PROVIDE_HIDDEN (__init_array_start = .);
Kojto 90:cb3d968589d8 97 KEEP(*(SORT(.init_array.*)))
Kojto 90:cb3d968589d8 98 KEEP(*(.init_array))
Kojto 90:cb3d968589d8 99 PROVIDE_HIDDEN (__init_array_end = .);
Kojto 90:cb3d968589d8 100
Kojto 90:cb3d968589d8 101
Kojto 90:cb3d968589d8 102 . = ALIGN(4);
Kojto 90:cb3d968589d8 103 /* finit data */
Kojto 90:cb3d968589d8 104 PROVIDE_HIDDEN (__fini_array_start = .);
Kojto 90:cb3d968589d8 105 KEEP(*(SORT(.fini_array.*)))
Kojto 90:cb3d968589d8 106 KEEP(*(.fini_array))
Kojto 90:cb3d968589d8 107 PROVIDE_HIDDEN (__fini_array_end = .);
Kojto 90:cb3d968589d8 108
Kojto 90:cb3d968589d8 109 KEEP(*(.jcr*))
Kojto 90:cb3d968589d8 110 . = ALIGN(4);
Kojto 90:cb3d968589d8 111 /* All data end */
Kojto 90:cb3d968589d8 112 __data_end__ = .;
Kojto 90:cb3d968589d8 113
Kojto 90:cb3d968589d8 114 } > RAM
Kojto 90:cb3d968589d8 115
Kojto 90:cb3d968589d8 116 .bss :
Kojto 90:cb3d968589d8 117 {
Kojto 90:cb3d968589d8 118 . = ALIGN(4);
Kojto 90:cb3d968589d8 119 __bss_start__ = .;
Kojto 90:cb3d968589d8 120 *(.bss*)
Kojto 90:cb3d968589d8 121 *(COMMON)
Kojto 90:cb3d968589d8 122 . = ALIGN(4);
Kojto 90:cb3d968589d8 123 __bss_end__ = .;
Kojto 90:cb3d968589d8 124 } > RAM
Kojto 90:cb3d968589d8 125
Kojto 90:cb3d968589d8 126 .heap (COPY):
Kojto 90:cb3d968589d8 127 {
Kojto 90:cb3d968589d8 128 __end__ = .;
Kojto 90:cb3d968589d8 129 end = __end__;
Kojto 90:cb3d968589d8 130 *(.heap*)
Kojto 90:cb3d968589d8 131 __HeapLimit = .;
Kojto 90:cb3d968589d8 132 } > RAM
Kojto 90:cb3d968589d8 133
Kojto 90:cb3d968589d8 134 /* .stack_dummy section doesn't contains any symbols. It is only
Kojto 90:cb3d968589d8 135 * used for linker to calculate size of stack sections, and assign
Kojto 90:cb3d968589d8 136 * values to stack symbols later */
Kojto 90:cb3d968589d8 137 .stack_dummy (COPY):
Kojto 90:cb3d968589d8 138 {
Kojto 90:cb3d968589d8 139 *(.stack*)
Kojto 90:cb3d968589d8 140 } > RAM
Kojto 90:cb3d968589d8 141
Kojto 90:cb3d968589d8 142 /* Set stack top to end of RAM, and stack limit move down by
Kojto 90:cb3d968589d8 143 * size of stack_dummy section */
Kojto 90:cb3d968589d8 144 __StackTop = ORIGIN(RAM) + LENGTH(RAM);
Kojto 90:cb3d968589d8 145 __StackLimit = __StackTop - SIZEOF(.stack_dummy);
Kojto 90:cb3d968589d8 146 PROVIDE(__stack = __StackTop);
Kojto 90:cb3d968589d8 147
Kojto 90:cb3d968589d8 148 /* Check if data + heap + stack exceeds RAM limit */
Kojto 90:cb3d968589d8 149 ASSERT(__StackLimit >= __HeapLimit, "region RAM overflowed with stack")
Kojto 90:cb3d968589d8 150 }
Kojto 90:cb3d968589d8 151