新建 IAR环境 STM32工程,报错:
Error[Lp011]: section placement failed: unable to allocate space for sections/blocks with a total estimated minimum size of 0x9ca8 bytes in <[0x20000000-0x20004fff]> (total uncommitted space 0x5000).
原因:没指定.icf文件而导致不能够给段/块分配空间....。当然,这解释未必使用其他情况。
回想下IAR 建立工程还有.icf 文件一说.....手生啦。
想着尽量弄清楚些,今个得空+有这个心情。奏起:
STM32存储器结构
首先,我们对比一下Cortex-M3存储器结构和STM32存储器结构:
可知,cortex-M3内核的寻址能力为32位,4G的空间,然 每个片子(stm32的) 用能够用上多少?少.............
这里关心stm32的信息。
code 代码的存放位置。
嵌入式闪存:闪存模块--出自相关手册
这里关注主存储快+信息快(系统存储器+选择字节)大小,不同片型,大小不同。我们在某些情况下读写flash,可操作主存储块的靠后的程序代码用不到的一部分。
SRAM:静态ram
STM32F103V8T6内置64K字节的静态SRAM。它可以以字节、半字(16位)或全字(32位)访问。SRAM的起始地址是0x2000 0000。
所以,我们调试程序时,能够看到的变量地址均在这20K的范围内。0x2000 0000后边的20k。
PERIPHERALS:片内外设
地址空间:0x4000 0000--0x4002 3400
下边说说
IAR中使用.icf文件 划分存储资源
设备:STM32F103V8T6-- ROM---64K RAM:20K
认识IAR 开发环境下的.icf 文件: ----这篇文章可以当做IAP下载方式下,带外部SRAM的整个存储资源规划。
IAR 开发环境下使用 .icf文件定义 MCU及其外扩资源的应用范围,这些在项目设计之前必须被确定下来。所以认识它非常重要。那么该文件是如何定义的呢?
下面通过一个.icf来认识其具体结构:
这是一个基于STM32芯片的.icf文件定义结构:
/*###ICF### Section handled by ICF editor, don't touch! ****/
/*-Editor annotation file-*/
/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
/*-Specials-*/
define symbol __ICFEDIT_intvec_start__ = 0x08000000;/*中断向量表开始地址*/
/*-Memory Regions-*/
define symbol __ICFEDIT_region_ROM_start__ = 0x08000000;/*闪存起始地址*/
define symbol __ICFEDIT_region_ROM_end__ = 0x0800FFFF;/*闪存结束地址---flash大小64k*/
define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;/*SRAM起始地址*/
define symbol __ICFEDIT_region_RAM_end__ = 0x20004FFF;/*SRAM结束地址---SRAM大小20k*/
/*-Sizes-*/
define symbol __ICFEDIT_size_cstack__ = 0x800; /*栈大小*/
define symbol __ICFEDIT_size_heap__ = 0x200;/*堆大小*/
/**** End of ICF editor section. ###ICF###*/
define memory mem with size = 4G;
define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };//CSTACK块属性(8字节对齐、大小__ICFEDIT_size_cstack__)
define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
initialize by copy { readwrite };
do not initialize { section .noinit };
place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; //__ICFEDIT_intvec_start__赋值给.intvec标识符
place in ROM_region { readonly };
place in RAM_region { readwrite,
block CSTACK, block HEAP };
.map 目标文件实际的内存分配
首先当然要生成map文件了,注意IAR的默认设置是不生成map文件的,我们需要手动设置一下,如下图,然后点击准备就绪之后编译
map文件主要由以下几部分构成:
(1)文件头中显示链接器版本,输出文件名,MAP 文件名以及链接器命令行等。
(2)RUNTIME MODEL ATTRIBUTES 部份显示 Endian等属性;
(3) PLACEMENT SUMMARY部份显示各sections 在存储器中的分布;
(4)INIT TABLE 部份显示与初始化有关的section tables;
(5)MODULE SUMMARY部份显示所有被连接的文件信息,包括目标文件和库文件等;
(6)ENTRY LIST部份给出了所有函数的入口地址及其所在的目标文件。
(7)文件尾中显示了总的代码和数据字节数(想看下最后目标代码占用多少Flash和多少RAM的可以从这里查到)。
详情见:深入剖析之通过IAR MAP文件查看目标文件内存分配
看看总是好的.......
上一篇:IAR+STM32固件库 启动文件startup_stm32f10x_hd.s功用及注释
下一篇:STM32学习笔记-Flash做为存储器储存数据
推荐阅读最新更新时间:2024-03-16 15:39
设计资源 培训 开发板 精华推荐
- 睿瀚医疗万斌:“脑机接口+AI+机器人”是康复赛道的未来
- 希润医疗孟铭强:手功能软体机器人,让脑卒中患者重获新生
- 柔灵科技陈涵:将小型、柔性的脑机接口睡眠设备,做到千家万户
- 微灵医疗李骁健:脑机接口技术正在开启意识与AI融合的新纪元
- USB Type-C® 和 USB Power Delivery:专为扩展功率范围和电池供电型系统而设计
- 景昱医疗耿东:脑机接口DBS治疗技术已实现国产替代
- 首都医科大学王长明:针对癫痫的数字疗法已进入使用阶段
- 非常见问题解答第223期:如何在没有软启动方程的情况下测量和确定软启动时序?
- 兆易创新GD25/55全系列车规级SPI NOR Flash荣获ISO 26262 ASIL D功能安全认证证书
- 新型IsoVu™ 隔离电流探头:为电流测量带来全新维度