link.sct 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. #!armclang --target=arm-arm-none-eabi -mcpu=cortex-m7 -E -x c
  2. /*
  3. ** ###################################################################
  4. ** Processors: MIMXRT1062CVJ5A
  5. ** MIMXRT1062CVL5A
  6. ** MIMXRT1062DVJ6A
  7. ** MIMXRT1062DVL6A
  8. **
  9. ** Compiler: Keil ARM C/C++ Compiler
  10. ** Reference manual: IMXRT1060RM Rev.1, 12/2018 | IMXRT1060SRM Rev.3
  11. ** Version: rev. 0.1, 2017-01-10
  12. ** Build: b210709
  13. **
  14. ** Abstract:
  15. ** Linker file for the Keil ARM C/C++ Compiler
  16. **
  17. ** Copyright 2016 Freescale Semiconductor, Inc.
  18. ** Copyright 2016-2021 NXP
  19. ** All rights reserved.
  20. **
  21. ** SPDX-License-Identifier: BSD-3-Clause
  22. **
  23. ** http: www.nxp.com
  24. ** mail: support@nxp.com
  25. **
  26. ** ###################################################################
  27. */
  28. #if (defined(__ram_vector_table__))
  29. #define __ram_vector_table_size__ 0x00000400
  30. #else
  31. #define __ram_vector_table_size__ 0x00000000
  32. #endif
  33. #define m_flash_config_start 0x60000000
  34. #define m_flash_config_size 0x00001000
  35. #define m_ivt_start 0x60001000
  36. #define m_ivt_size 0x00001000
  37. #define m_interrupts_start 0x60002000
  38. #define m_interrupts_size 0x00000400
  39. #define m_text_start 0x60002400
  40. #define m_text_size 0x007FDC00
  41. #define m_qacode_start 0x00000000
  42. #define m_qacode_size 0x00020000
  43. #define m_interrupts_ram_start 0x80000000
  44. #define m_interrupts_ram_size __ram_vector_table_size__
  45. #define m_data_start (m_interrupts_ram_start + m_interrupts_ram_size)
  46. #define m_data_size (0x01E00000 - m_interrupts_ram_size)
  47. #define m_data2_start 0x20200000
  48. #define m_data2_size 0x00020000
  49. /* Sizes */
  50. #if (defined(__stack_size__))
  51. #define Stack_Size __stack_size__
  52. #else
  53. #define Stack_Size 0x0400
  54. #endif
  55. #if (defined(__heap_size__))
  56. #define Heap_Size __heap_size__
  57. #else
  58. #define Heap_Size 0x0400
  59. #endif
  60. #define RTT_HEAP_SIZE (m_data_size-ImageLength(RW_m_data)-ImageLength(ARM_LIB_HEAP)-ImageLength(ARM_LIB_STACK))
  61. #if defined(XIP_BOOT_HEADER_ENABLE) && (XIP_BOOT_HEADER_ENABLE == 1)
  62. LR_m_text m_flash_config_start m_text_start+m_text_size-m_flash_config_start { ; load region size_region
  63. RW_m_config_text m_flash_config_start FIXED m_flash_config_size { ; load address = execution address
  64. * (.boot_hdr.conf, +FIRST)
  65. }
  66. RW_m_ivt_text m_ivt_start FIXED m_ivt_size { ; load address = execution address
  67. * (.boot_hdr.ivt, +FIRST)
  68. * (.boot_hdr.boot_data)
  69. * (.boot_hdr.dcd_data)
  70. }
  71. #else
  72. LR_m_text m_interrupts_start m_text_start+m_text_size-m_interrupts_start { ; load region size_region
  73. #endif
  74. VECTOR_ROM m_interrupts_start FIXED m_interrupts_size { ; load address = execution address
  75. * (.isr_vector,+FIRST)
  76. }
  77. ER_m_text m_text_start FIXED m_text_size { ; load address = execution address
  78. * (InRoot$$Sections)
  79. .ANY (+RO)
  80. }
  81. #if (defined(__ram_vector_table__))
  82. VECTOR_RAM m_interrupts_ram_start EMPTY m_interrupts_ram_size {
  83. }
  84. #else
  85. VECTOR_RAM m_interrupts_start EMPTY 0 {
  86. }
  87. #endif
  88. RW_m_data m_data_start m_data_size-Stack_Size-Heap_Size { ; RW data
  89. .ANY (+RW +ZI)
  90. * (RamFunction)
  91. * (NonCacheable.init)
  92. * (*NonCacheable)
  93. * (DataQuickAccess)
  94. }
  95. ARM_LIB_HEAP +0 EMPTY Heap_Size{} ; Heap region growing up
  96. ARM_LIB_STACK +0 EMPTY Stack_Size{} ; Stack region growing down
  97. RTT_HEAP +0 EMPTY RTT_HEAP_SIZE{}
  98. RW_m_ram_text m_qacode_start m_qacode_size { ;
  99. * (CodeQuickAccess)
  100. }
  101. RW_m_ncache m_data2_start EMPTY 0 {
  102. }
  103. RW_m_ncache_unused +0 EMPTY m_data2_size-ImageLength(RW_m_ncache) { ; Empty region added for MPU configuration
  104. }
  105. }