FMC&FSMC

简介: 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 数据通信事务转换为适当的外部器件协议
  • 满足外部器件的访问时序要求

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

参考内容:

目录
相关文章
|
8月前
STM32F103标准外设库——SysTick系统定时器(八)
STM32F103标准外设库——SysTick系统定时器(八)
638 0
STM32F103标准外设库——SysTick系统定时器(八)
|
8月前
|
芯片
Keil5中添加C51芯片
Keil5中添加C51芯片
955 0
|
8月前
|
网络协议 Python
python中socket客户端发送和接收数据
【4月更文挑战第7天】本教程聚焦TCP客户端数据发送与接收。使用Python的`socket`模块,通过`send()`发送字节串至服务器,如`client_socket.send(message_bytes)`;用`recv()`接收数据,如`received_data = client_socket.recv(buffer_size)`。异常处理确保网络错误时程序健壮性,例如`try-except`捕获`socket.error`。理解和掌握这些基础操作对于构建稳定的TCP客户端至关重要。
1628 1
|
8月前
|
Linux API SoC
linux系统中驱动框架基本分析
linux系统中驱动框架基本分析
242 0
|
8月前
|
Ubuntu Linux 编译器
Linux通过/proc/version文件
`/proc/version`文件在Linux系统中提供当前内核版本详情,属于伪文件系统 `/proc`,展示内核、硬件和进程信息。通过`cat /proc/version`可查看,如`Linux version 5.4.0-80-generic...`,显示内核版本、编译日期等。但此文件不包含发行版信息,查询发行版详情可查看`/etc/os-release`或用`lsb_release`命令。
320 6
|
8月前
|
Java 关系型数据库 MySQL
NUL (NULL) - ASCII值0 (0x00)
NUL (NULL) - ASCII值0 (0x00)
661 2
|
8月前
|
内存技术
esp8266-01s烧录AT固件方法以及遇到的问题总结
esp8266-01s烧录AT固件方法以及遇到的问题总结
438 0
|
IDE 开发工具 开发者
ESP8266固件SDK开发初体验-打印helloworld
ESP8266固件SDK开发初体验-打印helloworld
280 0
STM32中断与事件的理解
STM32中断与事件的理解
407 1
|
安全 网络安全 开发工具
Git 之 git clone 使用 https 和 ssh 的区别
Git 之 git clone 使用 https 和 ssh 的区别
1228 0