FSMC——扩展外部的SRAM

SRAM简介

stm32f1系列芯片使用FSMC外设来管理扩展的存储器,FSMC灵活地静态存储器控制器,他可以用于驱动包括SRAM、NORflash、NANDflash类型的存储器,不能驱动如SDRAM这种动态的存储器。在STM32F429中,具有FMC外设,支持FMC,可以控制SDRAM存储器

SRAM:静态随机存取存储器,易失性存储器,读写速度非常快,适合做内存,但是非常贵。
SRAM的引脚图:A是地址线、IO是数据线,就是通过地址去访问数据。
在这里插入图片描述
整个芯片的内部架构
在这里插入图片描述
芯片是通过地址译码器来寻址,找到要访问的存储器矩阵的地址,然后通过IO数据电路去访问

SRAM信号线

在这里插入图片描述
A0~A8:信号线,用来寻址
IO8~IO15:数据线,用作读出或者写入数据
CS1和CS2:同样的功能
UB和LB后面介绍

SRAM存储矩阵

在这里插入图片描述
RAM通过行地址和列地址,来找到某一个单元,但是SRAM没那么复杂,只需要行地址就能找到对应的单元格了
本例中SRAM的空间较小,没有列地址线,数据宽度为16位,即一个行地址对应两个字节的空间,19根数据线可以表示的容量是2^19次方,也就是512K的空间容量(注意这512K和512KB是两码事,512K可以理解成能够寻址512K行,是两个概念),所以说能访问的空间大小是512K x 16Bit 。
上边讲到的UB#和LB#,带 # 号是低电平有效的意思,就是来控制到底访问这个字节的高位还是低位,因为每一个行地址对应的两个字节

SRAM的读写流程

对SRAM读数据时,各个信号线的时序流程如下:
在这里插入图片描述
可以看到读写SRAM是异步通讯,没有时钟线

  • 在整个通讯过程中,地址线都需要保持,不能变。
  • 要把两条片选信号使能,CS1和CS2
  • 各个信号线的时间段非常重要,需要严格按照手册设置
  • 异步通讯就是通过时间来协调的各种参数的

对SRAM写数据时
在这里插入图片描述

FSMC简介

STM32使用FSMC外设管理扩展存储器,译为灵活的静态存储控制器(Flexible Static Memory Controller),可以用于驱动包括SRAM,NORFLASH、NANDFLASH类型的存储器,但是不能用于驱动SDRAM这种动态存储器

FSMC 功能框图

在这里插入图片描述
NORflash:flash的一种,
如图所示FSMC可以控制三种存储器,它有三种信号:

  • NORFLASH控制信号
  • NANDFLASH控制信号
  • PC卡信号(不常用)

FLASH:又叫闪存,用来存储程序的,它结合了ROM和RAM的优点,速度快(RAM)、电可擦写+掉电不丢失(ROM)
NORFLASH:NOR Flash的读取和我们常见的SDRAM的读取是一样,用户可以直接运行装载在NOR FLASH里面的代码,这样可以减少SRAM的容量从而节约了成本。
DANDFLASH:NAND Flash没有采取内存的随机读取技术,它的读取是以一次读取一块的形式来进行的,通常是一次读取512个字节,采用这种技术的Flash比较廉价。用户不能直接运行NAND Flash上的代码,因此好多使用NAND Flash的开发板除了使用NAND Flah以外,还作上了一块小的NOR Flash来运行启动代码。

FSMC引脚名称对关系

在这里插入图片描述
特殊的:FSMC_NE引脚是用于控制SRAM的控制信号线,它有FSMC_NE1~4号引脚,不同的引脚对应stm32内部不同地址区域
比如:当STM32访问0X68000000~0X6BFFFFFF时,FSMC_NE3会自动设置为地电平,其他1、2、4仍为高电平,而FSMC这个脚时连接到SRAM的使能端的,所以可以访问SRAM芯片,其他的引脚就可以多块SRAM,从而达到控制多块SRAM芯片的目的。
这个1~4只是SRAM或者NORFLASH这种模式的,可以连接4块SRAM,四块互相独立。

FSMC结构体配置

  • 时序结构体:FSMC_NORSRAMTimingInitTypeDef
  • 初始化结构体:FSMC_NORSRAMInitTypeDef

版权声明:本文为CSDN博主「叶落小达」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_45589030/article/details/120091238

生成海报
点赞 0

叶落小达

我还没有学会写个人说明!

暂无评论

发表评论

相关推荐

RT-Thread Studio移植LAN8720A驱动

RTT网络协议栈驱动移植(霸天虎) 1、新建工程 ​ 工程路径不含中文路径名,工程名用纯英文不含任何符号。 2、用CubeMx配置板子外设 2.1、配置时钟 ​ 按照自己板子配置相应时钟。

Lin总线通信在STM32作为主机代码以及从机程序

距离上次做资料准备已经过去六天了。最近在学车,上周末就没有开电脑。这周开始进行了Lin通信的代码整理,目前是可以正常通信的了,采用的是增强型校验方式。后期再进一步跟进研究。。。更新一博,留

4路红外循迹模块使用教程

4路红外循迹模块使用教程 个人原创博客:点击浏览模块详细信息: 工作电压:DC 3.3V~5V 工作电流:尽量选择1A以上电源供电 工作温度:-10℃~50℃ 安装孔

【STM32Cube笔记】12-配置外部中断

【STM32Cube笔记】系列文章目录 1-基于STM32的VSCode入门级教程前言 2-STM32Cube安装教程 3-STM32CubeIDE汉化 4-STM32Cube配置时钟设置 5-跑马灯引脚配置 6-Cortex-M7内核基本配