通过Keil如何查看MCU的RAM与ROM使用情况

概述

        在很多偏门MCU,还是使用keil进行开发,开发过程中能免会出现ram,rom不够问题,怎么查看呢?下面揭晓答案^_^。

一、查看方式

1)、编译后

2)、通过map查看

方法很简单,鼠标对准红色圈,双击即可。


有时,双击不了,只要按照上图配置,此 .map文件一定会在本工程里面,如下所示:

 找到.map,拖拽到keil中打开,即可。通过此文件可以分析,对应各个部分使用情况与合理性,从而进行做相应的优化处理。

 Keil 生成的 Map 文件里面内容大致分为五大类(按照.map文件分类的顺序)如下所示:

1.Section Cross References

指的是各个源文件生成的模块、段(定义的入口)之间相互引用的关系,配置中需勾选上:Cross Reference,例如:

startup_stm32f401xe.o(RESET) refers to stm32f4xx_it.o(i.NMI_Handler) for NMI_Handler

上面表示 startup_stm32f401xe.o 文件中的 main 函数调用了 stm32f4xx_it文件中的 NMI_Handler函数

2.Removing Unused input sections from the image

移除未使用的模块,配置中需勾选上:Unused Sections Info,就是删除工程代码中,没有被调用的模块。最后面还有个统计信息,例如

表明有294段没用使用,总的占17904字节

3.Image Symbol Table

映射符号表,配置中需勾选上:Symbols,从中可以看出符号名称,存储地址,存储大小,所在的目标文件

 举例:可以看出,footwear_title_lists_cn,在main.c文件中,占用了52个字节,如果RAM满了,可以做相对应的优化,如下所示:
 

4.Memory Map of the image

内存映射分布,配置中需勾选上:Memory Map

Image Entry point : 0x08000195:指程序入口地址。

Load Region LR_IROM1 (Base: 0x08000000, Size: 0x000021f8, Max: 0x00080000, ABSOLUTE):
指加载区域 LR_IROM1 起始地址为 0x08000000,大小有0x000021f8,这块区域最大为0x00080000.

Execution Region ER_IROM1 (Exec base: 0x08000000, Load base: 0x08000000, Size: 0x000021d0, Max: 0x00080000, ABSOLUTE):
指可执行区域 ROM_VECTOR 起始地址为 0x08000000,大小有0x000021d0,这块区域最大为0x00080000.

5.Image component sizes

存储组成大小配置中需勾选上:Size Info,其实主要就是对模块进行汇总存储大小信息

Code:指代码的大小;

RO-data:指除了内联数据(inline data)之外的常量数据;

RW-data:指可读写(RW)、已初始化的变量数据;

ZI-data:指未初始化(ZI)的变量数据;

Code、RO-data:位于FLASH中;

RW-data、ZI-data:位于RAM中;

提醒:RW-data已初始化的数据会存储在Flash中,上电会从FLASH搬移至RAM中。

关系如下:

RO Size = Code + RO Data

RW Size = RW Data + ZI Data

ROM Size = Code + RO Data + RW Data

现在已经弄明白Map文件的内容,可以做以下分析。

(1)函数和变量所在的地址,这在推导函数调用栈时非常有用

(2)根据Code RO data RW data 的组成部分,可针对性的优化ROM空间和RAM空间

二、总结

       详细了解,也可以阅读我之前写的文章,链接,时间久了都忘差不多了,好在做了笔录,方便以后翻阅。
 

  • 13
    点赞
  • 89
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
AES加密单片机内存需求取决于多个因素,包括加密算法的实现方式、密钥长度和处理内存与数据存储区域的大小。通常情况下,AES加密单片机所需的内存可以分为以下几个方面: 首先,加密算法的实现方式对内存需求有一定的影响。如果采用软件实现AES加密算法,内存需求通常较大。因为软件实现需要存储加密算法的程序代码和数据,以及中间结果的临时存储空间。而硬件实现的AES加密单片机通常具有专用的硬件电路,可以大大节约内存使用。 其次,密钥长度也会影响内存需求。AES算法的标准密钥长度为128位、192位和256位。通常情况下,密钥越长,加密算法所需的内存也会相应增加。 最后,处理内存和数据存储区的大小也会影响内存需求。处理内存是指用于存储运行时变量和中间结果的内存空间,而数据存储区则是用于存储输入和输出数据的内存空间。如果需要同时处理大量的数据或者进行大量的加密操作,就需要较大的处理内存和数据存储区。 综上所述,如果采用硬件实现AES加密算法,且仅需处理较小规模的数据,一般来说,AES加密单片机所需内存的大小可能在几KB到几十KB之间。但需要注意的是,具体内存需求还取决于具体的单片机型号和设计方案,因此在进行AES加密单片机设计时,需对具体需求进行深入评估和分析,以确定所需的内存大小。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ch_champion

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值