link.icf 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*###ICF### Section handled by ICF editor, don't touch! ****/
  2. /*-Editor annotation file-*/
  3. /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_4.xml" */
  4. /*-Specials-*/
  5. define symbol __ICFEDIT_intvec_start__ = 0x00000000;
  6. /*-Memory Regions-*/
  7. define symbol __ICFEDIT_region_IROM1_start__ = 0x00000000;
  8. define symbol __ICFEDIT_region_IROM1_end__ = 0x000FFFFF;
  9. define symbol __ICFEDIT_region_IROM2_start__ = 0x0;
  10. define symbol __ICFEDIT_region_IROM2_end__ = 0x0;
  11. define symbol __ICFEDIT_region_EROM1_start__ = 0x0;
  12. define symbol __ICFEDIT_region_EROM1_end__ = 0x0;
  13. define symbol __ICFEDIT_region_EROM2_start__ = 0x0;
  14. define symbol __ICFEDIT_region_EROM2_end__ = 0x0;
  15. define symbol __ICFEDIT_region_EROM3_start__ = 0x0;
  16. define symbol __ICFEDIT_region_EROM3_end__ = 0x0;
  17. define symbol __ICFEDIT_region_IRAM1_start__ = 0x20000000;
  18. define symbol __ICFEDIT_region_IRAM1_end__ = 0x2003FFFF;
  19. define symbol __ICFEDIT_region_IRAM2_start__ = 0x0;
  20. define symbol __ICFEDIT_region_IRAM2_end__ = 0x0;
  21. define symbol __ICFEDIT_region_ERAM1_start__ = 0x0;
  22. define symbol __ICFEDIT_region_ERAM1_end__ = 0x0;
  23. define symbol __ICFEDIT_region_ERAM2_start__ = 0x0;
  24. define symbol __ICFEDIT_region_ERAM2_end__ = 0x0;
  25. define symbol __ICFEDIT_region_ERAM3_start__ = 0x0;
  26. define symbol __ICFEDIT_region_ERAM3_end__ = 0x0;
  27. /*-Sizes-*/
  28. define symbol __ICFEDIT_size_proc_stack__ = 0x0000;
  29. define symbol __ICFEDIT_size_cstack__ = 0x1000;
  30. define symbol __ICFEDIT_size_heap__ = 0x2000;
  31. /**** End of ICF editor section. ###ICF###*/
  32. define memory mem with size = 4G;
  33. define region IROM_region = mem:[from __ICFEDIT_region_IROM1_start__ to __ICFEDIT_region_IROM1_end__];
  34. define region EROM_region = mem:[from __ICFEDIT_region_EROM1_start__ to __ICFEDIT_region_EROM1_end__]
  35. | mem:[from __ICFEDIT_region_EROM2_start__ to __ICFEDIT_region_EROM2_end__]
  36. | mem:[from __ICFEDIT_region_EROM3_start__ to __ICFEDIT_region_EROM3_end__];
  37. define region IRAM_region = mem:[from __ICFEDIT_region_IRAM1_start__ to __ICFEDIT_region_IRAM1_end__]
  38. | mem:[from __ICFEDIT_region_IRAM2_start__ to __ICFEDIT_region_IRAM2_end__];
  39. define region ERAM_region = mem:[from __ICFEDIT_region_ERAM1_start__ to __ICFEDIT_region_ERAM1_end__]
  40. | mem:[from __ICFEDIT_region_ERAM2_start__ to __ICFEDIT_region_ERAM2_end__]
  41. | mem:[from __ICFEDIT_region_ERAM3_start__ to __ICFEDIT_region_ERAM3_end__];
  42. define block PROC_STACK with alignment = 8, size = __ICFEDIT_size_proc_stack__ { };
  43. define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
  44. define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
  45. initialize by copy { readwrite };
  46. do not initialize { section .noinit };
  47. place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
  48. place in IROM_region { readonly };
  49. place in EROM_region { readonly section application_specific_ro };
  50. place in IRAM_region { readwrite, block CSTACK, block PROC_STACK, block HEAP };
  51. place in ERAM_region { readwrite section application_specific_rw };