MIMXRT1021xxxxx_ram.scf 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. #!armclang --target=arm-arm-none-eabi -mcpu=cortex-m7 -E -x c
  2. /*
  3. ** ###################################################################
  4. ** Processors: MIMXRT1021CAF4A
  5. ** MIMXRT1021CAG4A
  6. ** MIMXRT1021DAF5A
  7. ** MIMXRT1021DAG5A
  8. **
  9. ** Compiler: Keil ARM C/C++ Compiler
  10. ** Reference manual: IMXRT1020RM Rev.1, 12/2018 | IMXRT1020SRM Rev.3
  11. ** Version: rev. 0.1, 2017-06-06
  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. #define m_interrupts_start 0x00000000
  29. #define m_interrupts_size 0x00000400
  30. #define m_text_start 0x00000400
  31. #define m_text_size 0x0000FC00
  32. #define m_data_start 0x20000000
  33. #define m_data_size 0x00010000
  34. #define m_data2_start 0x20200000
  35. #define m_data2_size 0x00020000
  36. /* Sizes */
  37. #if (defined(__stack_size__))
  38. #define Stack_Size __stack_size__
  39. #else
  40. #define Stack_Size 0x0400
  41. #endif
  42. #if (defined(__heap_size__))
  43. #define Heap_Size __heap_size__
  44. #else
  45. #define Heap_Size 0x0400
  46. #endif
  47. LR_m_text m_interrupts_start m_text_start+m_text_size-m_interrupts_start { ; load region size_region
  48. VECTOR_ROM m_interrupts_start FIXED m_interrupts_size { ; load address = execution address
  49. * (.isr_vector,+FIRST)
  50. }
  51. ER_m_text m_text_start FIXED m_text_size { ; load address = execution address
  52. * (InRoot$$Sections)
  53. * (CodeQuickAccess)
  54. .ANY (+RO)
  55. }
  56. VECTOR_RAM m_interrupts_start EMPTY 0 {
  57. }
  58. RW_m_data m_data_start m_data_size-Stack_Size-Heap_Size { ; RW data
  59. .ANY (+RW +ZI)
  60. * (NonCacheable.init)
  61. * (*NonCacheable)
  62. * (DataQuickAccess)
  63. }
  64. ARM_LIB_HEAP +0 EMPTY Heap_Size { ; Heap region growing up
  65. }
  66. ARM_LIB_STACK m_data_start+m_data_size EMPTY -Stack_Size { ; Stack region growing down
  67. }
  68. RW_m_ncache m_data2_start EMPTY 0 {
  69. }
  70. RW_m_ncache_unused +0 EMPTY m_data2_size-ImageLength(RW_m_ncache) { ; Empty region added for MPU configuration
  71. }
  72. }