0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

STM32如何通過FSMC點(diǎn)亮LCD

CHANBAEK ? 來源:頭條號科G棧 ? 作者:頭條號科G棧 ? 2023-03-23 10:02 ? 次閱讀

FSMC是Flexible static memory controller(可變靜態(tài)存儲控制器)的簡稱,是STM32系列采用的一種新型的存儲器擴(kuò)展技術(shù),支持SRAM、Nor Flash、LCD、PSRAM、NAND Flash、PC Card等。只在某些芯片上有,使用前要查看對應(yīng)的手冊確定。

在FSMC的角度來看,外部存儲分成了4個固定的大小為256MB的bank。

pYYBAGQbsyeALt0FAADB_IK47Us138.jpg

Bank1分成了4個子bank,每一個64MB大小,并且每個bank都有獨(dú)立的片選,用來控制Nor Flash、RAM、PSRAM。Bank2和Bank3用來控制NAND Flash。Bank4控制PC Card。

不同的Bank共享了地址、數(shù)據(jù)、讀、寫信號,其他信號根據(jù)bank的用途不同會有一些差別。

pYYBAGQbsyiAGyDKAABGVE_gg2U739.jpg

下面介紹下如何通過FSMC點(diǎn)亮LCD。LCD可以看作是一個SRAM,通過Bank1控制。理論上支持8080接口的LCD都可以使用FSMC來點(diǎn)亮(不知是否有例外)。LCD有8位或16位接口的,F(xiàn)SMC的設(shè)置需要一致,本文以16位為例。

STM32的設(shè)置使用cubeMX很方便,下面是針對FSMC的設(shè)置,其他基礎(chǔ)設(shè)置這里就不羅列了。

poYBAGQbsymAV1oDAAG_xbnM61k692.jpg

這里使用了bank1的第四個子bank,片選是NE4;

內(nèi)存類型是LCD接口;

LCD寄存器選擇為A0,其他A1-A24都可以,這本來是存儲器尋址信號,這里用來接LCD的RS信號,控制LCD是寫命令(低0)還是寫數(shù)據(jù)(高1)。;

數(shù)據(jù)選擇16位。

再往下

寫操作使能;

擴(kuò)展模式Disabled;

地址建立時間設(shè)置為6;

數(shù)據(jù)建立時間設(shè)置為6;

總線翻轉(zhuǎn)時間設(shè)置為0.

上面建立時間范圍如下表所示,實(shí)際要根據(jù)LCD的時序確定。

poYBAGQbsyqANpN1AAG8n4G7s4c892.jpg

除了上面的配置,別忘了一般LCD還有個背光控制引腳。

pYYBAGQbsyuAWK0mAAAarHjrZ-E294.jpg

之后生成代碼。(只羅列了變量和函數(shù)內(nèi)容,不是真正的函數(shù))

背光引腳代碼如下:

poYBAGQbsy2AVjKEAAHLHXBr2dY483.jpg

FSMC的初始化代碼如下:

FSMC的引腳配置

pYYBAGQbsy-AdO4cAAIoVVKqGcw275.jpg

FSMC模式和時序配置:

pYYBAGQbszGAKNHfAAJQf3B5r_g171.jpg

到此,F(xiàn)SMC的初始化就搞定了,后邊就可以通過內(nèi)存地址直接控制LCD了。這里有幾個需要注意的點(diǎn),下面來詳細(xì)說說。

第一, 存儲基地址

bank1的基地址是0x60000000,不同的子bank地址不同,通過HADDR[27:26]這兩位的值確定。我們選擇了第四個,這兩位是11,所以子bank的基地址是

0x60000000+(0x3<<26)=0x6c000000。

poYBAGQbszOAYBVmAACWOmFuhXk160.jpg

第二, 外部存儲地址

HADDR[25:0]存儲了外部存儲器的地址,對于8位和16位略有差別。

pYYBAGQbszSALu5vAAAavL2HumE336.jpg

8位用到了HADDR[25:0]的所有位,對映FSMC_A[25:0]。而16位只用了HADDR[25:1],沒有用HADDR0,所以對于16位,HADDR[25:1]就對映了FSMC_A[24:0]。

pYYBAGQbszWAbnv2AAC81il_JTM837.jpg

第三, LCD的數(shù)據(jù)or命令選擇

LCD沒有地址,我們引出的地址線實(shí)際上接到了LCD的RS或者叫D/C引腳上。當(dāng)RS為低,則通過D[15:0]的是命令,當(dāng)RS為高,則通過D[15:0]的是數(shù)據(jù)。上面我們選擇了A0,在16位模式下,寫命令的地址就是0x6c000000(HADDR1為0),寫數(shù)據(jù)的地址就是0x6c000002(HADDR1為1)

(其實(shí)地址不唯一,只要保證HADDR1的0和1準(zhǔn)確就行,其他地址位隨意,但是一般選擇最簡單或?qū)嵱玫牡刂?,后邊會提到)?/p>

pYYBAGQbszaAPt73AACjAfu5ZAQ101.jpg

我們再假設(shè)選擇A3,那么寫命令的地址還是0x6c000000(HADDR4為0),寫數(shù)據(jù)的地址是0x6c000010(HADDR4為1)。所以結(jié)論就是,寫命令的地址可以都是0x6c000000,寫數(shù)據(jù)的地址根據(jù)選擇的地址線確定。這是最簡單的地址。

pYYBAGQbszaAXM9rAADrhh7RyYU120.jpg

第四, 巧用結(jié)構(gòu)體,只需定義一個地址

在很多參考例程中,會出現(xiàn)下面的實(shí)現(xiàn)方法:

pYYBAGQbszeAKcvZAAB9YNtN71o340.jpg

我們都知道結(jié)構(gòu)體是順序排列的,所以LCD_REG的地址是0x6c000000,變量大小是2個字節(jié)(16位),所以LCD_RAM的地址就是0x6c000002,剛好就是我們選擇A0地址線(HADDR1)拉高的值。

那如果選擇其他地址線,這里就需要做一點(diǎn)變動。比如選擇A3,我們逆向操作來解決這個問題,A3寫數(shù)據(jù)地址是0x6c000010,也就是LCD_RAM的地址。LCD_REG比LCD_RAM小兩個字節(jié),減2就得到了0x6c00000e,此時HADDR4為0,那這個就是我們需要的LCD基地址,因?yàn)橹挥羞@個值加2后會變成寫數(shù)據(jù)的地址,這就是那個實(shí)用的地址。

poYBAGQbsziATdmqAAB4Dg8Xu7w197.jpg

操作框圖如下圖所示,F(xiàn)SMC初始化好后就跟透明的一樣,只需要往指定的地址送命令或者數(shù)據(jù)即可。類似串口藍(lán)牙的透傳,一旦設(shè)置配對好,就可以無視藍(lán)牙的存在。

poYBAGQbszmAG-uqAADLTESdCI8539.jpg

后面的事情就跟具體的LCD有關(guān)了,比如讀取ID,寫初始化序列等,這里就不多介紹了。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • lcd
    lcd
    +關(guān)注

    關(guān)注

    34

    文章

    4387

    瀏覽量

    166714
  • 存儲器
    +關(guān)注

    關(guān)注

    38

    文章

    7404

    瀏覽量

    163402
  • sram
    +關(guān)注

    關(guān)注

    6

    文章

    760

    瀏覽量

    114555
  • STM32
    +關(guān)注

    關(guān)注

    2263

    文章

    10847

    瀏覽量

    353798
  • FSMC
    +關(guān)注

    關(guān)注

    0

    文章

    54

    瀏覽量

    38079
收藏 人收藏

    評論

    相關(guān)推薦

    在rtthread系統(tǒng)中STM32103VET6使用硬件FSMC驅(qū)動LCD刷屏速度慢怎么解決?

    STM32103VET6板子,使用rtthread系統(tǒng),用硬件FSMC驅(qū)動LCD(SSD1963)時,初始化時刷屏超級快,但進(jìn)入線程中速度就變慢了,請教有無大佬遇到過這樣的情況,有解決思路么?
    發(fā)表于 07-16 07:00

    stm32fsmc總線上同時掛載LCD屏和SRAM和單獨(dú)設(shè)置一個FSMC總線設(shè)備的有哪些區(qū)別?

    我想問一下stm32fsmc總線上同時掛載LCD屏和SRAM和單獨(dú)設(shè)置一個FSMC總線設(shè)備的有那些區(qū)別(我只做個單個設(shè)備的掛載)那位大神和廠家能講一下嗎,有實(shí)例最好,我就是怕不會出現(xiàn)
    發(fā)表于 05-31 07:31

    求助,關(guān)于STM32F103ZE+UC/GUI+7寸LCD硬件選擇問題求解

    實(shí)現(xiàn)的方案。不過CPLD我一點(diǎn)基礎(chǔ)也沒有。想選擇現(xiàn)成的控制模塊,通過FSMC以外部總線的方式連接,就像很多開發(fā)板上帶的320*240的LCD一樣。不知STM32+UC/GUI推這么大的
    發(fā)表于 05-17 13:32

    stm32f429將NandFlash和SDRAM都外掛在FSMC總線上,LCD顯示很多黑線怎么解決?

    我使用stm32f429開發(fā)板,將NandFlash和SDRAM都外掛在FSMC總線上, 而LCD的顯存是存放在SDRAM中,當(dāng)對NandFlash進(jìn)行格式化時,LCD 顯示很多黑線,
    發(fā)表于 05-17 07:20

    FSMC_Bank1和FSMC_Bank1E沒有定義是怎么回事?

    ?如標(biāo)題所述, FSMC_Bank1和FSMC_Bank1E 沒用定義,但是在stm3f4xx.h中明明有: ? ?#if defined (STM32F427_437xx) || defined
    發(fā)表于 05-15 08:00

    求助,關(guān)于STM32F407VET6 FSMC的地址問題求解

    STM32F407VET6FSMC接口驅(qū)動 DM9000的問題,PD7 接做為片選,PD11做為指令與數(shù)據(jù)的 代碼如下: #define DM9000_DATA*(vu16*)((u32
    發(fā)表于 05-15 07:49

    求助,關(guān)于STM32F407通過FSMC訪問NAND FLASH問題求解

    問題描述:STM32F407通過FSMC外設(shè)訪問三星NAND FLASH,系統(tǒng)時鐘是168MHz,始化外設(shè)GPI0D的PD0、PD1、PD3、PD4、PD6、PD11、PD12、PD14、PD15
    發(fā)表于 05-09 06:14

    stm32f405rg LQFP64封裝的芯片支持fsmc嗎?

    選取的是stm32f405rg芯片 預(yù)計(jì)是直接fsmc驅(qū)動屏 但是我看了一下數(shù)據(jù)手冊 發(fā)現(xiàn)stm32f405rg LQFP64封裝的芯片 并沒有fsmc的引腳定義 那么它是不支持
    發(fā)表于 04-25 07:14

    關(guān)于STM32F103使用FSMC同步模式問題求解

    大家好,我現(xiàn)在正在使用STM32F103的FSMC同步模式。 需要讀取高速ADC數(shù)據(jù),ADC是8位并口,但需要一個時鐘去觸發(fā)轉(zhuǎn)換,在時鐘上升沿讀取數(shù)據(jù),速度20M, 我看FSMC的同步模式正好有
    發(fā)表于 04-17 08:13

    CKS32F4xx系列FSMC功能簡介

    本課講為大家講解CKS32F4xx系列產(chǎn)品的FSMC應(yīng)用實(shí)例,FSMC全稱是Flexible Static Memory Controller,讀作靈活的靜態(tài)存儲控制器,顧名思義,MCU可以通過
    的頭像 發(fā)表于 04-14 15:06 ?786次閱讀
    CKS32F4xx系列<b class='flag-5'>FSMC</b>功能簡介

    STM32實(shí)例教程,帶你了解FSMC的功能和用法[?]()

    PC 存儲卡。STM32通過FSMC可以與SRAM、 ROM、 PSRAM、 NOR Flash和NANDFlash等存儲器的引腳直接相連。STM32F1的
    發(fā)表于 03-15 15:53

    關(guān)于STM32F103從外設(shè)到存儲器DMA通道數(shù)據(jù)格式的問題

    在基于STM32F103開發(fā)過程中遇到了一個瓶頸,就是圖片取模后的數(shù)據(jù)放在W25Q64當(dāng)中,通過硬件SPI+DMA的方式直接將數(shù)據(jù)發(fā)送給FSMC,FSMC被用來驅(qū)動16bit的
    發(fā)表于 03-07 07:11

    使用STM32FSMC與CYUSB3014通信,3014的GPIF要設(shè)置成什么模式?

    需求是STM32的數(shù)據(jù)通過FSMC傳輸給CYUSB3014,再USB傳給PC。 1.請問使用STM32FSMC與CYUSB3014通信,3
    發(fā)表于 02-27 07:52

    求助,請問STM32FSMC可以配置大小端嗎?

    STM32FSMC可以配置大小端么。
    發(fā)表于 01-17 08:22

    請問如何配置STM32FSMC的大端模式小端模式?

    請問如何配置STM32FSMC的大端模式小端模式?還是硬件確定好了的不能修改?
    發(fā)表于 11-07 15:15