你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

stm32存储器结构、 IAR 开发环境下的.icf 文件、.map文件 解析

[复制链接]
tansft 发布时间:2017-8-16 19:14
新建 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 文件一说.....手生啦。
想着尽量弄清楚些,今个得空+有这个心情。奏起:
20151027231856610.png
STM32存储器结构
首先,我们对比一下Cortex-M3存储器结构和STM32存储器结构:

可知,cortex-M3内核的寻址能力为32位,4G的空间,然 每个片子(stm32的) 用能够用上多少?少.............
这里关心stm32的信息。
code 代码的存放位置。
20151027232551111.png
嵌入式闪存:闪存模块--出自相关手册

这里关注主存储快+信息快(系统存储器+选择字节)大小,不同片型,大小不同。我们在某些情况下读写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文件定义结构:
  1. [cpp] view plain copy print?
  2. /*###ICF### Section handled by ICF editor, don't touch! ****/  
  3. /*-Editor annotation file-*/  
  4. /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */  
  5. /*-Specials-*/  
  6. define symbol __ICFEDIT_intvec_start__ = 0x08000000;/*中断向量表开始地址*/  
  7. /*-Memory Regions-*/  
  8. define symbol __ICFEDIT_region_ROM_start__ = 0x08000000;/*闪存起始地址*/  
  9. define symbol __ICFEDIT_region_ROM_end__   = 0x0800FFFF;/*闪存结束地址---flash大小64k*/  
  10. define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;/*SRAM起始地址*/  
  11. define symbol __ICFEDIT_region_RAM_end__   = 0x20004FFF;/*SRAM结束地址---SRAM大小20k*/  
  12. /*-Sizes-*/  
  13. define symbol __ICFEDIT_size_cstack__ = 0x800; /*栈大小*/  
  14. define symbol __ICFEDIT_size_heap__   = 0x200;/*堆大小*/  
  15. /**** End of ICF editor section. ###ICF###*/  
  16.   
  17. define memory mem with size = 4G;  
  18. define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__];  
  19. define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__];  
  20.   
  21. define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { };//CSTACK块属性(8字节对齐、大小__ICFEDIT_size_cstack__)  
  22. define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { };  
  23.   
  24. initialize by copy { readwrite };  
  25. do not initialize  { section .noinit };  
  26.   
  27. place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; //__ICFEDIT_intvec_start__赋值给.intvec标识符  
  28.   
  29. place in ROM_region   { readonly };  
  30. place in RAM_region   { readwrite,  
  31.                         block CSTACK, block HEAP };  
复制代码


.map 目标文件实际的内存分配
20151027235908357.png
首先当然要生成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的可以从这里查到)。

收藏 评论0 发布时间:2017-8-16 19:14

举报

0个回答

所属标签

STM32团队

意法半导体微控制器和微处理器拥有广泛的产品线,包含低成本的8位单片机和基于ARM® Cortex®-M0、M0+、M3、M4、M33、M7及A7内核并具备丰富外设选择的32位微控制器及微处理器


最新内容

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版