keil rt-thread link.sct 解析
生活随笔
收集整理的這篇文章主要介紹了
keil rt-thread link.sct 解析
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
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: 加載域名稱(chēng)m_flash_config_start: 加載域 LR_m_text 起始地址; 0x60000000m_text_start+m_text_size-m_flash_config_start: 加載域 LR_m_text 空間大小; (m_flash, m_ivt, m_interrupts, m_text這四個(gè)空間加在一起) */ LR_m_text m_flash_config_start m_text_start+m_text_size-m_flash_config_start { ; load region size_regionRW_m_config_text m_flash_config_start FIXED m_flash_config_size { ; load address = execution address* (.boot_hdr.conf, +FIRST) //所有目標(biāo)文件和庫(kù)的.boot_hdr.conf段, 第一個(gè)被加載到執(zhí)行域, 從起始地址開(kāi)始}RW_m_ivt_text m_ivt_start FIXED m_ivt_size { ; load address = execution address* (.boot_hdr.ivt, +FIRST) //所有目標(biāo)文件和庫(kù)的.boot_hdr.ivt段, 第一個(gè)被加載到執(zhí)行域, 從起始地址開(kāi)始* (.boot_hdr.boot_data) //所有目標(biāo)文件和庫(kù)的.boot_hdr.boot_data段, 被加載到執(zhí)行域, 緊跟著.boot_hdr.ivt段后* (.boot_hdr.dcd_data) //所有目標(biāo)文件和庫(kù)的.boot_hdr.dcd_data段, 被加載到執(zhí)行域, 緊跟著.boot_hdr.boot_data段后}#else /*LR_m_text: 加載域名稱(chēng)m_interrupts_start: 加載域 LR_m_text 起始地址; 0x60002000m_text_start+m_text_size-m_interrupts_start: 加載域 LR_m_text 空間大小; (m_interrupts, m_text這兩個(gè)空間加在一起) */ 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) //所有目標(biāo)文件和庫(kù)的RESET段, 第一個(gè)被加載到執(zhí)行域, 從起始地址開(kāi)始}ER_m_text m_text_start FIXED m_text_size { ; load address = execution address* (InRoot$$Sections) //InRoot$$Sections段的所有目標(biāo)文件和庫(kù), 被加載到執(zhí)行域, 從起始地址開(kāi)始.ANY (+RO) //所有目標(biāo)文件和庫(kù)的RO段, 被加載到執(zhí)行域, 緊跟著InRoot$$Sections段后}RW_m_data m_data_start m_data_size-Stack_Size-Heap_Size { ; RW data.ANY (+RW +ZI) //所有目標(biāo)文件和庫(kù)的RO,ZI段, 第一個(gè)被加載到執(zhí)行域, 從起始地址開(kāi)始* (NonCacheable.init) //所有目標(biāo)文件和庫(kù)的NonCacheable.init段, 被加載到執(zhí)行域, 緊跟著上一段后* (NonCacheable) //所有目標(biāo)文件和庫(kù)的NonCacheable段, 被加載到執(zhí)行域, 緊跟著上一段后}/*ARM_LIB_HEAP: 堆區(qū)執(zhí)行域名稱(chēng)+0: 前一個(gè)加載區(qū)域尾地址+offset 做為當(dāng)前的起始地址, 且"offset"應(yīng)為"0"或"4"的倍數(shù)EMPTY: 表示這段空間留空,防止其它應(yīng)用占用或編譯提示warningHeap_Size: 長(zhǎng)度是正值,說(shuō)明向高地址增長(zhǎng), 大小是Heap_SizeARM_LIB_STACK: 棧區(qū)執(zhí)行域名稱(chēng)Stack_Size: 如果值為正,則棧向高地址增長(zhǎng);否則,棧向低地址增長(zhǎng)RTT_HEAP: rt-thread堆區(qū)執(zhí)行域名稱(chēng)RTT_HEAP_SIZE: 同Heap_Size */ARM_LIB_HEAP +0 EMPTY Heap_Size{} ; Heap region growing upARM_LIB_STACK +0 EMPTY Stack_Size{} ; Stack region growing downRTT_HEAP +0 EMPTY RTT_HEAP_SIZE{} }參考鏈接:
KEIL MDK鏈接腳本詳解
Keil sct分散加載文件
STM32 分散加載文件 .sct 解析
總結(jié)
以上是生活随笔為你收集整理的keil rt-thread link.sct 解析的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 钢材
- 下一篇: 2019杭电多校Problem 5 Sn