link.sct 4.1 KB
Newer Older
G
guozhanxin 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
#! armcc -E
/*
** ###################################################################
**     Processors:          MIMXRT1052CVL5A
**                          MIMXRT1052DVL6A
**
**     Compiler:            Keil ARM C/C++ Compiler
**     Reference manual:    IMXRT1050RM Rev.C, 08/2017
**     Version:             rev. 0.1, 2017-01-10
**     Build:               b170927
**
**     Abstract:
**         Linker file for the Keil ARM C/C++ Compiler
**
**     Copyright 2016 Freescale Semiconductor, Inc.
**     Copyright 2016-2017 NXP
**     Redistribution and use in source and binary forms, with or without modification,
**     are permitted provided that the following conditions are met:
**
**     1. Redistributions of source code must retain the above copyright notice, this list
**       of conditions and the following disclaimer.
**
**     2. Redistributions in binary form must reproduce the above copyright notice, this
**       list of conditions and the following disclaimer in the documentation and/or
**       other materials provided with the distribution.
**
**     3. Neither the name of the copyright holder nor the names of its
**       contributors may be used to endorse or promote products derived from this
**       software without specific prior written permission.
**
**     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
**     ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
**     WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
**     DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
**     ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
**     (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
**     LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
**     ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
**     (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
**     SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
**
**     http:                 www.nxp.com
**     mail:                 support@nxp.com
**
** ###################################################################
*/

#define m_flash_config_start           0x60000000
#define m_flash_config_size            0x00001000

#define m_ivt_start                    0x60001000
#define m_ivt_size                     0x00001000

#define m_text_start                   0x60002000
#define m_text_size                    0x1F7FE000

#define m_data_start                   0x20000000
#define m_data_size                    0x00020000

#define m_ncache_start                 0x81E00000
#define m_ncache_size                  0x00200000

/* Sizes */
#if (defined(__stack_size__))
  #define Stack_Size                   __stack_size__
#else
  #define Stack_Size                   0x1000
#endif

#if (defined(__heap_size__))
  #define Heap_Size                    __heap_size__
#else
  #define Heap_Size                    0x0400
#endif

#define RTT_HEAP_SIZE (m_data_size-ImageLength(RW_m_data)-ImageLength(ARM_LIB_HEAP)-ImageLength(ARM_LIB_STACK))

; load region size_region
mysterywolf's avatar
mysterywolf 已提交
79 80
LR_IROM1 m_text_start m_text_size
{
G
guozhanxin 已提交
81
    ER_IROM1 m_text_start m_text_size ; load address = execution address
mysterywolf's avatar
mysterywolf 已提交
82
    {
G
guozhanxin 已提交
83 84 85 86
        * (RESET,+FIRST)
        * (InRoot$$Sections)
        .ANY (+RO)
    }
mysterywolf's avatar
mysterywolf 已提交
87

G
guozhanxin 已提交
88
    RW_m_data m_data_start m_data_size-Stack_Size-Heap_Size ; RW data
mysterywolf's avatar
mysterywolf 已提交
89
    {
G
guozhanxin 已提交
90 91
        .ANY (+RW +ZI)
    }
mysterywolf's avatar
mysterywolf 已提交
92

G
guozhanxin 已提交
93 94 95 96 97
    ARM_LIB_HEAP +0 EMPTY Heap_Size{}   ; Heap region growing up
    ARM_LIB_STACK +0 EMPTY Stack_Size{} ; Stack region growing down
    RTT_HEAP +0 EMPTY RTT_HEAP_SIZE{}

    ; ncache RW data
mysterywolf's avatar
mysterywolf 已提交
98 99
    RW_m_ncache m_ncache_start m_ncache_size
    {
G
guozhanxin 已提交
100 101 102 103 104 105 106 107 108 109 110 111 112
        * (NonCacheable.init)
        * (NonCacheable)
    }
    ITCM 0x400 0xFBFF {
        ;drv_flexspi_hyper.o(+RO)
        ;fsl_flexspi.o(+RO)
        * (*CLOCK_DisableClock)
        * (*CLOCK_ControlGate)
        * (*CLOCK_EnableClock)
        * (*CLOCK_SetDiv)
        * (itcm)
    }
}