Rev 58 | Rev 65 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
| Rev 58 | Rev 61 | ||
|---|---|---|---|
| Line 1... | Line 1... | ||
| 1 | /* |
1 | /* |
| 2 | ***************************************************************************** |
2 | ****************************************************************************** |
| 3 | ** |
3 | ** |
| 4 | 4 | ||
| 5 | ** File : stm32_flash.ld |
5 | ** File : LinkerScript.ld |
| - | 6 | ** |
|
| - | 7 | ** Author : STM32CubeMX |
|
| 6 | ** |
8 | ** |
| 7 | ** Abstract : Linker script for STM32L152RE Device with |
9 | ** Abstract : Linker script for STM32L152RETx series |
| 8 | ** 512KByte FLASH, 80KByte RAM |
10 | ** 512Kbytes FLASH and 80Kbytes RAM |
| 9 | ** |
11 | ** |
| 10 | ** Set heap size, stack size and stack location according |
12 | ** Set heap size, stack size and stack location according |
| 11 | ** to application requirements. |
13 | ** to application requirements. |
| 12 | ** |
14 | ** |
| 13 | ** Set memory bank area and size if external memory is used. |
15 | ** Set memory bank area and size if external memory is used. |
| 14 | ** |
16 | ** |
| 15 | ** Target : STMicroelectronics STM32 |
17 | ** Target : STMicroelectronics STM32 |
| 16 | ** |
18 | ** |
| 17 | ** Environment : Atollic TrueSTUDIO(R) |
- | |
| 18 | ** |
- | |
| 19 | ** Distribution: The file is distributed as is, without any warranty |
19 | ** Distribution: The file is distributed “as is,” without any warranty |
| 20 | ** of any kind. |
20 | ** of any kind. |
| 21 | ** |
21 | ** |
| - | 22 | ***************************************************************************** |
|
| 22 | ** (c)Copyright Atollic AB. |
23 | ** @attention |
| - | 24 | ** |
|
| - | 25 | ** <h2><center>© COPYRIGHT(c) 2019 STMicroelectronics</center></h2> |
|
| - | 26 | ** |
|
| - | 27 | ** Redistribution and use in source and binary forms, with or without modification, |
|
| - | 28 | ** are permitted provided that the following conditions are met: |
|
| - | 29 | ** 1. Redistributions of source code must retain the above copyright notice, |
|
| 23 | ** You may use this file as-is or modify it according to the needs of your |
30 | ** this list of conditions and the following disclaimer. |
| 24 | ** project. This file may only be built (assembled or compiled and linked) |
31 | ** 2. Redistributions in binary form must reproduce the above copyright notice, |
| - | 32 | ** this list of conditions and the following disclaimer in the documentation |
|
| - | 33 | ** and/or other materials provided with the distribution. |
|
| - | 34 | ** 3. Neither the name of STMicroelectronics nor the names of its contributors |
|
| 25 | ** using the Atollic TrueSTUDIO(R) product. The use of this file together |
35 | ** may be used to endorse or promote products derived from this software |
| 26 | ** with other tools than Atollic TrueSTUDIO(R) is not permitted. |
36 | ** without specific prior written permission. |
| - | 37 | ** |
|
| - | 38 | ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
|
| - | 39 | ** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
|
| - | 40 | ** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
|
| - | 41 | ** DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE |
|
| - | 42 | ** FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
|
| - | 43 | ** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
|
| - | 44 | ** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER |
|
| - | 45 | ** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
|
| - | 46 | ** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
|
| - | 47 | ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|
| 27 | ** |
48 | ** |
| 28 | ***************************************************************************** |
49 | ***************************************************************************** |
| 29 | */ |
50 | */ |
| 30 | 51 | ||
| 31 | /* Entry Point */ |
52 | /* Entry Point */ |
| 32 | ENTRY(Reset_Handler) |
53 | ENTRY(Reset_Handler) |
| 33 | 54 | ||
| 34 | /* Highest address of the user mode stack */ |
55 | /* Highest address of the user mode stack */ |
| 35 | _estack = 0x20014000; /* end of RAM */ |
56 | _estack = ORIGIN(RAM) + LENGTH(RAM); /* end of RAM */ |
| 36 | /* Generate a link error if heap and stack don't fit into RAM */ |
57 | /* Generate a link error if heap and stack don't fit into RAM */ |
| 37 | _Min_Heap_Size = 0x200; /* required amount of heap */ |
58 | _Min_Heap_Size = 0x200; /* required amount of heap */ |
| 38 | _Min_Stack_Size = 0x400; /* required amount of stack */ |
59 | _Min_Stack_Size = 0x400; /* required amount of stack */ |
| 39 | 60 | ||
| 40 | /* Specify the memory areas */ |
61 | /* Specify the memory areas */ |
| 41 | MEMORY |
62 | MEMORY |
| 42 | { |
63 | { |
| 43 | FLASH (rx) : ORIGIN = 0x8000000, LENGTH = 512K |
- | |
| 44 | RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 80K |
64 | RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 80K |
| 45 | NVRAM (rx) : ORIGIN = 0x08080000, LENGTH = 4K |
65 | FLASH (rx) : ORIGIN = 0x8000000, LENGTH = 512K |
| 46 | } |
66 | } |
| 47 | 67 | ||
| 48 | /* Define output sections */ |
68 | /* Define output sections */ |
| 49 | SECTIONS |
69 | SECTIONS |
| 50 | { |
70 | { |
| Line 143... | Line 163... | ||
| 143 | } >RAM |
163 | } >RAM |
| 144 | 164 | ||
| 145 | /* User_heap_stack section, used to check that there is enough RAM left */ |
165 | /* User_heap_stack section, used to check that there is enough RAM left */ |
| 146 | ._user_heap_stack : |
166 | ._user_heap_stack : |
| 147 | { |
167 | { |
| 148 | . = ALIGN(4); |
168 | . = ALIGN(8); |
| 149 | PROVIDE ( end = . ); |
169 | PROVIDE ( end = . ); |
| 150 | PROVIDE ( _end = . ); |
170 | PROVIDE ( _end = . ); |
| 151 | . = . + _Min_Heap_Size; |
171 | . = . + _Min_Heap_Size; |
| 152 | . = . + _Min_Stack_Size; |
172 | . = . + _Min_Stack_Size; |
| 153 | . = ALIGN(4); |
173 | . = ALIGN(8); |
| 154 | } >RAM |
174 | } >RAM |
| 155 | 175 | ||
| 156 | 176 | ||
| 157 | 177 | ||
| 158 | /* Remove information from the standard libraries */ |
178 | /* Remove information from the standard libraries */ |
| Line 161... | Line 181... | ||
| 161 | libc.a ( * ) |
181 | libc.a ( * ) |
| 162 | libm.a ( * ) |
182 | libm.a ( * ) |
| 163 | libgcc.a ( * ) |
183 | libgcc.a ( * ) |
| 164 | } |
184 | } |
| 165 | 185 | ||
| 166 | - | ||
| 167 | /* NVRAM image section : nothing gets stored here but the addresses are set up */ |
- | |
| 168 | .nvram_data (NOLOAD) : |
- | |
| 169 | { |
- | |
| 170 | _nvr_base = .; |
- | |
| 171 | KEEP ( *(.NVRAM_Data)) /* any __attribute__((section(".NVRAM_Data"))) section info to be put in here */ |
- | |
| 172 | } >NVRAM |
- | |
| 173 | - | ||
| 174 | - | ||
| 175 | - | ||
| 176 | PROVIDE ( NVRAM_Base = _nvr_base ); |
- | |
| 177 | - | ||
| 178 | - | ||
| 179 | .ARM.attributes 0 : { *(.ARM.attributes) } |
186 | .ARM.attributes 0 : { *(.ARM.attributes) } |
| 180 | } |
187 | } |
| 181 | 188 | ||
| 182 | 189 | ||