Update to new build system.
[clinton/Smoothieware.git] / mbed / src / vendor / NXP / cmsis / LPC1768 / IAR / LPC17xx.icf
CommitLineData
172d42d9
AG
1/* [ROM] */
2define symbol __intvec_start__ = 0x00000000;
3define symbol __region_ROM_start__ = 0x00000000;
4define symbol __CRP_start__ = 0x000002FC;
5define symbol __CRP_end__ = 0x000002FF;
6define symbol __region_ROM_end__ = 0x0007FFFF;
7
8/* [RAM] Vector table dynamic copy: 8_byte_aligned(49 vect * 4 bytes) = 8_byte_aligned(0xC4) = 0xC8*/
9define symbol __NVIC_start__ = 0x10000000;
10define symbol __NVIC_end__ = 0x100000C7;
11define symbol __region_RAM_start__ = 0x100000C8;
12define symbol __region_RAM_end__ = 0x1000FFDF;
13define symbol _AHB_RAM_start__ = 0x2007C000;
14define symbol _AHB_RAM_end__ = 0x20083FFF;
15
16/* Memory regions */
17define memory mem with size = 4G;
18
19define region ROM_region = mem:[from __region_ROM_start__ to __region_ROM_end__] - mem:[from __CRP_start__ to __CRP_end__];
20define region CRP_region = mem:[from __CRP_start__ to __CRP_end__];
21
22define region RAM_region = mem:[from __region_RAM_start__ to __region_RAM_end__];
23define region AHB_RAM_region = mem:[from _AHB_RAM_start__ to _AHB_RAM_end__];
24
25/* Stack and Heap */
26define symbol __size_cstack__ = 0x800;
27define symbol __size_heap__ = 0x800;
28define block CSTACK with alignment = 8, size = __size_cstack__ { };
29define block HEAP with alignment = 8, size = __size_heap__ { };
30define block STACKHEAP with fixed order { block HEAP, block CSTACK };
31
32initialize by copy with packing = zeros { readwrite };
33do not initialize { section .noinit };
34
35place at address mem:__intvec_start__ { section .intvec };
36place at address mem:0x2FC { section CRPKEY };
37place in ROM_region { readonly };
38place in RAM_region { readwrite, block STACKHEAP };
39place in AHB_RAM_region { section USB_RAM };
40place in CRP_region { section .crp };