首先,要在工程设置选项中勾选生成map文件,默认设置是不生成map文件的,我们需要手动设置一下。如下图:
另外,也可以在workspace的Output虚拟目录下双击显示的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的可以从这里查到)。
下面介绍调试的时候常常会用到的几个部分。
1. PLACEMENT SUMMARY,该部分主要显示代码和数据在芯片内部的存储器映射地址。可能会有人疑问为什么会分配到这些地址的呢,其实这些地址分配都是在Linker文件(*.icf文件)里定义好的,IAR根据所选目标芯片就按照该定义的地址进行链接,然后烧写进Flash,具体的地址空间的定义可以查看icf文件说明了解详细内容。
2. ENTRY LIST,开发工程内所有函数的入口地址。这部分很有用,通过该地址映射再结合调试的时候观察内存空间,可以了解整个程序的执行状况。
3. MODULE SUMMARY,主要概述被链接文件所占ro代码大小、rw数据大小。
这是map文件末尾部分,最后给出了整个工程文件占用的资源情况,即芯片内部Flash和RAM的使用情况,便于你对工程开发规模上的掌握,最后给出工程编译链接输出信息。