link.icf 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /***************************************************************************//**
  2. * \file HC32F4A0.icf
  3. * \version 1.0
  4. *
  5. * \brief Linker file for the IAR compiler.
  6. *
  7. ********************************************************************************
  8. * \copyright
  9. * Copyright (C) 2022-2025, Xiaohua Semiconductor Co., Ltd. All rights reserved.
  10. *
  11. * This software component is licensed by XHSC under BSD 3-Clause license
  12. * (the "License"); You may not use this file except in compliance with the
  13. * License. You may obtain a copy of the License at:
  14. * opensource.org/licenses/BSD-3-Clause
  15. *******************************************************************************/
  16. /*###ICF### Section handled by ICF editor, don't touch! *****/
  17. /*-Editor annotation file-*/
  18. /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_4.xml" */
  19. // Check that necessary symbols have been passed to linker via command line interface
  20. if((!isdefinedsymbol(_LINK_RAM_)) && (!isdefinedsymbol(_LINK_FLASH_))) {
  21. error "Link location not defined or not supported!";
  22. }
  23. if((!isdefinedsymbol(_HC32F4A0_2M_)) && (!isdefinedsymbol(_HC32F4A0_1M_SINGLE_)) && (!isdefinedsymbol(_HC32F4A0_1M_DUAL_))) {
  24. error "Mcu type or size not defined or not supported!";
  25. }
  26. /*******************************************************************************
  27. * Memory address and size definitions
  28. ******************************************************************************/
  29. define symbol ram1_base_address = 0x1FFE0000;
  30. define symbol ram1_end_address = 0x2005FFFF;
  31. if(isdefinedsymbol(_LINK_RAM_)) {
  32. define symbol ram_start_reserve = 0x20000;
  33. define symbol rom1_base_address = ram1_base_address;
  34. define symbol rom1_end_address = rom1_base_address + ram_start_reserve - 0x01;
  35. define symbol rom2_base_address = 0x0;
  36. define symbol rom2_end_address = 0x0;
  37. define symbol rom3_base_address = 0x0;
  38. define symbol rom3_end_address = 0x0;
  39. } else {
  40. define symbol ram_start_reserve = 0x0;
  41. define symbol rom1_base_address = 0x0;
  42. define symbol rom3_base_address = 0x03000000;
  43. define symbol rom3_end_address = 0x030017FF;
  44. if (isdefinedsymbol(_HC32F4A0_2M_)) {
  45. define symbol rom1_end_address = 0x001FFFFF;
  46. define symbol rom2_base_address = 0x0;
  47. define symbol rom2_end_address = 0x0;
  48. } else if (isdefinedsymbol(_HC32F4A0_1M_SINGLE_)) {
  49. define symbol rom1_end_address = 0x000FFFFF;
  50. define symbol rom2_base_address = 0x0;
  51. define symbol rom2_end_address = 0x0;
  52. } else if (isdefinedsymbol(_HC32F4A0_1M_DUAL_)) {
  53. define symbol rom1_end_address = 0x0007FFFF;
  54. define symbol rom2_base_address = 0x00100000;
  55. define symbol rom2_end_address = 0x0017FFFF;
  56. }
  57. }
  58. /*-Specials-*/
  59. define symbol __ICFEDIT_intvec_start__ = rom1_base_address;
  60. /*-Memory Regions-*/
  61. define symbol __ICFEDIT_region_IROM1_start__ = rom1_base_address;
  62. define symbol __ICFEDIT_region_IROM1_end__ = rom1_end_address;
  63. define symbol __ICFEDIT_region_IROM2_start__ = rom2_base_address;
  64. define symbol __ICFEDIT_region_IROM2_end__ = rom2_end_address;
  65. define symbol __ICFEDIT_region_IROM3_start__ = rom3_base_address;
  66. define symbol __ICFEDIT_region_IROM3_end__ = rom3_end_address;
  67. define symbol __ICFEDIT_region_EROM1_start__ = 0x0;
  68. define symbol __ICFEDIT_region_EROM1_end__ = 0x0;
  69. define symbol __ICFEDIT_region_EROM2_start__ = 0x0;
  70. define symbol __ICFEDIT_region_EROM2_end__ = 0x0;
  71. define symbol __ICFEDIT_region_EROM3_start__ = 0x0;
  72. define symbol __ICFEDIT_region_EROM3_end__ = 0x0;
  73. define symbol __ICFEDIT_region_IRAM1_start__ = ram1_base_address + ram_start_reserve;
  74. define symbol __ICFEDIT_region_IRAM1_end__ = ram1_end_address;
  75. define symbol __ICFEDIT_region_IRAM2_start__ = 0x200F0000;
  76. define symbol __ICFEDIT_region_IRAM2_end__ = 0x200F0FFF;
  77. define symbol __ICFEDIT_region_ERAM1_start__ = 0x0;
  78. define symbol __ICFEDIT_region_ERAM1_end__ = 0x0;
  79. define symbol __ICFEDIT_region_ERAM2_start__ = 0x0;
  80. define symbol __ICFEDIT_region_ERAM2_end__ = 0x0;
  81. define symbol __ICFEDIT_region_ERAM3_start__ = 0x0;
  82. define symbol __ICFEDIT_region_ERAM3_end__ = 0x0;
  83. /*-Sizes-*/
  84. define symbol __ICFEDIT_size_cstack__ = 0x800;
  85. define symbol __ICFEDIT_size_proc_stack__ = 0x0;
  86. define symbol __ICFEDIT_size_heap__ = 0x0;
  87. /**** End of ICF editor section. ###ICF###*/
  88. /*******************************************************************************
  89. * Memory definitions
  90. ******************************************************************************/
  91. define memory mem with size = 4G;
  92. define region ROM_region = mem:[from __ICFEDIT_region_IROM1_start__ to __ICFEDIT_region_IROM1_end__]
  93. | mem:[from __ICFEDIT_region_IROM2_start__ to __ICFEDIT_region_IROM2_end__];
  94. define region OTP_region = mem:[from __ICFEDIT_region_IROM3_start__ to __ICFEDIT_region_IROM3_end__];
  95. define region RAM_region = mem:[from __ICFEDIT_region_IRAM1_start__ to __ICFEDIT_region_IRAM1_end__]
  96. | mem:[from __ICFEDIT_region_IRAM2_start__ to __ICFEDIT_region_IRAM2_end__];
  97. define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
  98. define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
  99. initialize by copy { readwrite };
  100. do not initialize { section .noinit };
  101. place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
  102. place in ROM_region { readonly };
  103. place in OTP_region { readonly section .otp_data };
  104. place in RAM_region { readwrite,
  105. block CSTACK, block HEAP };