在线时间0 小时
UID205017
ST金币0
蝴蝶豆0
注册时间2010-6-5
新手上路
- 最后登录
- 1970-1-1
|
发表于 2011-4-12 19:44:45
|
显示全部楼层
a0a.1 0b0c
回复:各位大侠帮帮忙
FSMC(Flexible Static Memory Controller,可变静态存储控制器))是STM32系列中内部集成256 KB以上FlaSh,后缀为xC、xD和xE的高存储密度微控制器特有的存储控制机制。之所以称为“可变”,是由于通过对特殊功能寄存器的设置,FSMC能够根据不同的外部存储器类型,发出相应的数据/地址/控制信号类型以匹配信号的速度,从而使得STM32系列微控制器不仅能够应用各种不同类型、不同速度的外部静态存储器,而且能够在不增加外部器件的情况下同时扩展多种不同类型的静态存储器,满足系统设计对存储容量、产品体积以及成本的综合要求。
优点:
①支持多种静态存储器类型。STM32通过FSMC可以与SRAM、ROM、PSRAM、NOR Flash和NANDFlash存储器的引脚直接相连。
②支持丰富的存储操作方法。FSMC不仅支持多种数据宽度的异步读/写操作,而且支持对NOR/PSRAM/NAND存储器的同步突发访问方式。
③支持同时扩展多种存储器。FSMC的映射地址空间中,不同的BANK是独立的,可用于扩展不同类型的存储器。当系统中扩展和使用多个外部存储器时,FSMC会通过总线悬空延迟时间参数的设置,防止各存储器对总线的访问冲突。
④支持更为广泛的存储器型号。通过对FSMC的时间参数设置,扩大了系统中可用存储器的速度范围,为用户提供了灵活的存储芯片选择空间。
⑤支持代码从FSMC扩展的外部存储器中直接运行,而不需要首先调入内部SRAM。
FSMC分为四个BANK,其中BANK1通过NE[1..4]可以片选四个外设,一般对于入门者来说主要看的就是BANK1的操作,比如NOR Flash和LCD的操作。这里我主要说BANK1的设置。
对BANK1的操作主要是首先设置FSMC_BCRx[1..4],FSMC_BTRx[1..4]和FSMC_BWTRx[1..4]寄存器,把这几个寄存器的意义弄明白了就基本好了:
FSMC_BCRx是控制设置。
FSMC_BTRx是读写时序设置。
FSMC_BWTRx是写时序设置,具体内容与FSMC_BTRx相同。
如果FSMC_BCRx[1..4]中设置了EXTMOD位, 则FSMC_BTRx[1..4]和FSMC_BWTRx[1..4]两个时序寄存器分别对应读、写操作。
如果未设置EXTMOD位,则读和写使用相同的时序FSMC_BTRx[1..4]。
下面给出FSMC相关的寄存器:
/* FSMC registers base address */
// BANK1
#define RFSMC_BCR1 (*(volatile unsigned *)0xA0000000) // SRAM/NOR片选控制寄存器1
#define rFSMC_BCR2 (*(volatile unsigned *)0xA0000008) // SRAM/NOR片选控制寄存器2
#define rFSMC_BCR3 (*(volatile unsigned *)0xA0000010) // SRAM/NOR片选控制寄存器3
#define rFSMC_BCR4 (*(volatile unsigned *)0xA0000018) // SRAM/NOR片选控制寄存器4
#define rFSMC_BTR1 (*(volatile unsigned *)0xA0000004) // SRAM/NOR片选时序寄存器1
#define rFSMC_BTR2 (*(volatile unsigned *)0xA000000C) // SRAM/NOR片选时序寄存器2
#define rFSMC_BTR3 (*(volatile unsigned *)0xA0000014) // SRAM/NOR片选时序寄存器3
#define rFSMC_BTR4 (*(volatile unsigned *)0xA000001C) // SRAM/NOR片选时序寄存器4
#define rFSMC_BWTR1 (*(volatile unsigned *)0xA0000104) // SRAM/NOR写时序寄存器1
#define rFSMC_BWTR2 (*(volatile unsigned *)0xA000010C) // SRAM/NOR写时序寄存器2
#define rFSMC_BWTR3 (*(volatile unsigned *)0xA0000114) // SRAM/NOR写时序寄存器3
#define rFSMC_BWTR4 (*(volatile unsigned *)0xA000011C) // SRAM/NOR写时序寄存器4
// BANK2
#define rFSMC_PCR2 (*(volatile unsigned *)0xA0000060) // PC卡/NAND控制寄存器2
#define rFSMC_SR2 (*(volatile unsigned *)0xA0000064) // FIFO状态和中断寄存器2
#define rFSMC_PMEM2 (*(volatile unsigned *)0xA0000068) // 通用存储空间时序寄存器2
#define rFSMC_PATT2 (*(volatile unsigned *)0xA000006C) // 属性存储空间时序寄存器2
// BANK3
#define rFSMC_PCR3 (*(volatile unsigned *)0xA0000080) // PC卡/NAND控制寄存器3
#define rFSMC_SR3 (*(volatile unsigned *)0xA0000084) // FIFO状态和中断寄存器3
#define rFSMC_PMEM3 (*(volatile unsigned *)0xA0000088) // 通用存储空间时序寄存器3
#define rFSMC_PATT3 (*(volatile unsigned *)0xA000008C) // 属性存储空间时序寄存器3
// BANK4
#define rFSMC_PCR4 (*(volatile unsigned *)0xA00000A0) // PC卡/NAND控制寄存器4
#define rFSMC_SR4 (*(volatile unsigned *)0xA00000A4) // FIFO状态和中断寄存器4
#define rFSMC_PMEM4 (*(volatile unsigned *)0xA00000A8) // 通用存储空间时序寄存器4
#define rFSMC_PATT4 (*(volatile unsigned *)0xA00000AC) // 属性存储空间时序寄存器4
#define rFSMC_PIO4 (*(volatile unsigned *)0xA00000B0) // I/O存储空间时序寄存器4 |
|