FMC&FSMC

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 数据通信事务转换为适当的外部器件协议

    扫描二维码关注公众号,回复: 15055671 查看本文章
  • 满足外部器件的访问时序要求

所有外部存储器共享地址、数据和控制信号,但有各自的片选信号。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 的框图如图所示:

在这里插入图片描述

参考内容:
https://blog.csdn.net/qq_42069216/article/details/119452813
https://blog.csdn.net/as480133937/article/details/123740365

猜你喜欢

转载自blog.csdn.net/weixin_45264425/article/details/130535839
FMC