历史上的今天
返回首页

历史上的今天

今天是:2025年03月18日(星期二)

正在发生

2019年03月18日 | STM32存储器结构&存储器映射

2019-03-18 来源:eefocus

1 STM32系统结构

    要想深刻理解STM32的存储器,需要首先知道STM32的系统结构。

如Figure 1,是STM32系统结构框图。




根据STM32 Reference manual (RM0008)中的描述,如图:




 

 

可以得知STM32系统结构的组成,每一个模块更为详细的内容,请参考相关文档。


RM0008文档中可以看出,STM32采用的是Cortex-M3内核,因此,有必要了解Cortex-M3的存储器结构。

图中还可以看出,Cortex-M3是通过各个总线和Flash、SROM相连接的。


2 STM32内核(Cortex-M3)的结构

以下是Cortex-M3模块框图:


 

 

 

该Cortex-M3内核通过I-Code、D-Code、System总线与STM32内部的Flash、SROM相连接的,该种连接情况直接关系到STM32存储器的结构组织;也就是说,Cortex-M3的存储器结构决定了STM32的存储器结构。


这里可能说的比较笼统,可以这样理解:Cortex-M3是一个内核,自身定义了一个存储器结构,ST公司按照Cortex-M3的这个存储器定义,设计出了自己的存储器结构;但是ST公司的STM32的存储器结构必须按照Cortex-M3这个定义的存储器结构来进行设计。


举个例子:


我买了一个做饭的调料盒子,有三块区域(假设存储器分为3块),上面分别标有盐(Flash)、糖(SROM)、味精(Peripheral);此时,该调料盒子并没有任何意义(对应Cortex-M3内核);我按照标签放入特定品牌、特定分量的盐(Flash)、糖(SROM)、味精(Peripheral),产生一个有实际意义的调料盒(各类Cortex-M3内核的芯片,如STM32)。


期间,调料位置不能放错,但可以不放。由上面的例子可以看出,空的调料盒子决定了有意义的调料盒子存放调料的结构。因此,只要了解空盒子的存储结构,就可以很清楚的明白当有调料时的用法了。


3 STM32内核(Cortex-M3)的存储器映射


存储器映射是指把芯片中或芯片外的FLASH,RAM,外设,BOOTBLOCK等进行统一编址。即用地址来表示对象。这个地址绝大多数是由厂家规定好的,用户只能用而不能改。用户只能在挂外部RAM或FLASH的情况下可进行自定义。


如图,是Cortex-M3存储器映射结构图。


 

 

Cortex-M3是32位的内核,因此其PC指针可以指向2^32=4G的地址空间,也就是0x0000_0000——0xFFFF_FFFF这一大块空间。


好,根据图中描述,Cortex-M3内核将0x0000_0000——0xFFFF_FFFF这块4G大小的空间分成8大块:代码、SRAM、外设、外部RAM、外部设备、专用外设总线-内部、专用外设总线-外部、特定厂商等。导致了,使用该内核的设计者必须按照这个进行各自芯片的存储器结构设计。


这就可以去了解STM32的存储器结构,以及为什么这样设计STM32存储器的结构了。


4 STM32存储器结构


首先,我们对比一下Cortex-M3存储器结构和STM32存储器结构:



 

 

 

图中可以很清晰的看到,STM32的存储器结构和Cortex-M3的很相似,不同的是,STM32加入了很多实际的东西,如:Flash、SRAM等。只有加入了这些东西,才能成为一个拥有实际意义的、可以工作的处理芯片——STM32。


STM32的存储器地址空间被划分为大小相等的8块区域,每块区域大小为512MB。


对STM32存储器知识的掌握,实际上就是对Flash和SRAM这两个区域知识的掌握。因此,下面将重点描述Flash和SRAM的知识。


5 STM32的SRAM


以下是STM32参考手册RM0008中的一段原话:

 

 

不同类型的STM32单片机的SRAM大小是不一样的,但是他们的起始地址都是0x2000 0000,终止地址都是0x2000 0000+其固定的容量大小。


SRAM的理解比较简单,其作用是用来存取各种动态的输入输出数据、中间计算结果以及与外部存储器交换的数据和暂存数据。设备断电后,SRAM中存储的数据就会丢失。


6 STM32的Flash


STM32的Flash,严格说,应该是Flash模块。


该Flash模块包括:Flash主存储区(Main memory)、Flash信息区(Information block),以及Flash存储接口寄存器区(Flash memory interface)。


三个组成部分分别在0x0000 0000——0xFFFF FFFF不同的区域,如图(小密度的STM32)所示:

 



 

 

 

图中完全可以看出Flash模块中的三个组成部分在整个存储器中的位置。

具体的内部区域的意义及功能请参见编程手册PM0042,里面很详细。


7 STM32存储器结构总结


 

图中淡蓝色就是你需要知道的。

Peripherals:外设的存储器映射,对该区域操作,就是对相应的外设进行操作;

SRAM:运行时临时存放代码的地方;

Flash:存放代码的地方;

System Memory:STM32出厂时自带的你只能使用,不能写或擦除;

Option Bytes:可以按照用户的需要进行配置(如配置看门狗为硬件实现还是软件实现);

今后,你的编写代码、程序运行、寄存器设置、ICP、IAP都依靠这些东西。

 

以上描述的是STM32存储器的结构相关,其具体存储器的应用在我的下一篇笔记《STM32存储器知识的相关应用(IAP和Bit Banding)》中详细描述。


推荐阅读

史海拾趣

Afero公司的发展小趣事

随着Afero物联网平台的逐渐成熟,公司开始积极寻求与各行各业的合作伙伴建立合作关系。他们与多家知名的电子设备制造商、软件开发商和服务提供商签订了战略合作协议,共同开发基于Afero平台的物联网解决方案。这些合作不仅帮助Afero拓展了业务领域,还提升了其在行业内的知名度和影响力。

EMCORE公司的发展小趣事

随着Afero物联网平台的逐渐成熟,公司开始积极寻求与各行各业的合作伙伴建立合作关系。他们与多家知名的电子设备制造商、软件开发商和服务提供商签订了战略合作协议,共同开发基于Afero平台的物联网解决方案。这些合作不仅帮助Afero拓展了业务领域,还提升了其在行业内的知名度和影响力。

Changzhou Galaxy Century Microelectronics Co.,Ltd公司的发展小趣事

为了进一步加速企业的发展,银河微电决定走上上市之路。经过精心筹备和严格审核,公司终于在2021年成功在上交所上市。上市不仅为公司带来了大量的资金支持,还提高了公司的知名度和品牌影响力。借助上市融资的优势,银河微电加大了对研发、生产、销售等各个环节的投入,企业发展步入快车道。

ENERGIZER公司的发展小趣事

为了配合全球业务的发展,ENERGIZER在亚太地区设立了8个厂房和18个国家的办事处。其中,劲量(中国)有限公司于1992年开始进驻中国,并在1998年在天津设立了生产工厂。这一举措不仅促进了中国与国际间的技术交流与合作,还为中国的电池制造业带来了新的发展机遇。随着中国市场的不断扩大,ENERGIZER在中国的业务也逐渐壮大,成为了中国电池市场的重要参与者。

爱浦电子(AIPULNION)公司的发展小趣事

随着公司业务的不断扩展,爱浦电子于XXXX年成立了广州优联电气科技有限公司作为其分支机构。这一举措不仅进一步扩大了公司的业务范围和市场影响力,还为公司提供了更多的发展机遇和合作伙伴。广州优联电气科技有限公司在爱浦电子的业务开拓、经营及配套服务方面发挥了重要作用,推动了公司整体业务的快速发展。

这五个故事只是爱浦电子发展起来的一部分缩影,它们展现了公司在技术创新、市场拓展、服务升级、创新引领以及分支机构成立等方面的努力和成就。正是这些不懈的努力和持续的进步,使得爱浦电子在电子行业中脱颖而出,成为一家备受瞩目的高新技术企业。

捷嘉电子(Chequers Electronic)公司的发展小趣事

捷嘉电子在成立初期面临着巨大的挑战。那是一个智能电子产品刚刚开始兴起的时代,市场竞争激烈。公司创始人余文跃凭借对电子行业的深刻理解和对技术创新的执着追求,决定投身于智能控制器的研发与生产。在初创阶段,资金紧张、人才短缺、市场推广困难重重。但余文跃凭借着坚韧不拔的毅力,带领团队攻克了一个又一个技术难题,逐渐在市场上站稳了脚跟。

问答坊 | AI 解惑

跪求基于单片机控制的数据采集设计

跪求高手帮忙 我的毕业设计是基于单片机控制的数据采集设计  现在一点头绪都没     有资料的发我171597708@qq.com [ 本帖最后由 171597708 于 2008-10-16 16:12 编辑 ]…

查看全部问答>

arm 的很好的资料

arm 的很好的资料,特别适合初学者!!!…

查看全部问答>

【藏书阁】最新可编程控制器概述及参考答案

可编程控制器(Programmble  Controller)简称PC或PLC。它是在电器控制技术和计算机技术的基础上开发出来的,并逐渐发展成为以微处理器为核心,把自动化技术、计算机技术、通讯技术融为一体的新型工业控制装置 目录 1、可编程控制器的 ...…

查看全部问答>

CE6+6410 Nandflash当U盘问题

平台:S3c6410 + winCE6.0 BSP:三星官方BSP(七月的)     我要实现的功能是Nandflash当U盘功能,现在把SD卡当U盘是没有问题的,在实现U盘功能时 USB驱动的注册表要给 [HKEY_LOCAL_MACHINE\\Drivers\\USB\\FunctionDrivers\\Mass_Sto ...…

查看全部问答>

wm6.0用C#将摄像头视频通过网络向外发送,是否可行?

wm6.0下,想通过C#实现对摄像头视频的捕捉,并且通过网络向外界发送(直播、监控),能不能实现? 大体思路是怎样的?…

查看全部问答>

在ADS编译器中下载程序问题

小弟我刚买了块开发板(arm9 2410), 自己写了个小程序, 在ADS下可以正确编译了, 但是不知道怎么下载到板子里面调试. 好像是用超级终端下载, 但是我在超级终端里面找不到下载的按钮什么的, 郁闷中, 请教各位了. 谢谢各位大侠了!!…

查看全部问答>

可控硅控制罩极电动机

我做了一个可控硅控制负载的电路,负载中灯泡、普通电动机都能够正常启动,只有罩极电动机无法正常启动,哪位有遇到过这种情况的,帮忙讲解下原因?…

查看全部问答>

FPGA学习经验谈

FPGA在目前应用领域非常,在目前的单板设计里面,几乎都可以看到它的身影。从简单的逻辑组合,到高端的图像、通信协议处理,从单片逻辑到复杂的ASIC原型验证,从小家电到航天器,都可以看到FPGA应用,它的优点在这里无庸赘述。从个人实用角度看,对 ...…

查看全部问答>

OS下,软件模拟的SPI,需要禁止任务切换吗?

请问在OS下,操作软件模拟的SPI,I2C等接口,需要禁止任务切换吗? 或者更严重需要禁止中断??…

查看全部问答>