| /*- SRAM0 memory region -*/ |
| define symbol __region_RAM0_size__ = 0x10000 ; |
| define symbol __region_RAM0_start__ = 0x20000000 ; |
| define symbol __region_RAM0_end__ = __region_RAM0_start__+__region_RAM0_size__-1 ; |
| |
| export symbol __region_RAM0_size__ ; |
| export symbol __region_RAM0_start__ ; |
| export symbol __region_RAM0_end__ ; |
| |
| /*- SRAM1 memory region -*/ |
| define symbol __region_RAM1_size__ = 0x8000 ; |
| define symbol __region_RAM1_start__ = 0x20080000 ; |
| define symbol __region_RAM1_end__ = __region_RAM1_start__+__region_RAM1_size__-1 ; |
| |
| export symbol __region_RAM1_size__ ; |
| export symbol __region_RAM1_start__ ; |
| export symbol __region_RAM1_end__ ; |
| |
| /*- Continous SRAM region (SRAM0 is mirrored) -*/ |
| define symbol __region_RAM_size__ = __region_RAM0_size__+__region_RAM1_size__ ; |
| define symbol __region_RAM_start__ = __region_RAM1_start__-__region_RAM0_size__ ; |
| define symbol __region_RAM_end__ = __region_RAM1_end__ ; |
| |
| export symbol __region_RAM_size__ ; |
| export symbol __region_RAM_start__ ; |
| export symbol __region_RAM_end__ ; |
| |
| /*- NFC SRAM region -*/ |
| define symbol __region_NFC_RAM_start__ = 0x20100000 ; |
| define symbol __region_NFC_RAM_end__ = 0x20100FFF ; |
| |
| export symbol __region_NFC_RAM_start__ ; |
| export symbol __region_NFC_RAM_end__ ; |
| |
| /*- Flash region -*/ |
| define symbol __region_ROM_size__ = 0x00080000 ; |
| define symbol __region_ROM_start__ = 0x00080000 ; |
| define symbol __region_ROM_end__ = __region_ROM_start__+__region_ROM_size__-1 ; |
| |
| export symbol __region_ROM_size__ ; |
| export symbol __region_ROM_start__ ; |
| export symbol __region_ROM_end__ ; |
| |
| /*-Vector table start*/ |
| define symbol __vector_start__ = __region_ROM_start__ ; |
| |
| /*-Sizes-*/ |
| define symbol __size_cstack__ = 0x2000 ; |
| define symbol __size_heap__ = 0x2000 ; |
| |
| define memory mem with size = 4G ; |
| define region RAM_region = mem:[from __region_RAM_start__ to __region_RAM_end__]; |
| define region ROM_region = mem:[from __region_ROM_start__ to __region_ROM_end__]; |
| |
| define block CSTACK with alignment = 8, size = __size_cstack__ { }; |
| define block HEAP with alignment = 8, size = __size_heap__ { }; |
| |
| initialize by copy { readwrite }; |
| do not initialize { section .noinit }; |
| |
| place at address mem:__vector_start__ { readonly section .intvec }; |
| place in ROM_region { readonly }; |
| place in RAM_region { readwrite, block CSTACK, block HEAP }; |