单片机学习小组
直播中

你又知道了

12年用户 1059经验值
私信 关注

stm32出现ram、rom不够用怎么解决?

STM32出现ram、rom不够用怎么解决?

回帖(1)

宋宾

2022-2-16 10:23:02


手里有一块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.
..工程目录Listinginternal_FLASH.map

4、分析malloc.c
打开malloc.h,可以看到有两块内存池,其中外部高达192k,可以把这个减少至1(反mini也没有外部ram),然后把内部ram也相应减少

5、再编译,看效果
ram减少了,相对应的map文件中mallo.c的zi data也减少了
(用这个方法改了其它地方,最后达到如图所示,可以在103r8tc上运行)



一、keil编译完后会产生以下数据:

Code代表可执行代码,程序中定义的所有函数都位于此处;
RO-data代表可读数据,程序中所有的全局常量数据和字符都位于此处;
RW-data代表已经初始化的读写数据,程序中所有定义并且初始化的全局变量和静态变量均位于此处;
ZI-data代表未初始化的读写数据,程序中定义了但是没有初始化的全局变量和静态变量位于此处;

RAM 里包含的是ZI-data的存储区,ROM包含的是Code RO-data RW-data 三者数据量之和。
二、分析map文件
map文件中,有一段大约跟下图差不多的部分,看划线部分,ZI data 有17k的ram占用,文件位置在heap_2.o

根据map文件显示heap_2.c 占用大量的RAM,定位到FreeRTOSConfig.h文件修改如下

根据芯片具体型号将FreeRTOS的栈空间大小修改(configTOTAL_HEAP_SIZE)
举报

更多回帖

发帖
×
20
完善资料,
赚取积分