文件路径:bl_iot_sdk\components\platform\soc\bl602\bl602\evb\ld\flash.ld
这个描述文件叫链接文件,比如 KEIL 中的 *.sct文件,IAR中的*.icf文件 都是此类文件,linux中一般是*.ld文件。
下面是文件内容
OUTPUT_ARCH( "riscv" ) /*设置输出文件的体系结构为 riscv 架构 */
ENTRY( bl602_start ) /* 将 bl602_start 函数设置为 入口函数 */
__EM_SIZE = DEFINED(ble_controller_init) ? 8K : 0K; /* 如果定义了 ble_controller_init 函数,
那么分配一个 __EM_SIZE 大小是 8K */
/* MEMORY 描述的是存储区域 代码空间 */
/* tcm 是紧耦合内存,速度比一般ram 快,分为:itcm和dtcm */
/* r:只读 x:可执行 a:可分配 w:可读写 i:可初始化 !后面属性是没有后面/否定后面属性 */
MEMORY
{
rom (rxai!w) : ORIGIN = 0x21015000, LENGTH = 44K
flash (rxai!w) : ORIGIN = 0x23000000, LENGTH = 4M
ram_tcm (wxa) : ORIGIN = 0x4200C000, LENGTH = (16K + 16K + 48K + 64K) /*put itcm with dtcm and also OCRAM*/
ram_wifi (wxa) : ORIGIN = 0x42030000, LENGTH = (104K) /*leave 8K left for BLE*/
}
/* 描述 各个section 如何放入MEMORY空间 */
SECTIONS
{
/* 定义栈的大小,如果用户自定义 __stack_size 则使用此值 */
__stack_size = DEFINED(__stack_size) ? __stack_size : 2K;
/* 设置 boot2 的分区表地址 */
BOOT2_PT_ADDR = 0x42049C00;
/* 设置 boot2 中 flashCfg地址 */
BOOT2_FLASHCFG_ADDR = 0x42049c18;
/* 初始化段存储到 flash区域 输入是所有的不排序的初始化段 */
.init :
{
KEEP (*(SORT_NONE(.init)))
} > flash
/* 生成 text段 到flash 输入是所有text 段 */
.text :
{
*(.te
RISC-V架构设备的链接文件配置详解

该文件是针对RISC-V架构的链接文件,定义了入口函数、内存布局以及各段的分配。内存包括ROM、FLASH和不同类型的RAM,如TCM。文件详细指定了代码、只读数据、初始化数组等在flash和ram_tcm中的位置。此外,还设置了栈的大小、预初始化和初始化数组,并包含了对特定代码段的处理。
最低0.47元/天 解锁文章
2712

被折叠的 条评论
为什么被折叠?



