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 改回去
|