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

KEIL编译代码,大小超过单片机容量后,会产生
Error: L6406E: No space in execution regions with XXX
这样的一个报错。
定位KEIL编译的程序大小异常位置_第1张图片

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

先尝试解决

打开 Options for target...

定位KEIL编译的程序大小异常位置_第2张图片

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

把编译优化等级开到 -O3 试试看能否编译过去
定位KEIL编译的程序大小异常位置_第3张图片
一般只要你刚刚新加的代码使用资源不是太夸张,很大概率会编译成功

判断是RAM超了还是ROM超了

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

定位KEIL编译的程序大小异常位置_第5张图片
编译一下,果然能过了,看编译输出,这内存占用…离谱

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

定位KEIL编译的程序大小异常位置_第6张图片
人傻了,什么鬼能占这么多RAM?

定位出问题的代码

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

定位KEIL编译的程序大小异常位置_第9张图片
原因已经很明显了,我使用的这个库,它有着坑爹的数组长度。

收工

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

你可能感兴趣的:(STM32,HAL,stm32)