fastboot.icf 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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__ = 0x0100000;
  6. /*-Memory Regions-*/
  7. define symbol __ICFEDIT_region_ROM_start__ = 0x0100000;
  8. define symbol __ICFEDIT_region_ROM_end__ = 0x0101FFF;
  9. define symbol __ICFEDIT_region_RAM_start__ = 0x0104000;
  10. define symbol __ICFEDIT_region_RAM_end__ = 0x0107FFF;
  11. define symbol __ICFEDIT_region_RELOCATE_start__ = 0x00108000;
  12. define symbol __ICFEDIT_region_RELOCATE_end__ = 0x0010ffff;
  13. /*-Sizes-*/
  14. define symbol __ICFEDIT_size_cstack__ = 0x1000;
  15. define symbol __ICFEDIT_size_heap__ = 0;
  16. /**** End of ICF editor section. ###ICF###*/
  17. /* Flash Organization
  18. * 1. Privileged Code:
  19. * Start : 0x100000
  20. * End : 0x1001FF
  21. * Size : 512 bytes
  22. * 2. Unprivileged Code:
  23. * Start : 0x100200
  24. * End : 0x101FFF
  25. * Size : 7680 bytes
  26. */
  27. define symbol __reigon_ROM_privileged_start__ = __ICFEDIT_region_ROM_start__;
  28. define symbol __reigon_ROM_privileged_end__ = 0x10001F;
  29. define symbol __reigon_ROM_unprivileged_start__ = 0x100020;
  30. define symbol __reigon_ROM_unprivileged_end__ = __ICFEDIT_region_ROM_end__;
  31. /* RAM Organization
  32. * 1. Privileged Data:
  33. * Start : 0x102000
  34. * End : 0x1021FF
  35. * Size : 512 bytes
  36. * 2. Unprivileged Data:
  37. * Start : 0x102200
  38. * End : 0x103FFF
  39. * Size : 7680 bytes
  40. */
  41. define symbol __region_RAM_privileged_start__ = __ICFEDIT_region_RAM_start__;
  42. define symbol __region_RAM_privileged_end__ = 0x1067FF;
  43. define symbol __region_RAM_unprivileged_start__ = 0x106800;
  44. define symbol __region_RAM_unprivileged_end__ = __ICFEDIT_region_RAM_end__;
  45. /* Memory regions. */
  46. define memory mem with size = 4G;
  47. define region ROM_region_privileged = mem:[from __reigon_ROM_privileged_start__ to __reigon_ROM_privileged_end__];
  48. define region ROM_region_unprivileged = mem:[from __reigon_ROM_unprivileged_start__ to __reigon_ROM_unprivileged_end__];
  49. define region RAM_region_privileged = mem:[from __region_RAM_privileged_start__ to __region_RAM_privileged_end__];
  50. define region RAM_region_unprivileged = mem:[from __region_RAM_unprivileged_start__ to __region_RAM_unprivileged_end__];
  51. define region RELOCATE_region = mem:[from __ICFEDIT_region_RELOCATE_start__ to __ICFEDIT_region_RELOCATE_end__];
  52. /* Stack and Heap. */
  53. define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
  54. define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
  55. /* Initialization. */
  56. initialize by copy { readwrite, section realocate_functions };
  57. do not initialize { section .noinit };
  58. do not initialize { section privileged_data };
  59. /* Exported symbols. */
  60. define exported symbol __FLASH_segment_start__ = __ICFEDIT_region_ROM_start__;
  61. define exported symbol __FLASH_segment_end__ = __ICFEDIT_region_ROM_end__;
  62. define exported symbol __IRAM_segment_start__ = __ICFEDIT_region_RAM_start__;
  63. define exported symbol __IRAM_segment_end__ = __ICFEDIT_region_RAM_end__;
  64. define exported symbol __privileged_functions_start__ = __reigon_ROM_privileged_start__;
  65. define exported symbol __privileged_functions_end__ = __reigon_ROM_privileged_end__;
  66. define exported symbol __privileged_data_start__ = __region_RAM_privileged_start__;
  67. define exported symbol __privileged_data_end__ = __region_RAM_privileged_end__;
  68. /* Placements. */
  69. place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
  70. place in ROM_region_privileged { readonly section privileged_functions };
  71. place in ROM_region_unprivileged { readonly };
  72. place in RAM_region_privileged { readwrite section privileged_data };
  73. place in RAM_region_unprivileged { readwrite,
  74. block CSTACK, block HEAP };
  75. place in RELOCATE_region { readwrite section realocate_functions };