link.icf 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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__ = 0x00000000;
  6. /*-Memory Regions-*/
  7. define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
  8. define symbol __ICFEDIT_region_ROM_end__ = 0x0007FFFF;
  9. define symbol __ICFEDIT_region_RAM_start__ = 0x10000000;
  10. define symbol __ICFEDIT_region_RAM_end__ = 0x1000FFDF;
  11. define symbol __ICFEDIT_region_SDRAM_start__ = 0xA0000000;
  12. define symbol __ICFEDIT_region_SDRAM_end__ = 0xA3FFFFFF;
  13. define symbol _AHB_RAM_start__ = 0x20000000;
  14. define symbol _AHB_RAM_end__ = 0x20007FFF;
  15. /*-Sizes-*/
  16. define symbol __ICFEDIT_size_cstack__ = 0x1C00;
  17. define symbol __ICFEDIT_size_heap__ = 0x000;
  18. /**** End of ICF editor section. ###ICF###*/
  19. define symbol __CRP_start__ = 0x000002FC;
  20. define symbol __CRP_end__ = 0x000002FF;
  21. define memory mem with size = 4G;
  22. define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__] - mem:[from __CRP_start__ to __CRP_end__];
  23. define region CRP_region = mem:[from __CRP_start__ to __CRP_end__];
  24. define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
  25. define region SDRAM_region = mem:[from __ICFEDIT_region_SDRAM_start__ to __ICFEDIT_region_SDRAM_end__];
  26. define region AHB_RAM_region = mem:[from _AHB_RAM_start__ to _AHB_RAM_end__];
  27. define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
  28. define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
  29. initialize by copy { readwrite };
  30. do not initialize { section .noinit };
  31. do not initialize { section USB_DMA_RAM };
  32. place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
  33. place in ROM_region { readonly };
  34. place in RAM_region { readwrite,
  35. block CSTACK,
  36. block HEAP};
  37. place in AHB_RAM_region
  38. { readwrite data section AHB_RAM_MEMORY, section USB_DMA_RAM, section EMAC_DMA_RAM};
  39. place in SDRAM_region {section SDRAM,section EXFLASH_RAM};
  40. place in CRP_region { section .crp };
  41. define exported symbol SDRAM_BASE_ADDR = __ICFEDIT_region_SDRAM_start__;