1、 FLASH 存储控制器(FMC)
FLASH 存储控制器(FMC)是一个存储加速单元,其提供:
- 在设备和双行之间的一个接口,bank 0 由程序 flash 组成,bank 1 由 FlexNVM 组成。
- 缓存可以加速 FLASH,和 FlexNVM 数据传输。
FLASH 存储控制器管理设备和双行之间的一个接口,64 位不易失性存储器。FMC 接收状态信息详细记录了存储器的配置,使用该信息可确保一个正确的接口。下表显示了支持 8位,16 位和 32 位读/写操作。
1-概述
FMC功能块可连接:
- 同步/异步静态存储器-------SRAM、DRAM
- NAN Flash----------------NOR Flash、OneNAND Flash
- SDRAM存储器---------------SDRAM
所有外部存储器共享地址、数据和控制信号,但有自己的片选信号。FMC一次只能访问一个外部器件
2-框图
3-主要用途
- 将AHB数据通信事务转换为适当的外部器件协议
- 满足外部存储器件的访问时间要求
4-外部器件地址映射
FMC 总共管理 1.5GB 空间,拥有 6 个存储块(Bank)
从FMC的角度,外部器件比划分为固定大小的存储区域,每个存储取得大小为256MB
- 区域1可连接多达4个NOR Flash或PSRAM器件,此区域被划分为NOR/PSRAM1~4共4个子区域,带4个专用片选信号
- 区域3用于连接NAND Flash器件,此空间的MU存储器特性必须通过软件重新配置到寄存器中
- 区域4和5用于连接SDRAM器件(每个存储区域一个器件)
2、(FSMC)灵活的静态存储控制器。
- FSMC-Flexible static memory controller
FSMC全称“静态存储器控制器”。
Flexible static memory controller(FSMC)灵活的静态存储控制器。
FSMC可以连接异步或同步存储器或16位PC存储卡,主要用途有:
- 将 AHB 数据通信事务转换为适当的外部器件协议
- 满足外部器件的访问时序要求
所有外部存储器共享地址、数据和控制信号,但有各自的片选信号。FSMC 一次只能访问一个外部器件。
FSMC,即灵活的静态存储控制器,能够与同步或异步存储器和16位PC存储器卡连接,STM32的FSMC接口支持包括SRAM、NANDFLASH、NORFLASH和PSRAM等存储器。
FSMC( Flexible static memory controller)全称“灵活的静态存储器控制器”,是 STM32中一个很有特色的外设,通过 FSMC,STM32可以通过FSMC与SRAM、ROM、PSRAM、Nor Flash和NandFlash存储器的引脚相连,从而进行数据的交换。
要注意的是,FSMC 只能扩展静态的内存,即名称里面的 S:static,不能是动态的内存,比如 SDRAM 就不能扩展。
1-FSMC通俗讲解
既然我们知道FMC是可以方便的跟内存存储,那么到底方便到什么地方了呢?
我们用DRAM做一个最简单的举例,让你最直观的了解FMC的用处和便捷之处。
首先我们想一下,你想要在自己的电脑中查找一个文档文件的数据 ,然后拷到U盘里,需要的步骤是什么呢?
- 找到该文档在电脑中的位置(地址)
- 复制该文档(数据)
- 将文档粘贴到U盘中(数据传输)
一共需要三步,而我们的DRAM和NOR FLASH 都是存储器,把它们想成电脑 ,U盘是我们的STM32
单片机跟外部存储器通信,也需要知道数据的地址(电脑中的位置),然后把数据的内容传递(复制粘贴)过来。 那这样的话,存储器就需要地址传输线跟数据传输线,还要加上一些控制时序引脚 比方说复位 写数据 读数据 等等
- 1、地址线:是用来传输地址信息用的。举个简单的例子:cpu在内存或硬盘里面寻找一个数据时,先通过地址线找到地址,然后再通过数据线将数据取出来。 如果有32根.就可以访问2的32次方的字节,也就是4GB。
- 2、数据线(data cable),来传递数据或通信。通俗点说,就是单片机发送指令给存储器,和存储器发送数据给单片机这两个功能
2-FSMC的功能
FSMC的功能总结:
- 将AHB传输信号转换到适当的外部设备协议;
- 满足访问外部设备的时序要求。
所有的外部存储器共享控制器输出的地址、数据和控制信号,每个外部设备可以通过一个唯一的片选信号加以区分。FSMC在任一时刻只访问一个外部设备。
3-FSMC的特点
- 1、 FSMC的一大特点是支持不同位宽的异步读写操作。
- 2、 FSMC的映射地址空间中,不同的BANK是独立的,可用于扩展不同类型的存储器。当FSMC同时使用多个外部存储器时,FSMC会通过总线悬空延时时间参数,来防止访问冲突发生。
- 3、 支持代码从FSMC扩展的外部存储器中直接运行。不需要首先调入内部SRAM。
4-FSMC 框图
FSMC 的框图如图所示: