ch.icf 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. /*###ICF### Section handled by ICF editor, don't touch! ****/
  2. /*-Editor annotation file-*/
  3. /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
  4. /*-Specials-*/
  5. define symbol __ICFEDIT_intvec_start__ = 0x08000000;
  6. /*-Memory Regions-*/
  7. define symbol __ICFEDIT_region_ROM_start__ = 0x08000000;
  8. define symbol __ICFEDIT_region_ROM_end__ = 0x0801FFFF;
  9. define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
  10. define symbol __ICFEDIT_region_RAM_end__ = 0x2001FFFF;
  11. /*-Sizes-*/
  12. define symbol __ICFEDIT_size_cstack__ = 0x400;
  13. define symbol __ICFEDIT_size_heap__ = 0x400;
  14. /**** End of ICF editor section. ###ICF###*/
  15. /* Size of the IRQ Stack (Main Stack).*/
  16. define symbol __ICFEDIT_size_irqstack__ = 0x400;
  17. define memory mem with size = 4G;
  18. define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
  19. define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
  20. define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ {section CSTACK};
  21. define block IRQSTACK with alignment = 8, size = __ICFEDIT_size_irqstack__ {};
  22. define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ {};
  23. define block SYSHEAP with alignment = 8 {section SYSHEAP};
  24. define block DATABSS with alignment = 8 {readwrite, zeroinit};
  25. initialize by copy { readwrite };
  26. do not initialize { section .noinit };
  27. keep { section .intvec };
  28. place at address mem:__ICFEDIT_intvec_start__ {section .intvec};
  29. place in ROM_region {readonly};
  30. place at start of RAM_region {block IRQSTACK};
  31. place in RAM_region {block DATABSS, block HEAP};
  32. place in RAM_region {block SYSHEAP};
  33. place at end of RAM_region {block CSTACK};