stm32出现ram、rom不够用,调试方法

2019-07-24 13:38发布

手里有一块stm32f103r8ct的板子,想移植ucosii+lwip,使用原子mini的源代码提示ram、rom不够用,一直很纠结,感觉应该是malloc的问题,但又不知道怎么改

103r8t6  ram 20k ,rom 64k
103rct6  ram 48k, rom 256k
两者性能差了很多,所以如果照搬代码,就会发生ram、rom不够用的问题
下面说一下,出现问题怎么解决:
1、编译打开map文件
用103rct6(选择大容量的芯片)先编译一遍(前提是可以编译通过),为的是看一下ram、rom的使用情况,然后双击项目,就会打开*.map的文件,如下图示:



2、查看空间占用情况
map文件最下面,会显示ram、rom的占用情况,如下图示,ram用红线标识,显示占用257.57k,rom用蓝线标识,显示占用126.8k(会发现ram竟然有257kb>48kb,原因是外部ram用192kb)
ram=rw data + zi DATA
rom = code + ro data + rw data

3、分析map文件

map文件中,有一段大约跟下图差不多的部分,看划线部分,ZI data 有200多k的ram占用,文件位置在mallo.o,顺藤摸瓜找到malloc.
捕获1.PNG
4、分析malloc.c
打开malloc.h,可以看到有两块内存池,其中外部高达192k,可以把这个减少至1(反mini也没有外部ram),然后把内部ram也相应减少
捕获.PNG
5、再编译,看效果
ram减少了,相对应的map文件中mallo.c的zi data也减少了
(用这个方法改了其它地方,最后达到如图所示,可以在103r8tc上运行)
捕获.PNG

ps:第一次写,比较乱,见谅~
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。