1 #!armclang --target=arm-arm-none-eabi -mcpu=cortex-m7 -E -x c
3 ** ###################################################################
4 ** Processors: MIMXRT1064CVJ5A
9 ** Compiler: Keil ARM C/C++ Compiler
10 ** Reference manual: IMXRT1064RM Rev.0.1, 12/2018 | IMXRT1064SRM Rev.3
11 ** Version: rev. 0.1, 2018-06-22
15 ** Linker file for the Keil ARM C/C++ Compiler
17 ** Copyright 2016 Freescale Semiconductor, Inc.
18 ** Copyright 2016-2021 NXP
19 ** All rights reserved.
21 ** SPDX-License-Identifier: BSD-3-Clause
24 ** mail: support@nxp.com
26 ** ###################################################################
29 /* Modified by Keil */
31 #if (defined(__ram_vector_table__))
32 #define __ram_vector_table_size__ 0x00000400
34 #define __ram_vector_table_size__ 0x00000000
37 #define m_flash_config_start 0x70000000
38 #define m_flash_config_size 0x00001000
40 #define m_ivt_start 0x70001000
41 #define m_ivt_size 0x00001000
43 #define m_interrupts_start 0x70002000
44 #define m_interrupts_size 0x00000400
46 #define m_text_start 0x70002400
47 #define m_text_size 0x003FDC00
49 #define m_qacode_start 0x00000000
50 #define m_qacode_size 0x00020000
52 #define m_interrupts_ram_start 0x80000000
53 #define m_interrupts_ram_size __ram_vector_table_size__
55 #define m_data_start (m_interrupts_ram_start + m_interrupts_ram_size)
56 #define m_data_size (0x01E00000 - m_interrupts_ram_size)
58 #define m_ncache_start 0x81E00000
59 #define m_ncache_size 0x00200000
61 #define m_data_noinit_size 0x00000500
63 #define m_data2_start 0x20000000
64 #define m_data2_size 0x00020000
66 #define m_data3_start 0x20200000
67 #define m_data3_size 0x000C0000
70 #if (defined(__stack_size__))
71 #define Stack_Size __stack_size__
73 #define Stack_Size 0x0400
76 #if (defined(__heap_size__))
77 #define Heap_Size __heap_size__
79 #define Heap_Size 0x10000
82 #if defined(XIP_BOOT_HEADER_ENABLE) && (XIP_BOOT_HEADER_ENABLE == 1)
83 LR_m_text m_flash_config_start m_text_start+m_text_size-m_flash_config_start { ; load region size_region
84 RW_m_config_text m_flash_config_start FIXED m_flash_config_size { ; load address = execution address
85 * (.boot_hdr.conf, +FIRST)
88 RW_m_ivt_text m_ivt_start FIXED m_ivt_size { ; load address = execution address
89 * (.boot_hdr.ivt, +FIRST)
90 * (.boot_hdr.boot_data)
91 * (.boot_hdr.dcd_data)
94 LR_m_text m_interrupts_start m_text_start+m_text_size-m_interrupts_start { ; load region size_region
96 VECTOR_ROM m_interrupts_start FIXED m_interrupts_size { ; load address = execution address
97 * (.isr_vector,+FIRST)
99 ER_m_text m_text_start FIXED m_text_size { ; load address = execution address
103 #if (defined(__ram_vector_table__))
104 VECTOR_RAM m_interrupts_ram_start EMPTY m_interrupts_ram_size {
107 VECTOR_RAM m_interrupts_start EMPTY 0 {
110 RW_m_data2 m_data2_start m_data2_size {
115 RW_m_data3 m_data3_start m_data3_size {
118 #if (defined(__heap_noncacheable__))
119 RW_m_data m_data_start m_data_size-Stack_Size { ; RW data
121 RW_m_data m_data_start m_data_size-Stack_Size-Heap_Size-m_ncache_size-m_data_noinit_size { ; RW data
124 * (*m_usb_dma_init_data)
125 * (*m_usb_dma_noninit_data)
127 RW_NOINIT +0 UNINIT { ; RW uninitialized data
130 #if (!defined(__heap_noncacheable__))
131 ARM_LIB_HEAP +0 EMPTY Heap_Size { ; Heap region growing up
134 ARM_LIB_STACK m_data_start+m_data_size EMPTY -Stack_Size { ; Stack region growing down
136 RW_m_ram_text m_qacode_start m_qacode_size { ;
140 #if (defined(__heap_noncacheable__))
141 RW_m_ncache m_ncache_start m_ncache_size - Heap_Size { ; ncache RW data
143 RW_m_ncache m_ncache_start m_ncache_size { ; ncache RW data
145 * (NonCacheable.init)
148 #if (defined(__heap_noncacheable__))
149 ARM_LIB_HEAP +0 EMPTY Heap_Size { ; Heap region growing up
151 RW_m_ncache_unused +0 EMPTY m_ncache_size-ImageLength(RW_m_ncache)-Heap_Size { ; Empty region added for MPU configuration
153 RW_m_ncache_unused +0 EMPTY m_ncache_size-ImageLength(RW_m_ncache) { ; Empty region added for MPU configuration