/*###ICF### Section handled by ICF editor, don't touch! ****/ /*-Editor annotation file-*/ /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ /*-Specials-*/ define symbol __ICFEDIT_intvec_start__ = 0x08000000; /*-Memory Regions-*/ define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; define symbol __ICFEDIT_region_ROM_end__ = 0x0803FFFF; define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; define symbol __ICFEDIT_region_RAM_end__ = 0x20009FFF; /*-Sizes-*/ define symbol __ICFEDIT_size_cstack__ = 0x400; /* Size of the process stack */ define symbol __ICFEDIT_size_heap__ = 0x100; /* Used to mark heap (heap + sysheap) maximum size limit */ /**** End of ICF editor section. ###ICF###*/ /* Size of the IRQ Stack (Main Stack).*/ define symbol __ICFEDIT_size_irqstack__ = 0x400; define memory mem with size = 4G; define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; define block IRQSTACK with alignment = 8, size = __ICFEDIT_size_irqstack__, fixed order { }; define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__, fixed order {section CSTACK}; define block DATABSS with alignment = 8, fixed order {readwrite, zeroinit}; define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__, fixed order {section HEAP}; define block SYSHEAP with alignment = 8 {section SYSHEAP}; initialize by copy {readwrite}; do not initialize {section .noinit}; keep { section .intvec }; place at address mem:__ICFEDIT_intvec_start__ {readonly section .intvec}; place in ROM_region {readonly}; place at start of RAM_region {block IRQSTACK}; /* Main stack which becomes IRQ stack */ place in RAM_region {block CSTACK}; /* Process stack */ place in RAM_region {block DATABSS}; /* Textdata region */ place in RAM_region {block HEAP}; /* Sys Heap size limit marker */ place at end of RAM_region {block SYSHEAP}; /* Sys Heap available for allocations */ /* Define stack and memory addresses for kernel usage */ define exported symbol __main_stack_base__ = __ICFEDIT_region_RAM_start__; define exported symbol __main_stack_end__ = __main_stack_base__ + __ICFEDIT_size_irqstack__; /* Note: End refers to empty stack */ define exported symbol __process_stack_base__ = __main_stack_end__; define exported symbol __main_thread_stack_base__ = __process_stack_base__; /* Note: Main thread uses process stack */ define exported symbol __process_stack_end__ = __process_stack_base__ + __ICFEDIT_size_cstack__;