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
经验分享 程序员 微信小程序 职场和发展