STM32存储器架构,如何通过Code、RO-data、RW-data和ZI-data选型

STM32存储器架构,如何通过Code、RO-data、RW-data和ZI-data选型

本文主要对STM32存储器架构进行了讲解,并解释了如何根据Keil编译后的Code、RO-data、RW-data、ZI-data进行选型。
内存架构
所有的使用Cortex™-M3内核的芯片都要遵循以上的结构进行开发,可以连接不同数量的外设以及分配不同大小的SRAM和FLASH。Cortex™-M3存储器共包括4G,如上图所示,0.5GB的代码区,0.5GB的SRAM区,0.5G的外设存储区、1G的外部RAM区,1G外部设备存储区,专用外设总线-外部、专用外设总线-内部和特定厂商共用0.5G的区域。所有存储块相加共4G。但是这些区域在不同的芯片内用到的也不相同。
下面以STM32F103C8T6进行介绍,根据其手册我们可以知道,且内部有20K的SRAM和64K的FLASH可以使用。也可以在KEIL中查看芯片的内存大小,如下图所示。
SRAM和FLASH查看
内部FLASH的起始地址为0X8000000(所有芯片的起始地址都是这个地址,知识大小不一样),大小为0X10000,计算如下:1*16^4/1024=64K,所以其内部FLASH为61K,通过右边可以看出,其SRAM的起始地址为0X20000000,大小为20K。
也就是说其代码运行区有20K,代码存储区有64K。在我们进行代码设计时候不可以超过其对应的最大值。
如何才能知道自己的代码实际占用了多大的空间呢?
方法1:编译后通过提示进行计算,编译后显示如下:
所需空间图
首先对这四个变量进行解释
Code :执行的代码所占的没存内存(有时候增加几行代码这个数可能不变,这是因为最后生成的Hex文件的代码所占空间没变);
RO-data :只读数据,程序中所定义的全局常量数据(在整个过程中没有变化);
RW-data:读写数据,已初始化的数据,程序中定义并且初始化的全局变量和静态变量;
ZI-data:定义了但未初始化的可读写数据,ZI英语是zero initial,就是程序中用到的变量并且被系统初始化为0的变量的字节数,keil编译器默认是把你没有初始化的变量都赋值一个0,这些变量在程序运行时是保存在RAM中的。
最终保存到Flash中的数据(Total ROM Size)包括:Code+ROData+RW Data
保存到SRAM中运行数据(Total RW Size)的大小:RWData+ZI Data
所有只有单片机的实际Flash容量大于等于程序编译后的Total ROM Size值,且单片机的实际RAM容量大于等于编译后的Total RW Size值,程序才能在单片机中正常运行。
我们对这些数值换算再相加判断空间是否够用显然十分麻烦,所以接下来介绍另外一个方法,在输出文件里面查看,在工程的输出文件中我们可以找到一个.map文件,如下图所示:使用内存查看通过此文件可以很直观的看出,所使用的FLASH的大小为15.61K<64K
所使用的SRAM空间为4.18K<20K
所以当外设够用时(ADC,TIM,IIC等)使用STM32F103C8T6运行此代码是可以的。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值