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.c
和fix16_trig.h
,找找有没有代码占用了大量RAM
原因已经很明显了,我使用的这个库,它有着坑爹的数组长度。
收工
别忘记进options for target...
- target
把IRAM
IROM
改回去