FSMC(Flexible Static Memory Controller,可变静态存储控制器)是STM32系列採用的一种新型的存储器扩展技术。在外部存储器扩展方面具有独特的优势,可根据系统的套用需要,方便地进行不同类型大容量静态存储器的扩展。
基本介绍
- 中文名可变静态存储控制器
- 外文名Flexible Static Memory Controller
- 相关係列STM32系列
- 用途大容量静态存储器的扩展。
引言
STM32是ST(意法半导体)公司推出的基于ARM核心Cortex-M3的32位微控制器系列。Cortex-M3核心是为低功耗和价格敏感的套用而专门设计的,具有突出的能效比和处理速度。通过採用Thumb-2高密度指令集,Cortex-M3核心降低了系统存储要求,快速的中断处理能够满足控制领域的高实时性要求,使基于该核心设计的STM32系列微控制器能够以更优越的性价比,面向更广泛的套用领域。
STM32系列微控制器为用户提供了丰富的选择,可适用于工业控制、智慧型家电、建筑安防、医疗设备以及消费类电子产品等多方位嵌入式系统设计。STM32系列採用一种新型的存储器扩展技术——FSMC,在外部存储器扩展方面具有独特的优势,可根据系统的套用需要,方便地进行不同类型大容量静态存储器的扩展。
机制
FSMC(Flexible Static Memory Controller,可变静态存储控制器)是STM32系列中内部集成256 KB以上FlaSh,后缀为xC、xD和xE的高存储密度微控制器特有的存储控制机制。之所以称为“可变”,是由于通过对特殊功能暂存器的设定,FSMC能够根据不同的外部存储器类型,发出相应的数据/地址/控制信号类型以匹配信号的速度,从而使得STM32系列微控制器不仅能够套用各种不同类型、不同速度的外部静态存储器,而且能够在不增加外部器件的情况下扩展多种不同类型的静态存储器,满足系统设计对存储容量、产品体积以及成本的综合要求。
FSMC技术优势
①支持多种静态存储器类型。STM32通过FSMC可以与SRAM、ROM、PSRAM、NOR Flash和NANDFlash存储器的引脚直接相连。
②支持丰富的存储操作方法。FSMC不仅支持多种数据宽度的异步读/写操作,而且支持对NOR/PSRAM/NAND存储器的同步突发访问方式。
③支持扩展多种存储器。FSMC的映射地址空间中,不同的BANK是独立的,可用于扩展不同类型的存储器。当系统中扩展和使用多个外部存储器时,FSMC会通过汇流排悬空延迟时间参数的设定,防止各存储器对汇流排的访问冲突。
④支持更为广泛的存储器型号。通过对FSMC的时间参数设定,扩大了系统中可用存储器的速度範围,为用户提供了灵活的存储晶片选择空间。
⑤支持代码从FSMC扩展的外部存储器中直接运行,而不需要调入内部SRAM。
FSMC内部结构
STM32微控制器之所以能够支持NOR Flash和NAND Flash这两类访问方式完全不同的存储器扩展,是因为FSMC内部实际包括NOR Flash和NAND/PC Card两个控制器,分别支持两种截然不同的存储器访问方式。在STM32内部,FSMC的一端通过内部高速汇流排AHB连线到核心Cortex-M3,另一端则是面向扩展存储器的外部汇流排。核心对外部存储器的访问信号传送到AHB汇流排后,经过FSMC转换为符合外部存储器通信规约的信号,送到外部存储器的相应引脚,实现核心与外部存储器之间的数据互动。FSMC起到桥樑作用,既能够进行信号类型的转换,又能够进行信号宽度和时序的调整,禁止掉不同存储类型的差异,使之对核心而言没有区别。
FSMC映射地址空间
FSMC管理1 GB的映射地址空间。该空间划分为4个大小为256 MB的BANK,每个BANK又划分为4个64 MB的子BANK,如表1所列。FSMC的2个控制器管理的映射地址空间不同。NOR Flash控制器管理第1个BANK,NAND/PC Card控制器管理第2~4个BANK。由于两个控制器管理的存储器类型不同,扩展时应根据选用的存储设备类型确定其映射位置。其中,BANK1的4个子BANK拥有独立的片选线和控制暂存器,可分别扩展一个独立的存储设备,而BANK2~BANK4只有一组控制暂存器。
表1FSMC映射地址空间
配置
FSMC扩展NOR Flash配置
SRAM/ROM、NOR Flash和PSRAM类型的外部存储器都是由FSMC的NOR Flash控制器管理的,扩展方法基本相同,其中NOR Flash最为複杂。通过FSMC扩展外部存储器时,除了传统存储器扩展所需要的硬体电路外,还需要进行FSMC初始化配置。FSMC提供大量、细緻的可程式参数,以便能够灵活地进行各种不同类型、不同速度的存储器扩展。外部存储器能否正常工作的关键在于用户能否根据选用的存储器型号,对配置暂存器进行合理的初始化配置。
确定映射地址空间
根据选用的存储器类型确定扩展使用的映射地址空间。NOR Flash只能选用BANK1中的4个子BANK。选定映射子BANK后,即可确定以下2方面内容
①硬体电路中用于选中该存储器的片选线FSMC_NEi(i为子BANK号,i=1,…,4);
②FSMC配置中用于配置该外部存储器的特殊功能暂存器号(如表1所列)。
配置存储器基本特徵
通过对FSMC特殊功能暂存器FSMC_BCRi(i为子BANK号,i=1,…,4)中对应控制位的设定,FSMC根据不同存储器特徵可灵活地进行工作方式和信号的调整。根据选用的存储器晶片确定需要配置的存储器特徵,主要包括以下方面
①存储器类型(MTYPE)是SRAM/ROM、PSRAM,还是NOR FlaSh;
②存储晶片的地址和数据引脚是否复用(MUXEN),FSMC可以直接与AD0~AD15复用的存储器相连,不需要增加外部器件;
③存储晶片的数据线宽度(MWID),FSMC支持8位/16位两种外部数据汇流排宽度;
④对于NOR Flash(PSRAM),是否採用同步突发访问方式(B URSTEN);
⑤对于NOR Flash(PSRAM),NWAIT信号的特性说明(WAITEN、WAITCFG、WAITPOL);
⑥对于该存储晶片的读/写操作,是否採用相同的时序参数来确定时序关係(EXTMOD)。
配置存储器时序参数
FSMC通过使用可程式的存储器时序参数暂存器,拓宽了可选用的外部存储器的速度範围。FSMC的NORFlash控制器支持同步和异步突发两种访问方式。选用同步突发访问方式时,FSMC将HCLK(系统时钟)分频后,传送给外部存储器作为同步时钟信号FSMC_CLK。此时需要的设定的时间参数有2个
①HCLK与FSMC_CLK的分频係数(CLKDIV),可以为2~16分频;
②同步突发访问中获得第1个数据所需要的等待延迟(DATLAT)。
对于异步突发访问方式,FSMC主要设定3个时间参数地址建立时间(ADDSET)、数据建立时间(DATAST)和地址保持时间(ADDHLD)。FSMC综合了SRAM/ROM、PSRAM和NOR Flash产品的信号特点,定义了4种不同的异步时序模型。选用不同的时序模型时,需要设定不同的时序参数,如表2所列。在实际扩展时,根据选用存储器的特徵确定时序模型,从而确定各时间参数与存储器读/写周期参数指标之间的计算关係;利用该计算关係和存储晶片数据手册中给定的参数指标,可计算出FSMC所需要的各时间参数,从而对时间参数暂存器进行合理的配置。
3 STM32扩展S29GL系列NOR Flash实例
S29GL系列NOR Flash简介
Spansion公司的S29GL系列晶片是採用90nm技术製造的高集成度NOR Flash存储晶片,提供16~128 MB可选容量,支持最快25 ns的页访问速度和110 ns的随机访问速度,带有最大64位元组的写缓冲区,以提供更快、更高效的编程,是嵌入式系统设计中大容量存储器扩展的理想选择。本文选用的型号为S29GL512P,容量为512×64K字(总容量64 MB),扩展到NOR Flash控制器管理的BANK1的第2个子BANK。
STM32与S29GL512P的电路连线
S25GL512P可通过控制引脚BYTE选择对晶片的访问单位(字/位元组),区别在于
①对于晶片引脚DQ15,字模式时传送最高数据位D15;位元组模式时传送最低地址A-1。
②字模式时,数据引脚D0~D15上传送数据信号;位元组模式时,只有D0~D7上有信号。
此处,将BYTE上拉到高电平,选择16位的字访问单位。FSMC数据线FSMC_D[150]与S29GL512P的D15~D0对应连线;FSMC地址线FSMC_A[250]的低25根与S29GL512P的地址线A[240]对应连线。
由于S29GL512P晶片映射到BANK1的子BANK2,可确定其片选线应连线FSMC片选控制线FSMC_NE2。S29GL512P的RY/BY引脚连线FSMC的FSMC_NWAIT引脚,提供等待信号。
FSMC的配置
根据S29GL512P的映射位置,需要对FSMC_BCR2和FSMC_BTR2/BWTR2暂存器进行配置。
(1)FSMC_BCR2
配置S29GL512P的读/写採用统一时间参数,只需要设定时间暂存器FSMC_BTR2。配置存储器类型为NORFlash,数据汇流排宽度为16位(字),不採用地址/数据复用,使能BANK1的子BANK2。
(2)FSMC_BTR2
由表2可知,异步NOR Flash时序模型Mode2/B需要设定时间参数DATAST和ADDSET。根据时序图,两个参数的计算公式如下
式中Twc和Trc为所选存储晶片的写周期长度和读操作周期长度;Twp为所选存储晶片的写信号持续长度。根据S29GL512P用户手册,可知参数Twc=Trc=130 ns,Twp=35 ns。设STM32微控制器採用72 MHz主频,则HCLK=(1/72×10-6)s。通过上述公式计算,可取值为DATAST=2,ADDSET=5。
为了达到更好的控制效果,还应考虑FSMC自身延迟问题,使用校正公式
式中TAVQV为所选存储晶片访问过程中,从地址有效至数据有效的时间域;Tsu(Data_NE)为STM32特徵参数,从数据有效到FSMC_NE(片选)失效时间域;Ttv(A_NE)为STM32特徵参数,从FSMC_NE有效至地址有效的时间域。
TAVQV=130 ns,Tsu(Data_NE)+Ttv(A_NE]=36 ns,对DATAST参数进行校正,可得DATAST=3。
套用STM32固件对FSMC进行初始化配置
ST公司为用户开发提供了完整、高效的工具和固件库,其中使用C语言编写的固件库提供了覆盖所有标準外设的函式,使用户无需使用彙编操作外设特性,从而提高了程式的可读性和易维护性。
STM32固件库中提供的FSMC的NOR Flash控制器操作固件,主要包括2个数据结构和3个函式。
数据结构FSMC_NORSRAMTimingInitTypeDef对应 时间参数暂存器FSMC_BTR和FSMC_BWTR的结构定义;
FSMC_NORSRAMinitTypeDef对应特徵配置暂存器FSMC_BCR的结构定义,并包含2个指向对应BANK的FSMC_BTR和FSMC_BWTR暂存器的FSMC_NORSRAMTimingInitTypeDef结构指针。针对上述S29GL512P晶片扩展要求,利用固件库进行的主要初始化操作如下
STM32作为新一代ARM Cortex-M3核处理器,其卓越的性能和功耗控制能够适用于广泛的套用领域;而其特殊的可变静态存储技术FSMC具有高度的灵活性,对于存储容量要求较高的嵌入式系统设计,能够在不增加外部分立器件的情况下,扩展多种不同类型和容量的存储晶片,降低了系统设计的複杂性,提高了系统的可靠性。