定位KEIL编译的程序大小异常位置

当KEIL编译代码导致超过STM32F030C8t6单片机容量时,会出现Error:L6406E错误。通过提升编译优化等级、增大IRAM1大小进行临时解决。通过.map文件分析,发现是库文件中大数组导致RAM占用过高。优化代码或调整库使用以降低内存占用,确保代码能在单片机上运行。
摘要由CSDN通过智能技术生成

KEIL编译代码,大小超过单片机容量后,会产生
Error: L6406E: No space in execution regions with XXX
这样的一个报错。
在这里插入图片描述

简介:因为最近一下新加了很多我不熟悉的代码,而KEIL出现报错是没法看map文件占用大小的,所以现在不能定位出问题的代码。

先尝试解决

打开 Options for target...

在这里插入图片描述

选择 C/C++(AC6)选项卡

把编译优化等级开到 -O3 试试看能否编译过去
在这里插入图片描述
一般只要你刚刚新加的代码使用资源不是太夸张,很大概率会编译成功

判断是RAM超了还是ROM超了

如果还是编译不过去(代码容量超过单片机容量)
那我们需要确定是RAM干超了还是ROM干超了
切换到target选项卡,先把IRAM1强行改大
在这里插入图片描述
我用的MCU是STM32F030C8t6 它有着64KByte ROM、8KByte RAM
代码没改动之前容量我只用了几KByte
所以我怀疑是新加的库把RAM给搞大了… 直接IRAM1拉到1Mbyte测试一下
如果你怀疑ROM不够大,那就把ROM改大喽…

在这里插入图片描述
编译一下,果然能过了,看编译输出,这内存占用…离谱

给小白的提示:编译过了不代表你你现在可以下程序进单片机了!!!
现在代码容量已经超过单片机物理存储容量大小了!你要优化你的代码!让它占用容量变小!

在这里插入图片描述
人傻了,什么鬼能占这么多RAM?

定位出问题的代码

这时打开你的工程目录,去Listings目录(放编译输出文件的目录,里面一堆.o .d文件)
用文本编辑器打开.map文件
翻到最底下,这里可以看到坑爹的RAM占用情况
在这里插入图片描述
关于这三项啥意思:RO-data,RW-data,ZI-data含义及mcu的flash实际存储数据
往上翻,找到Image component sizes
在这里插入图片描述
这时去看fix16_trig.cfix16_trig.h,找找有没有代码占用了大量RAM

在这里插入图片描述
原因已经很明显了,我使用的这个库,它有着坑爹的数组长度。

收工

别忘记进options for target... - targetIRAM IROM 改回去
视芯片大小填写,请不要无脑照抄,不同信号芯片不同大小

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值