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

【经验分享】STM32 的FSMC功能理解

[复制链接]
STMCU小助手 发布时间:2022-1-23 17:44
FSMC全称“静态存储器控制器”。
使用FSMC控制器后,可以把FSMC提供的FSMC_A[25:0]作为地址线,而把FSMC提供的FSMC_D[15:0]作为数据总线。
(1)当存储数据设为8位时,(FSMC_NANDInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_8b)
    地址各位对应FSMC_A[25:0],数据位对应FSMC_D[7:0]
(2)当存储数据设为16位时,(FSMC_NANDInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b)
    地址各位对应FSMC_A[24:0],数据位对应FSMC_D[15:0]
& }3 K7 ~( j: [; b& {
FSMC 包含四个主要模块:
5 R. ~7 R8 J1 c: S2 s● AHB 接口 ( 包含 FSMC 配置寄存器 )
+ T0 ^! i4 q) R' g● NOR 闪存和 PSRAM 控制器
● NAND 闪存和 PC 卡控制器5 M1 }1 b% ]+ j" F9 P" I
● 外部设备接口
1965829-20200419195520036-1031207770.png

( }& U2 S& K) ?( \  F' V
TFT液晶的接线
LCD有如下控制线:* A4 p: o6 p2 t
CS:Chip Select 片选,低电平有效: \5 w6 k$ ]2 m0 _
RS:Register Select 寄存器选择
2 M/ S/ ^# ?! T7 Z% @1 JWR:Write 写信号,低电平有效
& \- S  _" D7 f3 c* W' NRD:Read 读信号,低电平有效6 u6 B9 Z1 A% I3 z* O
RESET:重启信号,低电平有效1 J9 H0 N% B5 U0 \/ ~' P) D) K
DB0-DB15:数据线

! a$ p3 {9 i& {9 ~
TFT液晶的读写编程思路
假如这些线,全部用普通IO口控制。根据LCD控制芯片手册(参考控制芯片时序理解一下):
% g! W0 i  a  _/ L如果情况如下:
$ x' l6 U" r& lDB0-DB15的IO全部为1(表示数据0xffff),也可以为其他任意值,这里以0xffff为例。! \/ v9 e9 B6 X. t/ G! A0 T% r+ H
CS为0(表示选上芯片,CS拉低时,芯片对传入的数据才会有效)
; D8 p' m8 D3 F* @$ H" yRS为1(表示DB0-15上传递的是要被写到寄存器的值),如果为0,表示传递的是数据。/ }0 j6 W9 O3 n, s
WR为0,RD为1(表示是写动作),反过来就是读动作。
' U5 o, h& o6 X  ~RESET一直为高,如果RESET为低,会导致芯片重启。7 V( E1 m, W6 Q' m# W& Z2 S
这种情况,会导致一个值0xffff被传入芯片,被LCD控制芯片当作写寄存器值去解析。LCD控制芯片收到DB0-15上的值之后,根据其他控制线的情况,它得出结论,这个0xffff是用来设置寄存器的。一般情况下,LCD控制芯片会把传入的寄存器值的高8位当做寄存器地址(因为芯片内部肯定不止一个寄存器),低8位当做真正的要赋给对应寄存器值。这样,就完成了一个写LCD控制芯片内部寄存器的时序。
如果上述情况不变,只将RS置低,那么得到的情况如下:LCD控制芯片会把DB0-15上的数据当做单纯的数据值来处理。那么假如LCD处在画图状态,这个传入的值0xffff,就会被显示到对应的点上,0xffff就表示白色,那么对应的点就是白色。在这个数据值传递过来之前,程序肯定会通过设置寄存器值,告诉LCD控制芯片要写的点的位置在哪里。
如果上述两种情况都不变,分别把WR和RD的信号反过来(WR=1,RD=0),那么写信号就会被变成读信号。读信号下,主控芯片需要去读DB0-15的值,而LCD控制芯片就会去设置DB0-15的值,从而完成读数据的时序。
读寄存器的时序麻烦一点。第一步,先要将WR和RD都置低,主控芯片通过DB0-15传入寄存器地址。第二步就和前面读数据一样,将WR置高,RD置低,读出DB0-15的值即可。在这整个的过程中,RS一直为低。好了,上面就是IO直接控制LCD的方法。
' L3 u. k8 B( m* x3 Z
TFT液晶采用FSMC操作,改善效率。
假如放到STM32里面,用IO直接控制显得效率很低。STM32有FSMC(其实其他芯片基本都有类似的总线功能),FSMC的好处就是你一旦设置好之后,WR、RD、DB0-DB15这些控制线和数据线,都是FSMC自动控制的。
打个比方,当你在程序中写到:*(volatile unsigned short int *)(0x60000000)=val;
那么FSMC就会自动执行一个写的操作,其对应的主控芯片的WE、RD这些脚,就会呈现出写的时序出来(即WE=0,RD=1),数据val的值也会通过DB0-15自动呈现出来(即FSMC-D0:FSMC-D15=val)。地址0x60000000会被呈现在数据线上(即A0-A25=0,地址线的对应最麻烦,要根据具体情况来,好好看看FSMC手册)。/ U, A" G7 @3 ~* X$ U- ~, J
那么在硬件上面,我们需要做的,仅仅是MCU和LCD控制芯片的连接关系:
& Y* O. S: k/ q( n+ o! CWE-WR,均为低电平有效
) H" y6 p5 R, g1 e& p6 |RD-RD,均为低电平有效! B* v: K4 F. W
FSMC-D0-15接LCD DB0-15
3 F( O2 h$ ?, t& \( C0 Y# Q连接好之后,读写时序都会被FSMC自动完成。
但是还有一个很关键的问题,就是RS没有接,CS没有接。因为在FSMC里面,根本就没有对应RS和CS的脚。怎么办呢?这个时候,有一个好方法,就是用某一根地址线来接RS。比如我们选择了A16这根地址线来接,那么当我们要写寄存器的时候,我们需要RS,也就是A16置高。软件中怎么做呢?也就是将FSMC要写的地址改成0x60020000,如下:
# N2 `* G! y: ^" @( d; W+ f+ z*(volatile unsigned short int *)(0x60020000)=val;7 p" M( K1 k1 N% V2 U) h
这个时候,A16在执行其他FSMC的同时会被拉高,因为A0-A18要呈现出地址0x60020000。0x60020000里面的Bit17=1,就会导致A16为1。
( {& W5 t' S/ R6 A. Y" v6 Y; ?当要读数据时,地址由0x60020000改为了0x60000000,这个时候A16就为0了。
那么有朋友就会有疑问,第一,为什么地址是0x6xxxxxxx而不是0x0xxxxxxx;第二,CS怎么接;第三,为什么Bit17对应A16?
7 W8 m, C! c7 ^先来看前两个问题,大家找到STM32的FSMC手册,在FSMC手册里面,我们很容易找到,FSMC将0x60000000-0x6fffffff的地址用作NOR/PRAM(共256M地址范围)。而这个存储块,又被分成了四部分,每部分64M地址范围。当对其中某个存储块进行读写时,对应的NEx就会置低。这里,就解决了我们两个问题,第一,LCD的操作时序,和NOR/PSRAM是一样的(为什么一样自己找找NOR/PSRAM的时序看看),所以我们选择0x6xxxxxxx这个地址范围(选择这个地址范围,操作这个地址时,FSMC就会呈现出NOR/PSRAM的时序)。第二,我们可以将NEx连接到LCD的CS,只要我们操作的地址是第一个存储块内即可(即0-0x3ffffff地址范围)。
第三个问题再来看一看FSMC手册关于存储器字宽的描述,我们发现,当外部存储器是16位时,硬件管脚A0-A24表示的是地址线A1-A25的值,所以我们要位移一下,Bit17的值,实际会被反应到A16这根IO来。关于数据宽度及位移的问题,初学的朋友可能会比较疑惑,当你接触了多NOR/PRAM这样的器件后,你会发现,很多芯片的总线,都是这样设计的,为的是节省地址线。
$ H. p# P% O' z4 r2 g
FSMC_CLK
FSMC_A0  ~~~~~~ FSMC_A25       FSMC_D0 ~~~~~~~ FSMC_D15
FSMC_NE1 ~~~FSMC_NE4
FSMC_NOE
FSMC_NWE
FSMC_NWAIT
FSMC_NADV          FSMC_NBL0             FSMC_NBL1
7 o# [* ?3 {" y& c4 @' n
1965829-20200419201124271-182510171.png

) o( V# O9 T/ a
1965829-20200419201155801-463365080.png
" q5 J9 q* S' g4 P/ I2 r  w- l# d+ e0 F1 |  B5 ~9 t0 x0 c
1965829-20200419201225573-910551047.png , N7 h) t; \7 b6 E  E
2 a; E' C$ K7 }- }
硬件接线的举例:
野火 STM32 开发板驱动配套的 3.2 寸液晶、触摸屏,使用 FSMC 接口控制该屏幕自带的液晶控制器 ILI9341 ,使用 SPI 接口与触摸屏控制器 TSC2046 通讯。驱动成功后可在屏幕上使用基本的触摸绘图功能。
//TFT 数 据 线
2 ~4 W' f% h$ }( @5 e3 @2 }! K
PD14-FSMC-D0 ----LCD-DB0' g; a* ]* i& P* K! q
PD15-FSMC-D1 ----LCD-DB1
' u# G3 D% r0 u( t
PD0-FSMC-D2 ----LCD-DB2
8 b$ B' F) [! V5 M' D/ w
PD1-FSMC-D3 ----LCD-DB3* r7 |8 z& ~  e5 U
PE7-FSMC-D4 ----LCD-DB47 p: O5 D1 [" i8 `* }
PE8-FSMC-D5 ----LCD-DB5
/ z8 n0 e) M, E' n% e7 m& E( @
PE9-FSMC-D6 ----LCD-DB6
2 k! L' u8 A( M$ v- U  T# v% M
PE10-FSMC-D7 ----LCD-DB75 }" h4 o2 d) E+ _7 i
PE11-FSMC-D8 ----LCD-DB8
# }$ u8 Q+ k( k, n/ Q# P% c
PE12-FSMC-D9 ----LCD-DB90 e! ~. m7 ^3 O* Y! ~( P- {7 Y
PE13-FSMC-D10 ----LCD-DB10
3 x" {9 F1 @" S2 k7 ]1 [2 h
PE14-FSMC-D11 ----LCD-DB11+ P" |1 i% d' d
PE15-FSMC-D12 ----LCD-DB12
' l: L3 J7 P- U$ D# }& `1 }; k5 J
PD8-FSMC-D13 ----LCD-DB13  @) T4 B, i; I! U8 z
PD9-FSMC-D14 ----LCD-DB14
6 i; P7 H- v3 Z( ^  t6 @7 L
PD10-FSMC-D15 ----LCD-DB15      
TFT 控制信 号线
. r( r1 O: E) e4 B& ~
PD4-FSMC-NOE ----LCD-RD. W3 [1 Y% M1 J5 \" ?3 K
PD5-FSMC-NEW ----LCD-WR( E% w: _$ y) h$ B5 ?
PD7-FSMC-NE1 ----LCD-CS0 Q( P8 [; \& {  h' S3 V4 c
PD11-FSMC-A16 ----LCD-DC" ~" {+ a& l3 N& h
PE1-FSMC-NBL1 ----LCD-RESET
6 Q) B5 K7 m7 x- e5 `6 X4 c3 ^
PD13-FSMC-A18 ----LCD-BLACK-LIGHT
/ j  `4 _  o, Z; I
//触 摸 屏 TSC2046 控制 线
4 S; J* C- Z! ~( A
PA5-SPI1-SCK ----TSC2046-SPI -SCK
1 y: [, p0 s' T$ [2 m. x
PA7-SPI1-MOSI ----TSC2046-SPI - MOSI
% G2 x0 n+ l7 f/ n1 i
PA6-SPI1-MISO ----TSC2046-SPI – MISO2 m4 R- [- V9 e" S" D
PB7-I2C1-SDA ----TSC2046-SPI-CS4 D) R! M: l; T  D+ H
PB6-I2C1-SCL ----TSC2046- INT_IRQ

' `4 Z. z3 L( [6 _3 w3 n2 b: U
收藏 评论0 发布时间:2022-1-23 17:44

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版