LCD有如下控制線:
CS:Chip Select 片選,低電平有效
RS:Register Select 寄存器選擇
WR:Write 寫信號,低電平有效
RD:Read 讀信號,低電平有效
RESET:重啟信號,低電平有效
DB0-DB15:數據線
假如這些線,全部用普通IO口控制。根據LCD控制芯片手冊(大部分控制芯片時序差不多):
如果情況如下:
DB0-DB15的IO全部為1(表示數據0xff),也可以為其他任意值,這里以0xff為例。
CS為0(表示選上芯片,CS拉低時,芯片對傳入的數據才會有效)
(:RS = 0時,表示讀寫寄存器;RS = 1表示讀寫數據RAM。)
WR為0,RD為1(表示是寫動作),反過來就是讀動作。
RESET一直為高,如果RESET為低,會導致芯片重啟。
這種情況,會導致一個值0xff被傳入芯片,被LCD控制芯片當作寫寄存器值去解析。LCD控制芯片收到DB0-15上的值之后,根據其他控制線的情況,它得出結論,這個0xff是用來設置寄存器的。一般情況下,LCD控制芯片會把傳入的寄存器值的高8位當做寄存器地址(因為芯片內部肯定不止一個寄存器),低8位當做真正的要賦給對應寄存器值。這樣,就完成了一個寫LCD控制芯片內部寄存器的時序。
如果上述情況不變,只將RS置低,那么得到的情況如下:LCD控制芯片會把DB0-15上的數據當做單純的數據值來處理。那么假如LCD處在畫圖狀態,這個傳入的值0xff,就會被顯示到對應的點上,0xffff就表示白色,那么對應的點就是白色。在這個數據值傳遞過來之前,程序肯定會通過設置寄存器值,告訴LCD控制芯片要寫的點的位置在哪里。
如果上述兩種情況都不變,分別把WR和RD的信號反過來(WR=1,RD=0),那么寫信號就會被變成讀信號。讀信號下,主控芯片需要去讀DB0-15的值,而LCD控制芯片就會去設置DB0-15的值,從而完成讀數據的時序。
讀寄存器的時序麻煩一點。第一步,先要將WR和RD都置低,主控芯片通過DB0-15傳入寄存器地址。第二步就和前面讀數據一樣,將WR置高,RD置低,讀出DB0-15的值即可。在這整個的過程中,RS一直為低。
好了,上面就是IO直接控制LCD的方法。假如放到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手冊)。
那么在硬件上面,我們需要做的,僅僅是MCU和LCD控制芯片的連接關系:
WE-WR,均為低電平有效
RD-RD,均為低電平有效
FSMC-D0-15接LCD DB0-15
連接好之后,讀寫時序都會被FSMC自動完成。但是還有一個很關鍵的問題,就是RS沒有接,CS沒有接。因為在FSMC里面,根本就沒有對應RS和CS的腳。怎么辦呢?這個時候,有一個好方法,就是用某一根地址線來接RS。比如我們選擇了A16這根地址線來接,那么當我們要寫寄存器的時候,我們需要RS,也就是A16置高。軟件中怎么做呢?也就是將FSMC要寫的地址改成0x60020000,如下:
*(volatile unsigned short int *)(0x60020000)=val;
這個時候,A16在執行其他FSMC的同時會被拉高,因為A0-A18要呈現出地址0x60020000。0x60020000里面的Bit17=1,就會導致A16為1。
當要讀數據時,地址由0x60020000改為了0x60000000,這個時候A16就為0了。
那么有朋友就會有疑問,第一,為什么地址是0x6xxxxxxx而不是0x0xxxxxxx;第二,CS怎么接;第三,為什么Bit17對應A16?
先來看前兩個問題,大家找到STM32的FSMC手冊,在FSMC手冊里面,我們很容易找到,FSMC將0x60000000-0x6fffffff的地址用作NOR/PRAM(共256M地址范圍)。而這個存儲塊,又被分成了四部分,每部分64M地址范圍。當對其中某個存儲塊進行讀寫時,對應的NEx就會置低。這里,就解決了我們兩個問題,第一,LCD的操作時序,和NOR/PRAM是一樣的(為什么一樣自己找找NOR/PRAM的時序看看),所以我們選擇0x6xxxxxxx這個地址范圍(選擇這個地址范圍,操作這個地址時,FSMC就會呈現出NOR/PRAM的時序)。第二,我們可以將NEx連接到LCD的CS,只要我們操作的地址是第一個存儲塊內即可(即0-0x3ffffff地址范圍)。
第三個問題再來看一看FSMC手冊關于存儲器字寬的描述,我們發現,當外部存儲器是16位時,硬件管腳A0-A24表示的是地址線A1-A25的值,所以我們要位移一下,Bit17的值,實際會被反應到A16這根IO來。關于數據寬度及位移的問題,初學的朋友可能會比較疑惑,當你接觸了多NOR/PRAM這樣的器件后,你會發現,很多芯片的總線,都是這樣設計的,為的是節省地址線。
PS:看到這里還是不明白,于是查了下手冊,有這么一個圖,大意是若外部設備的地址寬度是8位的,則HADDR[25:0]與STM32的CPU引腳FSMC_A[25:0]一一對應,最大可以訪問64M字節的空間。若外部設備的地址寬度是16位的,則是HADDR[25:1]與STM32的CPU引腳FSMC_A[24:0]一一對應。
HADDR | FSMC_A |
25 · · 1 | 24 · · 0 |
就是上圖這個意思,這里的HADDR是需要轉換到外部設備的內部AHB地址線,每個地址對應一個字節單元。所以我的理解是:上面出現的地址0x60020000,是工作于CPU內部的地址,體現在HADDR上面是17腳,但是轉換到硬件引腳上就是FSMC_A16腳了(因為從上圖看來,地址正好是差1,雖然HADDR的地址0并沒有,但是可以虛構一下,就當它有了,呵呵),與液晶屏的RS腳相連。
——純粹個人瞎理解,老是感覺再看的時候跟新的一樣,還是用自己的話記錄一下吧
那么上面就完全解決了LCD驅動如何接FSMC的問題,如果讀者沒懂,建議將上述文字抄上一遍,FSMC手冊對應NOR/PRAM的章節抄一遍。還沒懂,就繼續抄一遍,抄到懂為止。
雖然上述只是針對LCD講解了FSMC,但是其實對NOR和外部RAM的操作也是類似的,只不過多了些地址線來尋址而已。
上一篇:在線調試STM32 卡在LDR R0, = SystemInit_ExtMemCtl
下一篇:關于stm32的所有下載程序方法
推薦閱讀
史海拾趣
為了進一步提升品牌影響力和市場競爭力,驊訊積極尋求與知名品牌的合作。通過與音頻市場上的主要品牌建立合作關系,驊訊成功將其先進的音頻技術應用于各種音頻產品中,為消費者帶來了更為優質的音頻體驗。這種合作模式不僅促進了驊訊技術的推廣和應用,也為其帶來了更為廣闊的市場空間。
近年來,隨著科技的不斷進步和市場的不斷變化,驊訊公司也積極尋求創新轉型和拓展市場。在保持其在音頻芯片設計領域領先地位的同時,驊訊還積極開發新的業務領域,如軟件研發、數字內容供應等。這些創新舉措不僅為驊訊帶來了新的增長點,也為其在電子行業中保持領先地位提供了有力支持。
以上是關于驊訊(Cmedia)公司在電子行業中發展起來的相關故事簡要概述。這些故事展示了驊訊如何憑借其技術實力和市場洞察力在競爭激烈的電子行業中不斷發展壯大。
面對日益激烈的市場競爭,Connection One公司不斷推陳出新,研發出一系列創新產品。這些產品不僅性能卓越,而且設計新穎,深受消費者喜愛。公司因此贏得了大量忠實客戶,業績持續攀升。
為了進一步擴大市場份額和提升品牌影響力,Flambeau公司積極實施市場拓展戰略。公司不僅在北美市場深耕細作,還逐步將業務拓展到歐洲、亞洲等國際市場。通過參加國際展會、建立海外銷售渠道、與當地企業建立合作關系等方式,Flambeau成功地將自己的品牌和產品推向全球。同時,公司還注重品牌建設和客戶服務,通過提供優質的售前咨詢、售中支持和售后服務,贏得了廣大客戶的信賴和好評。
面對日益激烈的市場競爭,ERG始終堅持技術研發和創新。他們與多所知名大學和科研機構建立合作關系,共同研發新型電源技術和照明解決方案。這些合作不僅為ERG帶來了先進的技術和研發資源,還使其在行業中保持了技術領先地位。通過與科研機構的緊密合作,ERG不斷推出更具創新性和競爭力的產品。
寶士曼第三代半導體研發生產項目位于蘇州東山大道旁,占地50畝,計劃建設生產、研發、辦公等樓宇。項目整體將分二期建成,總建筑面積約70000平方米。已經封頂的4號樓建筑面積超11600平方米,主要用于第三代半導體器件專用封裝設備的研發生產。在施工過程中,寶士曼對環保和施工細節提出了更高的要求,要求地面每5平方米的高度誤差要小于3毫米,并在施工中做到“工完場清”,最大程度減少對今后生產的影響。這種對細節的嚴格要求體現了寶士曼對產品質量和環保責任的重視。
公司簡介 奧笙時代科技(北京)有限公司(www.orpheusys.com) 是成立于2007年的高科技企業,位于中關村腹地才智大廈,毗鄰北大、清華和中科院,本公司與中科院聲學研究所建立了戰略合作關系,依托聲學所在專業聲學設備、試驗場所、人 ...… 查看全部問答∨ |
|
FPGA在目前應用領域非常,在目前的單板設計里面,幾乎都可以看到它的身影。從簡單的邏輯組合,到高端的圖像、通信協議處理,從單片邏輯到復雜的ASIC原型驗證,從小家電到航天器,都可以看到FPGA應用,它的優點在這里無庸贅述。從個人實用角度看,對 ...… 查看全部問答∨ |
請教一下大家,我在用AT89S52和MAX485連接與計算機通訊,隔離電路圖如下,我主程序中讓單片機一直發送一個數據比如0x55,在接收中斷中讓單片機接收到數據后再把接收的數據發出來。但問題是單片機發出來的數據一直不對經常發FF,此時計算機發送任何 ...… 查看全部問答∨ |
AT91R40008是外掛到FPGA的,目前是為了創造一個網口掛接到FPGA上,方便從網口傳輸數據和FPGA交換。比較頭疼的AT91R40008是總線與FPGA交流,兩者是異步時鐘,經常有出現FPGA程序編譯后,AT91R40008工作不正常的問題?怎樣能徹底解決該問題?請高手支 ...… 查看全部問答∨ |
我最近做個超聲波檢測電路 但在超聲波的發射電路中出現了問題 我是參考http://www.vipcn.com/dianzijixie/ceshiceliang/328968_2.html 這個發射電路,但我用的是IRF840這個場效應管 R1為10K,C為0.01U,其他的都一樣 加入200V的高壓時 用示波器 ...… 查看全部問答∨ |
[img]http://b43.photo.store.qq.com/http_imgload.cgi?/rurl4_b=65eb643b9247d96aad2cb1643382905d899ecd1f97fe5bd6136434b1c3771b3759d363bd14945a81c89fcc246b8e930b72244e61fb1e6aeeda5a567cd5895c872543362ab4d4ff0f36ef6fa0fcded7cbbd68e686 ...… 查看全部問答∨ |
我們要做多路搶答器,我查了好多電路圖都用到了74LS273,但是我們沒有這塊芯片,只能代替,但是我不知道這個芯片的內部結構是由什么門組成的,所以請大俠們多多幫忙!!謝謝了!!… 查看全部問答∨ |