FSMC简介
为什么可以利用FSMC来使用外部RAM呢,先了解一下STM32里的FSMC。大容量且引脚数在100脚以上的STM32F103芯片都带有FSMC接口。FSMC是灵活的静态存储控制器,能够与同步或异步存储器和16位PC存储器卡接口,STM32的FSMC接口支持包括SRAM、NANDFLASH、NORFLASH和PSRAM等存储器。FSMC框图:
FSMC管理1GB的映射地址空间。该空间划分为4个大小为256MB的BANK,每个BANK又划分为4个64MB的子BANK,FSMC的2个控制器管理的映射地址空间不同。NORFlash控制器管理第1个BANK,NAND/PCCard控制器管理第2~4个BANK。如图是FSMC的存储空间地址映射:
这次的重点是用上外部的RAM,所以只介绍Bank1。STM32的FSMC存储块1被分为4个区,每个区管理64M字节空间,每个区都有独立的寄存器对连接的存储器进行配置。Bank1的256M字节空间由28根地址先寻址。当Bank1接的是16位宽的设备,HADDR[25:1]->FSMC[24:0]。当Bank1接的是8为宽度存储器的时候:HADDR[25:0]->FSMC[25:0]。
对FSMC的基本信息介绍就是上面这几点,重点是关注每一个区的地址范围。因为在下面的内容会用到。
FSMC配置
根据此原理图进行配置:
如图是以FSMC的BANK1区域3来控制IS63WV51216这个1M字节容量的SRAM芯片。开始配置FSMC,现在是利用FSMC来操作外部SRAM。所以在选择存储器类型时就选择SRAM。上图可以看出地址总线和数据总线是分开的,所以配置的时候选择不复用总线。也要注意的是芯片的数据宽度是16位。在配置完成后使能控制块就可以了。如下是配置代码
LDRR0,=0x00000114
LDRR1,=0x40021014
STRR0,[R1] ;使能FSMC时钟
LDRR0,=0X000001E0
LDRR1,=0X40021018
STRR0,[R1] ;GPIOD,GPIOE,GPIOF,GPIOG时钟使能
LDRR0,=0x44BB44BB
LDRR1,=0x40011400
STRR0,[R1]
LDRR0,=0xBBBBBBBB
LDRR1,=0x40011404
STRR0,[R1];配置GPIOD
LDRR0,=0xB44444BB
LDRR1,=0x40011800
STRR0,[R1]
LDRR0,=0xBBBBBBBB
LDRR1,=0x40011804
STRR0,[R1];配置GPIOE
LDRR0,=0x44BBBBBB
LDRR1,=0x40011C00
STRR0,[R1]
LDRR0,=0xBBBB4444
LDRR1,=0x40011C04
STRR0,[R1];配置GPIOF
LDRR0,=0x44BBBBBB
LDRR1,=0x40012000
STRR0,[R1]
LDRR0,=0x44444B44
LDRR1,=0x40012004
STRR0,[R1];配置GPIOG
LDRR0,=0x00001011;选择存储类型SRAM,地址数据不复用,总线宽度16位,写使能,并启动存储器块
LDRR1,=0xA0000010
STRR0,[R1];对控制寄存器配置完成
LDRR0,=0x00000200;根据外部SRAM芯片的时序配置时序寄存器
LDRR1,=0xA0000014
STRR0,[R1] ;时序寄存器配置结束
有了对FSMC的配置代码,最后一步就是修改STM32的启动文件以及编译软件的设置,具体如何操作咱继续往后看。
启动文件与编译软件配置
最后一步就是对启动文件进行修改以及对编译软件进行配置。现在需要把片内的RAM全部作为栈来使用,所以在启动文件中要完成栈顶地址的设置以及长度的设置。并在启动文件中完成对FSMC的配置。
DATA_IN_ExtSRAMEQU1;方便以后修改所用
Stack_SizeEQU0x00000400;定义栈的大小
AREASTACK,NOINIT,READWRITE,ALIGN=3
Stack_MemSPACEStack_Size
IF DATA_IN_ExtSRAM==1;重点从这里开始
__initial_sp EQU0X20000000+Stack_Size;设置栈顶地址,STM32是向下生长;的所以这么设置
ELSE
__initial_sp
ENDIF
第一处修改完成,主要完成了对栈顶的设置。下面开始第二处:
Reset_HandlerPROC
EXPORTReset_Handler[WEAK]
IFDATA_IN_ExtSRAM==1;方便以后修改
;此处添加上面对FSMC配置的代码
ENDIF;修改结束
IMPORT__main
IMPORTSystemInit
LDRR0,=SystemInit
BLXR0
LDRR0,=__main
BXR0
ENDP
第二处修改完成,主要是加入了对FSMC配置的代码。到此启动代码的修改部分就结束了,下面对编译软件进行设置。在设置之前我们回头看看第一部分对FSMC的介绍,可以看出现在RAM的首地址为0x68000000,因为我们是通过Bank1的第三区控制的所以首地址是0x68000000。了解了这个我们就开始设置编译软件:
到此为止所有工作都完工了,可以给UCGUI的存储设备分配70K字节的空间都毫无压力。最后提醒一点,记得将UseMicroLIB选上。