一、STM32系统结构

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

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

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

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

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

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

二、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)。

  期间,调料位置不能放错,但可以不放。由上面的例子可以看出,空的调料盒子决定了有意义的调料盒子存放调料的结构。因此,只

要了解空盒子的存储结构,就可以很清楚的明白当有调料时的用法了。

三、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存储器的结构了。

四、STM32存储器结构

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

  图中可以很清晰的看到,STM32的存储器结构和Cortex-M3的很相似,不同的是,STM32加入了很多实际的东西,如:Flash、

SRAM等。只有加入了这些东西,才能成为一个拥有实际意义的、可以工作的处理芯片——STM32。

  STM32的存储器地址空间被划分为大小相等的8块区域,每块区域大小为512MB。对STM32存储器知识的掌握,实际上就是对

Flash和SRAM这两个区域知识的掌握。因此,下面将重点描述Flash和SRAM的知识。

五、STM32的SRAM

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

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

的容量大小。

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

备断电后,SRAM中存储的数据就会丢失。

六、STM32的Flash

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

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

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

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

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

七、STM32存储器结构总结

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

  • Peripherals:外设的存储器映射,对该区域操作,就是对相应的外设进行操作;
  • SRAM:运行时临时存放代码的地方;
  • Flash:存放代码的地方;
  • System Memory:STM32出厂时自带的你只能使用,不能写或擦除;
  • Option Bytes:可以按照用户的需要进行配置(如配置看门狗为硬件实现还是软件实现);

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

  注:IAP的实现可以看这两篇文章:

八、MPU/MMU

MMU原理

  MPU的功能:MPU(Memory Protection Unit)内存保护单元,是ARM Cortex M 架构中设计的一个专门的硬件模块,目的是实施

对存储器的保护,从而使软件更加健壮可靠。MPU 可以对存储器(SRAM 或外设)的访问进行限制,这样可以限制程序的某些非法行为。

MPU 从某种意义上说,是MMU 的简化版本,MMU 通常出现在较为高端的芯片中,如ARM9,A8。MMU 支持虚拟内存机制,但对于

MCU 来说,其应用领域常常是对实时性要求高的控制领域,MMU 固然好,但由于引入虚拟内存机制,导致实时性的下降。MPU 很好的

解决了这个问题,它既可以起到MMU 的对存储器访问的保护作用,又去掉了虚拟内存机制,避免了实时性的下降。

九、FSMC

  FSMC全称“灵活静态存储器控制器”,是STM32系列采用一种新型的存储器扩展技术,stm32通过FSMC可以与SRAM、ROM、PSRAM、

NOR Flash和NAND Flash等存储器的引脚直接相连。下图为FSMC的结构图:

  stm32F4的FSMC把外部设备分为2类:NOR/PSRAM设备、NAND/PC卡设备,他们共用地址数据总线等信号,但是有不同的CS(片选)

信号来区分设备。从FSMC的角度,外部存储器被划分为4个固定大小的存储区域(Bank),每个存储区域的大小为256MB,共1GB空间,每

个存储区又分为4个区域,相当于带4个片选信号。如下图所示为FSMC存储器地址映射:

  根据不同的外部设备,FSMC控制器设置的时序模型、位宽、时钟参数等也有所不同。根据FSMC分配的地址,我们就可以开始直接对外设操作了。

十、内存管理

  采用的内存管理方法:分块式内存管理。其实现原理如下图:

stm32之存储系统的更多相关文章

  1. STM32学习之路入门篇之指令集及cortex——m3的存储系统

    STM32学习之路入门篇之指令集及cortex——m3的存储系统 一.汇编语言基础 一).汇编语言:基本语法 1.汇编指令最典型的书写模式: 标号 操作码        操作数1, 操作数2,... ...

  2. Hello China操作系统STM32移植指南(二)

    移植步骤详解 下面就以MDK 4.72为开发环境,详细说明Hello China内核向STM32的移植过程.MDK 4.72评估版只支持32K代码的编译,这对Hello China的内核来说,裁剪掉一 ...

  3. KV存储系统

    现在的KV存储系统都是分布式的,首先介绍Zookeeper——针对大型分布式系统的高可靠的协调系统. 开发分布式系统是件很困难的事情,其中的困难主要体现在分布式系统的“部分失败”.“部分失败”是指信息 ...

  4. ucos实时操作系统学习笔记——操作系统在STM32的移植

    使用ucos实时操作系统是在上学的时候,导师科研项目中.那时候就是网上找到操作系统移植教程以及应用教程依葫芦画瓢,功能实现也就罢了,没有很深入的去研究过这个东西.后来工作了,闲来无聊就研究了一下这个只 ...

  5. [转] STM32各种时钟的区别

    [原创]:http://m.oschina.net/blog/129357 我在原创的基础又从另一位博主处引用了一些内容. 时钟系统是处理器的核心,所以在学习STM32所有外设之前,认真学习时钟系统是 ...

  6. [转载]:STM32为什么必须先配置时钟再配置GPIO

    转载来源 :http://blog.csdn.net/fushiqianxun/article/details/7926442 [原创]:我来添两句,就是很多同学(包括我)之前搞低端单片机,到了stm ...

  7. STM32 NVIC配置详解

    例程:  /* Configure one bit for preemption priority */  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1) ...

  8. MDK st-link下载STM32程序出现Internal command error和Error:Flash download failed. Target DLL

    MDK st-link下载STM32程序出现Internal command error和Error:Flash download failed. Target DLL   是因为目标板的芯片处于休眠 ...

  9. MDK5 STM32编译问题汇总

    MDK5 STM32编译问题汇总 WIN8.KEIL-MDK-5 编译时,出现弹窗"The ARM C/C++ Compiler 已停止工作",关闭弹窗后,编译输出的窗口中出现如下 ...

随机推荐

  1. C#游戏开发高速新手教程Unity5.5教程

    C#游戏开发高速新手教程Unity5.5教程 试读文档下载地址:http://pan.baidu.com/s/1slwBHoD C#是微软公布的高级程序设计语言.这门语言和C语言一样,已经成为了大学计 ...

  2. 使用EasyPusher进行手机低延时直播推流便捷开发

    基于EasyPusher sdk库工程(即library module)实现一个推送客户端非常简单便捷,因为sdk端已经将各种烦人的状态维护\错误检查\权限判定\UI同步等功能都实现了,开发者仅仅只需 ...

  3. HttpModule与HttpHandler详解(转)

    ASP.NET对请求处理的过程:当请求一个*.aspx文件的时候,这个请求会被inetinfo.exe进程截获,它判断文件的后缀(aspx)之后,将这个请求转交给 ASPNET_ISAPI.dll,A ...

  4. 九度OJ 1078:二叉树遍历 (二叉树)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3748 解决:2263 题目描述: 二叉树的前序.中序.后序遍历的定义: 前序遍历:对任一子树,先访问跟,然后遍历其左子树,最后遍历其右子树 ...

  5. about gnu bash shell

    1 定义字符串不需要引号 var=NONE echo $var ==>NONE 2 支持基本的整数计算 a=1 b=2 echo $((a+b)) ==>3 必须用$(()),双括号的形式 ...

  6. 点聚-weboffice 6.0 (一)

    WebOffice是一款由北京点聚信息技术有限公司提供的完全免费(商业用途也免费)且功能强大的在线Word/excel/wps编辑辅助控件,可以实现:1.在线编辑Word.Excel.PPT.WPS. ...

  7. Java反射机制简单学习

    java中除了基本数据类型,几乎都为对象.例如 Person p=new Person(); 这句语句表明了p是Person类的一个实例对象.但其实,Person也是一个实例对象,它是Class类的实 ...

  8. 一文看透 Redis 分布式锁进化史(解读 + 缺陷分析)(转)

    近两年来微服务变得越来越热门,越来越多的应用部署在分布式环境中,在分布式环境中,数据一致性是一直以来需要关注并且去解决的问题,分布式锁也就成为了一种广泛使用的技术,常用的分布式实现方式为Redis,Z ...

  9. (转)php 根据url自动生成缩略图并处理高并发问题

    分享是一种精神,与技术高低无关!   图片缩略图动态生成- [代码编程] 2011-08-23 版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明http://www.blogbus.c ...

  10. 关于button的自动刷新

    今天在开发中遇到了ajax传数据到后台,处理结果正常,返回的resultMap是一个Map<String,Object>类型,但是返回时显示'Fail to load response d ...