111 lines
3.5 KiB
Plaintext
111 lines
3.5 KiB
Plaintext
|
#!armclang --target=arm-arm-none-eabi -mcpu=cortex-m7 -E -x c
|
||
|
/*
|
||
|
** ###################################################################
|
||
|
** Processors: MIMXRT1021CAF4A
|
||
|
** MIMXRT1021CAG4A
|
||
|
** MIMXRT1021DAF5A
|
||
|
** MIMXRT1021DAG5A
|
||
|
**
|
||
|
** Compiler: Keil ARM C/C++ Compiler
|
||
|
** Reference manual: IMXRT1020RM Rev.1, 12/2018 | IMXRT1020SRM Rev.3
|
||
|
** Version: rev. 0.1, 2017-06-06
|
||
|
** Build: b210709
|
||
|
**
|
||
|
** Abstract:
|
||
|
** Linker file for the Keil ARM C/C++ Compiler
|
||
|
**
|
||
|
** Copyright 2016 Freescale Semiconductor, Inc.
|
||
|
** Copyright 2016-2021 NXP
|
||
|
** All rights reserved.
|
||
|
**
|
||
|
** SPDX-License-Identifier: BSD-3-Clause
|
||
|
**
|
||
|
** http: www.nxp.com
|
||
|
** mail: support@nxp.com
|
||
|
**
|
||
|
** ###################################################################
|
||
|
*/
|
||
|
|
||
|
#define m_interrupts_start 0x80000000
|
||
|
#define m_interrupts_size 0x00000400
|
||
|
|
||
|
#define m_text_start 0x80000400
|
||
|
#define m_text_size 0x001FFC00
|
||
|
|
||
|
#define m_qacode_start 0x00000000
|
||
|
#define m_qacode_size 0x00010000
|
||
|
|
||
|
#define m_data_start 0x20200000
|
||
|
#define m_data_size 0x00020000
|
||
|
|
||
|
#define m_data2_start 0x20000000
|
||
|
#define m_data2_size 0x00010000
|
||
|
|
||
|
#define m_data3_start 0x80200000
|
||
|
#define m_data3_size 0x01C00000
|
||
|
|
||
|
#define m_ncache_start 0x81E00000
|
||
|
#define m_ncache_size 0x00200000
|
||
|
|
||
|
/* Sizes */
|
||
|
#if (defined(__stack_size__))
|
||
|
#define Stack_Size __stack_size__
|
||
|
#else
|
||
|
#define Stack_Size 0x0400
|
||
|
#endif
|
||
|
|
||
|
#if (defined(__heap_size__))
|
||
|
#define Heap_Size __heap_size__
|
||
|
#else
|
||
|
#define Heap_Size 0x0400
|
||
|
#endif
|
||
|
|
||
|
LR_m_text m_interrupts_start m_text_start+m_text_size-m_interrupts_start { ; load region size_region
|
||
|
VECTOR_ROM m_interrupts_start FIXED m_interrupts_size { ; load address = execution address
|
||
|
* (.isr_vector,+FIRST)
|
||
|
}
|
||
|
ER_m_text m_text_start FIXED m_text_size { ; load address = execution address
|
||
|
* (InRoot$$Sections)
|
||
|
.ANY (+RO)
|
||
|
}
|
||
|
VECTOR_RAM m_interrupts_start EMPTY 0 {
|
||
|
}
|
||
|
#if (defined(__heap_noncacheable__))
|
||
|
RW_m_data m_data_start m_data_size-Stack_Size { ; RW data
|
||
|
#else
|
||
|
RW_m_data m_data_start m_data_size-Stack_Size-Heap_Size { ; RW data
|
||
|
#endif
|
||
|
.ANY (+RW +ZI)
|
||
|
* (*m_usb_dma_init_data)
|
||
|
* (*m_usb_dma_noninit_data)
|
||
|
}
|
||
|
#if (!defined(__heap_noncacheable__))
|
||
|
ARM_LIB_HEAP +0 EMPTY Heap_Size { ; Heap region growing up
|
||
|
}
|
||
|
#endif
|
||
|
ARM_LIB_STACK m_data_start+m_data_size EMPTY -Stack_Size { ; Stack region growing down
|
||
|
}
|
||
|
RW_m_ram_text m_qacode_start m_qacode_size { ;
|
||
|
* (CodeQuickAccess)
|
||
|
}
|
||
|
RW_m_data2 m_data2_start m_data2_size { ;
|
||
|
* (DataQuickAccess)
|
||
|
}
|
||
|
#if (defined(__heap_noncacheable__))
|
||
|
RW_m_ncache m_ncache_start m_ncache_size - Heap_Size { ; ncache RW data
|
||
|
#else
|
||
|
RW_m_ncache m_ncache_start m_ncache_size { ; ncache RW data
|
||
|
#endif
|
||
|
* (NonCacheable.init)
|
||
|
* (*NonCacheable)
|
||
|
}
|
||
|
#if (defined(__heap_noncacheable__))
|
||
|
ARM_LIB_HEAP +0 EMPTY Heap_Size { ; Heap region growing up
|
||
|
}
|
||
|
RW_m_ncache_unused +0 EMPTY m_ncache_size-ImageLength(RW_m_ncache)-Heap_Size { ; Empty region added for MPU configuration
|
||
|
#else
|
||
|
RW_m_ncache_unused +0 EMPTY m_ncache_size-ImageLength(RW_m_ncache) { ; Empty region added for MPU configuration
|
||
|
#endif
|
||
|
}
|
||
|
}
|