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

STM32学习笔记:读写内部Flash(介绍+附代码) - 竹风清 - 博客园

https://www.cnblogs.com/pertor/p/9484663.html

STM32 进阶教程 11 - RAM中运行程序_张十三的博客-CSDN博客_stm32 ram中运行
https://blog.csdn.net/zhanglifu3601881/article/details/95040782

 

手里有一块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.

..\工程目录\Listing\internal_FLASH.map

stm32出现ram、rom不够用,调试方法_第1张图片

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

stm32出现ram、rom不够用,调试方法_第2张图片

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

stm32出现ram、rom不够用,调试方法_第3张图片

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

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

 

你可能感兴趣的:(单片机)