FSMC是Flexible static memory controller(可變靜態(tài)存儲(chǔ)控制器)的簡(jiǎn)稱(chēng),是STM32系列采用的一種新型的存儲(chǔ)器擴(kuò)展技術(shù),支持SRAM、Nor Flash、LCD、PSRAM、NAND Flash、PC Card等。只在某些芯片上有,使用前要查看對(duì)應(yīng)的手冊(cè)確定。
在FSMC的角度來(lái)看,外部存儲(chǔ)分成了4個(gè)固定的大小為256MB的bank。
Bank1分成了4個(gè)子bank,每一個(gè)64MB大小,并且每個(gè)bank都有獨(dú)立的片選,用來(lái)控制Nor Flash、RAM、PSRAM。Bank2和Bank3用來(lái)控制NAND Flash。Bank4控制PC Card。
不同的Bank共享了地址、數(shù)據(jù)、讀、寫(xiě)信號(hào),其他信號(hào)根據(jù)bank的用途不同會(huì)有一些差別。
下面介紹下如何通過(guò)FSMC點(diǎn)亮LCD。LCD可以看作是一個(gè)SRAM,通過(guò)Bank1控制。理論上支持8080接口的LCD都可以使用FSMC來(lái)點(diǎn)亮(不知是否有例外)。LCD有8位或16位接口的,F(xiàn)SMC的設(shè)置需要一致,本文以16位為例。
STM32的設(shè)置使用cubeMX很方便,下面是針對(duì)FSMC的設(shè)置,其他基礎(chǔ)設(shè)置這里就不羅列了。
這里使用了bank1的第四個(gè)子bank,片選是NE4;
內(nèi)存類(lèi)型是LCD接口;
LCD寄存器選擇為A0,其他A1-A24都可以,這本來(lái)是存儲(chǔ)器尋址信號(hào),這里用來(lái)接LCD的RS信號(hào),控制LCD是寫(xiě)命令(低0)還是寫(xiě)數(shù)據(jù)(高1)。;
數(shù)據(jù)選擇16位。
再往下
寫(xiě)操作使能;
擴(kuò)展模式Disabled;
地址建立時(shí)間設(shè)置為6;
數(shù)據(jù)建立時(shí)間設(shè)置為6;
總線(xiàn)翻轉(zhuǎn)時(shí)間設(shè)置為0.
上面建立時(shí)間范圍如下表所示,實(shí)際要根據(jù)LCD的時(shí)序確定。
除了上面的配置,別忘了一般LCD還有個(gè)背光控制引腳。
之后生成代碼。(只羅列了變量和函數(shù)內(nèi)容,不是真正的函數(shù))
背光引腳代碼如下:
FSMC的初始化代碼如下:
FSMC的引腳配置
FSMC模式和時(shí)序配置:
到此,F(xiàn)SMC的初始化就搞定了,后邊就可以通過(guò)內(nèi)存地址直接控制LCD了。這里有幾個(gè)需要注意的點(diǎn),下面來(lái)詳細(xì)說(shuō)說(shuō)。
第一, 存儲(chǔ)基地址
bank1的基地址是0x60000000,不同的子bank地址不同,通過(guò)HADDR[27:26]這兩位的值確定。我們選擇了第四個(gè),這兩位是11,所以子bank的基地址是
0x60000000+(0x3<<26)=0x6c000000。
第二, 外部存儲(chǔ)地址
HADDR[25:0]存儲(chǔ)了外部存儲(chǔ)器的地址,對(duì)于8位和16位略有差別。
8位用到了HADDR[25:0]的所有位,對(duì)映FSMC_A[25:0]。而16位只用了HADDR[25:1],沒(méi)有用HADDR0,所以對(duì)于16位,HADDR[25:1]就對(duì)映了FSMC_A[24:0]。
第三, LCD的數(shù)據(jù)or命令選擇
LCD沒(méi)有地址,我們引出的地址線(xiàn)實(shí)際上接到了LCD的RS或者叫D/C引腳上。當(dāng)RS為低,則通過(guò)D[15:0]的是命令,當(dāng)RS為高,則通過(guò)D[15:0]的是數(shù)據(jù)。上面我們選擇了A0,在16位模式下,寫(xiě)命令的地址就是0x6c000000(HADDR1為0),寫(xiě)數(shù)據(jù)的地址就是0x6c000002(HADDR1為1)
(其實(shí)地址不唯一,只要保證HADDR1的0和1準(zhǔn)確就行,其他地址位隨意,但是一般選擇最簡(jiǎn)單或?qū)嵱玫牡刂?,后邊?huì)提到)。
我們?cè)偌僭O(shè)選擇A3,那么寫(xiě)命令的地址還是0x6c000000(HADDR4為0),寫(xiě)數(shù)據(jù)的地址是0x6c000010(HADDR4為1)。所以結(jié)論就是,寫(xiě)命令的地址可以都是0x6c000000,寫(xiě)數(shù)據(jù)的地址根據(jù)選擇的地址線(xiàn)確定。這是最簡(jiǎn)單的地址。
第四, 巧用結(jié)構(gòu)體,只需定義一個(gè)地址
在很多參考例程中,會(huì)出現(xiàn)下面的實(shí)現(xiàn)方法:
我們都知道結(jié)構(gòu)體是順序排列的,所以L(fǎng)CD_REG的地址是0x6c000000,變量大小是2個(gè)字節(jié)(16位),所以L(fǎng)CD_RAM的地址就是0x6c000002,剛好就是我們選擇A0地址線(xiàn)(HADDR1)拉高的值。
那如果選擇其他地址線(xiàn),這里就需要做一點(diǎn)變動(dòng)。比如選擇A3,我們逆向操作來(lái)解決這個(gè)問(wèn)題,A3寫(xiě)數(shù)據(jù)地址是0x6c000010,也就是LCD_RAM的地址。LCD_REG比LCD_RAM小兩個(gè)字節(jié),減2就得到了0x6c00000e,此時(shí)HADDR4為0,那這個(gè)就是我們需要的LCD基地址,因?yàn)橹挥羞@個(gè)值加2后會(huì)變成寫(xiě)數(shù)據(jù)的地址,這就是那個(gè)實(shí)用的地址。
操作框圖如下圖所示,F(xiàn)SMC初始化好后就跟透明的一樣,只需要往指定的地址送命令或者數(shù)據(jù)即可。類(lèi)似串口藍(lán)牙的透?jìng)鳎坏┰O(shè)置配對(duì)好,就可以無(wú)視藍(lán)牙的存在。
后面的事情就跟具體的LCD有關(guān)了,比如讀取ID,寫(xiě)初始化序列等,這里就不多介紹了。
-
lcd
+關(guān)注
關(guān)注
34文章
4469瀏覽量
169093 -
存儲(chǔ)器
+關(guān)注
關(guān)注
38文章
7557瀏覽量
164951 -
sram
+關(guān)注
關(guān)注
6文章
777瀏覽量
115128 -
STM32
+關(guān)注
關(guān)注
2277文章
10952瀏覽量
359244 -
FSMC
+關(guān)注
關(guān)注
0文章
55瀏覽量
38305
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
FPGA與STM32通過(guò)FSMC總線(xiàn)通信的實(shí)驗(yàn)

在rtthread系統(tǒng)中STM32103VET6使用硬件FSMC驅(qū)動(dòng)LCD刷屏速度慢怎么解決?
stm32的fsmc總線(xiàn)上同時(shí)掛載LCD屏和SRAM和單獨(dú)設(shè)置一個(gè)FSMC總線(xiàn)設(shè)備的有哪些區(qū)別?
求助,關(guān)于STM32F103ZE+UC/GUI+7寸LCD硬件選擇問(wèn)題求解
stm32f429將NandFlash和SDRAM都外掛在FSMC總線(xiàn)上,LCD顯示很多黑線(xiàn)怎么解決?
STM32F427的FSMC能接入AD7606的并行總線(xiàn)嗎?
FSMC_Bank1和FSMC_Bank1E沒(méi)有定義是怎么回事?
求助,關(guān)于STM32F407VET6 FSMC的地址問(wèn)題求解
求助,關(guān)于STM32F407通過(guò)FSMC訪(fǎng)問(wèn)NAND FLASH問(wèn)題求解
用LCD采用杜邦線(xiàn)連接GD32F103的板子可以正常驅(qū)顯,但在焊的PCB板子上不能顯示,為什么?
stm32f405rg LQFP64封裝的芯片支持fsmc嗎?
關(guān)于STM32F103使用FSMC同步模式問(wèn)題求解
CKS32F4xx系列FSMC功能簡(jiǎn)介

評(píng)論