你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

各位大侠帮帮忙

[复制链接]
maolvtaijun 提问时间:2011-4-12 18:59 /
        我现在在用STM32做毕业设计,不知道FSMC该怎么用,哪位大侠能告诉我FSMC的各个引脚的功能是什么啊。。。。
收藏 评论4 发布时间:2011-4-12 18:59

举报

4个回答
goodboy3021 回答时间:2011-4-12 19:44:45

回复:各位大侠帮帮忙

 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
fxw451 回答时间:2011-4-12 20:20:28

RE:各位大侠帮帮忙

楼上给的相当 全!
net1234599 回答时间:2011-4-12 22:18:30

RE:各位大侠帮帮忙

二楼很详细啊,本来还想说一下的,呵呵!
k10k10k10-19309 回答时间:2011-4-12 22:30:52

RE:各位大侠帮帮忙

找个例程看看
https://www.stmcu.org.cn/bbs/article_1020_131738.html
这个帖子里面的液晶驱动都是基于FSMC的。

所属标签

相似问题

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版