娇小w搡bbbb搡bbb,《第一次の人妻》,中国成熟妇女毛茸茸,边啃奶头边躁狠狠躁视频免费观看

歷史上的今天

今天是:2024年10月06日(星期日)

2018年10月06日 | STM32之FSMC用法詳解

發布者:婉如Chanel 來源: eefocus關鍵字:STM32  FSMC用法 手機看文章 掃描二維碼
隨時隨地手機看文章

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  FSMC用法 引用地址:STM32之FSMC用法詳解

上一篇:在線調試STM32 卡在LDR R0, = SystemInit_ExtMemCtl
下一篇:關于stm32的所有下載程序方法

推薦閱讀

當我們在使用外部中斷的時候 STM32基本每一個io口都可以當外部中斷使用,在設置中斷優先級的時候有個很模糊的地方容易出錯 這里我說一下  定義中斷口的代碼我略過,這里假設使用的是PG8口做外部中斷,EXTI8線   NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);  NVIC_config.NVIC_IRQChannel=EXTI9_5_IRQn;  NVIC_config.NVIC_IRQChannelPree...
一、總部 1.國網辦公廳、國網董辦 2.國網總師辦 3.國網研究室 4.國網發展部 5.國網財務部 6.國網安監部 7.國網設備部 8.國網營銷部、國網農電部 9.國網科技部、國網聯辦 10.國網基建部 11.國網特高壓部 12.國網水新部 13.國網互聯網部 14.國網物資部 15.國網產業部 16.國網宣傳部、國網外聯部 17.國網國際部 18.國網...
  工業機器人目前在工業中逐漸適用,工業機器人將代替人工重復性勞動。現實中,更多工廠均采用進口工業機器人,那國產工業機器人與其到底有何差距呢?此外,目前工業機器人又有何應用呢?本文將揭露這些問題的答案。如果你對本文具有興趣,不妨繼續往下閱讀哦。   一、國內外工業機器人差距分析   在我國工業機器人市場的需求一直在持續增長,但...
來源:學習軍團·解放軍新聞傳播中心融媒體作者:解放軍報記者 韓 成 通訊員 于 晨“機器人技術正在深刻改變著人類的生產和生活方式,中國空間站機械臂也助力我們完成了兩次出艙任務。”9月中旬,在北京亦莊開幕的2021世界機器人大會上,神舟十二號飛行乘組3位航天員聶海勝、劉伯明、湯洪波從中國空間站傳來“太空點贊”。被表揚的主角,是我國自主研...

史海拾趣

問答坊 | AI 解惑

創業故事

本人創業10年,9死1生,占過便宜吃過虧,辛苦過也懶惰過,看到這個論壇里面充斥著大量的沒有創業經驗的人在指導別人創業,另有大量由于缺乏思路賠光家底的故事,本人非常痛心,本著救人加吹牛的心態特將本人獨家秘籍和盤托出,以免大家少走彎路.    ...…

查看全部問答∨

奧笙公司軟件部門招聘信息(北京職位)

公司簡介    奧笙時代科技(北京)有限公司(www.orpheusys.com) 是成立于2007年的高科技企業,位于中關村腹地才智大廈,毗鄰北大、清華和中科院,本公司與中科院聲學研究所建立了戰略合作關系,依托聲學所在專業聲學設備、試驗場所、人 ...…

查看全部問答∨

FPGA學習步驟,我的體會

FPGA在目前應用領域非常,在目前的單板設計里面,幾乎都可以看到它的身影。從簡單的邏輯組合,到高端的圖像、通信協議處理,從單片邏輯到復雜的ASIC原型驗證,從小家電到航天器,都可以看到FPGA應用,它的優點在這里無庸贅述。從個人實用角度看,對 ...…

查看全部問答∨

關于51單片機通訊問題

請教一下大家,我在用AT89S52和MAX485連接與計算機通訊,隔離電路圖如下,我主程序中讓單片機一直發送一個數據比如0x55,在接收中斷中讓單片機接收到數據后再把接收的數據發出來。但問題是單片機發出來的數據一直不對經常發FF,此時計算機發送任何 ...…

查看全部問答∨

【ATMEL 問題】AT91R40008工作不正常

AT91R40008是外掛到FPGA的,目前是為了創造一個網口掛接到FPGA上,方便從網口傳輸數據和FPGA交換。比較頭疼的AT91R40008是總線與FPGA交流,兩者是異步時鐘,經常有出現FPGA程序編譯后,AT91R40008工作不正常的問題?怎樣能徹底解決該問題?請高手支 ...…

查看全部問答∨

關于超聲波發射電路中地線出現振蕩問題,尋求高手解決

我最近做個超聲波檢測電路 但在超聲波的發射電路中出現了問題 我是參考http://www.vipcn.com/dianzijixie/ceshiceliang/328968_2.html 這個發射電路,但我用的是IRF840這個場效應管 R1為10K,C為0.01U,其他的都一樣 加入200V的高壓時 用示波器 ...…

查看全部問答∨

AD620運放調零 求助 5腳電壓為什么不穩定...

[img]http://b43.photo.store.qq.com/http_imgload.cgi?/rurl4_b=65eb643b9247d96aad2cb1643382905d899ecd1f97fe5bd6136434b1c3771b3759d363bd14945a81c89fcc246b8e930b72244e61fb1e6aeeda5a567cd5895c872543362ab4d4ff0f36ef6fa0fcded7cbbd68e686 ...…

查看全部問答∨

74LS273的內部結構

我們要做多路搶答器,我查了好多電路圖都用到了74LS273,但是我們沒有這塊芯片,只能代替,但是我不知道這個芯片的內部結構是由什么門組成的,所以請大俠們多多幫忙!!謝謝了!!…

查看全部問答∨

一個硬盤當多個用的控制芯片

工廠測試主板的SATA接口 有沒有什么芯片或者程序可以實現一個硬盤轉成多個接口.將主板上的多個SATA都能測試到. …

查看全部問答∨

8259A級聯的初始化流程圖

利用8259A擴展PC機的中斷功能,使其在IRQ2上擴展8個中斷輸入,初始化流程圖怎么畫呢? 一片的知道怎么化,兩片級聯就不太清楚了. …

查看全部問答∨
小廣播
設計資源 培訓 開發板 精華推薦

最新單片機文章
何立民專欄 單片機及嵌入式寶典

北京航空航天大學教授,20余年來致力于單片機與嵌入式系統推廣工作。

 
EEWorld訂閱號

 
EEWorld服務號

 
汽車開發圈

 
機器人開發圈

電子工程世界版權所有 京ICP證060456號 京ICP備10001474號-1 電信業務審批[2006]字第258號函 京公網安備 11010802033920號 Copyright ? 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
主站蜘蛛池模板: 土默特右旗| 诸城市| 巴里| 来凤县| 长岭县| 方城县| 肇州县| 孝义市| 乐业县| 东城区| 桂平市| 新闻| 阜阳市| 台湾省| 宿州市| 莱西市| 清涧县| 甘肃省| 阳泉市| 临颍县| 皋兰县| 贵州省| 唐山市| 桦川县| 永城市| 武宁县| 平武县| 疏附县| 平顺县| 收藏| 五寨县| 都安| 密云县| 临潭县| 手游| 昌吉市| 威信县| 临沧市| 綦江县| 安龙县| 禄丰县|