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

本文解析了STM32存储器结构,详细介绍了如何在IAR环境中使用.icf文件进行存储资源分配,并通过实例展示了存储区域的具体定义方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

新建 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文件查看目标文件内存分配

看看总是好的.......
这里不罗嗦了,睡(~﹃~)~zZ










### 解析 IAR 生成的 MAP 文件 #### 理解 MAP 文件的作用 MAP 文件提供了程序在目标硬件上的内存布局详情,对于嵌入式开发尤其重要。这些文件有助于理解代码段、数据段以及全局变量的具体位置和大小,从而优化应用程序性能并解决潜在问题[^1]。 #### 主要组成部分概述 MAP 文件通常会列出编译器版本、构建日期、最终二进制文件的位置以及其他基本信息。这使得开发者可以快速确认所使用的工具链设置是否正确无误[^2]。 #### 查看程序结构与资源分配情况 借助于 MAP 文件中的信息,能够直观地看到整个项目的组织形式——各个源文件贡献了多少代码量;不同类型的存储区域(如 FLASH 和 RAM)是如何被利用起来支持应用运行所需的各种功能模块;还有就是各函数之间的调用关系及其对应的地址偏移值等细节描述[^3]。 #### 堆栈配置分析实例展示 以一段具体的 MAP 数据为例: ```plaintext "P2", part 2 of 3: 0x5b1bc .iar.dynexit 0x2000339c 0x1bc <Block> .iar.dynexit uninit 0x2000339c 0xc cppinit.o [3] .iar.dynexit uninit 0x200033a8 0x1b0 <Block tail> CSTACK 0x20003558 0x2000 <Block> CSTACK uninit 0x20003558 0x2000 <Block tail> HEAP 0x20005558 0x59000 <Block> HEAP uninit 0x20005558 0x59000 <Block tail> ``` 上述片段展示了部分动态初始化节(`.iar.dynexit`)的内容,其中包括未初始化的数据区(`uninit`), 同时也指出了堆(`HEAP`)和栈(`CSTACK`)的空间起始地址及长度。这对于评估系统的实时性和稳定性非常有帮助,因为合理的堆栈规划能有效防止溢出错误的发生[^4]。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值