keil rt-thread link.sct 解析

link.sct 解析

#define m_flash_config_start           0x60000000
#define m_flash_config_size            0x00001000

#define m_ivt_start                    0x60001000
#define m_ivt_size                     0x00001000

#define m_interrupts_start             0x60002000
#define m_interrupts_size              0x00000400

#define m_text_start                   0x60002400
#define m_text_size                    0x1fffdbff

#define m_data_start                   0x20000000
#define m_data_size                    0x00020000

#define m_data2_start                  0x20200000
#define m_data2_size                   0x00040000

/* 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

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

#if defined(XIP_BOOT_HEADER_ENABLE) && (XIP_BOOT_HEADER_ENABLE == 1)
/*
    LR_m_text:  加載域名稱
    m_flash_config_start: 加載域 LR_m_text 起始地址; 0x60000000
    m_text_start+m_text_size-m_flash_config_start: 加載域 LR_m_text 空間大小; (m_flash, m_ivt, m_interrupts, m_text這四個空間加在一起)
*/
LR_m_text m_flash_config_start m_text_start+m_text_size-m_flash_config_start {   ; load region size_region
  RW_m_config_text m_flash_config_start FIXED m_flash_config_size { ; load address = execution address
    * (.boot_hdr.conf, +FIRST)  //所有目標文件和庫的.boot_hdr.conf段, 第一個被加載到執行域, 從起始地址開始
  }

  RW_m_ivt_text m_ivt_start FIXED m_ivt_size { ; load address = execution address
    * (.boot_hdr.ivt, +FIRST)   //所有目標文件和庫的.boot_hdr.ivt段, 第一個被加載到執行域, 從起始地址開始
    * (.boot_hdr.boot_data) //所有目標文件和庫的.boot_hdr.boot_data段, 被加載到執行域, 緊跟着.boot_hdr.ivt段後
    * (.boot_hdr.dcd_data)  //所有目標文件和庫的.boot_hdr.dcd_data段, 被加載到執行域, 緊跟着.boot_hdr.boot_data段後
  }
  
#else
/*
    LR_m_text:  加載域名稱
    m_interrupts_start: 加載域 LR_m_text 起始地址; 0x60002000
    m_text_start+m_text_size-m_interrupts_start: 加載域 LR_m_text 空間大小; (m_interrupts, m_text這兩個空間加在一起)
*/
LR_m_text m_interrupts_start m_text_start+m_text_size-m_interrupts_start {   ; load region size_region
#endif
//FIXED: 固定地址
  VECTOR_ROM m_interrupts_start FIXED m_interrupts_size { ; load address = execution address
    * (RESET,+FIRST)    //所有目標文件和庫的RESET段, 第一個被加載到執行域, 從起始地址開始
  }
  ER_m_text m_text_start FIXED m_text_size { ; load address = execution address
    * (InRoot$$Sections)    //InRoot$$Sections段的所有目標文件和庫, 被加載到執行域, 從起始地址開始
    .ANY (+RO)  //所有目標文件和庫的RO段, 被加載到執行域, 緊跟着InRoot$$Sections段後
  }
  RW_m_data m_data_start m_data_size-Stack_Size-Heap_Size { ; RW data
    .ANY (+RW +ZI)  //所有目標文件和庫的RO,ZI段, 第一個被加載到執行域, 從起始地址開始
    * (NonCacheable.init)   //所有目標文件和庫的NonCacheable.init段, 被加載到執行域, 緊跟着上一段後
    * (NonCacheable)    //所有目標文件和庫的NonCacheable段, 被加載到執行域, 緊跟着上一段後
  }

/*
    ARM_LIB_HEAP: 堆區執行域名稱
    +0: 前一個加載區域尾地址+offset 做爲當前的起始地址, 且"offset"應爲"0"或"4"的倍數
    EMPTY: 表示這段空間留空,防止其它應用佔用或編譯提示warning
    Heap_Size: 長度是正值,說明向高地址增長, 大小是Heap_Size
    
    ARM_LIB_STACK: 棧區執行域名稱
    Stack_Size: 如果值爲正,則棧向高地址增長;否則,棧向低地址增長
    
    RTT_HEAP: rt-thread堆區執行域名稱
    RTT_HEAP_SIZE: 同Heap_Size
*/
  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{}
}

參考鏈接:
KEIL MDK鏈接腳本詳解
Keil sct分散加載文件
STM32 分散加載文件 .sct 解析

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章