[導(dǎo)讀]本文在對(duì)該模塊進(jìn)行分析的基礎(chǔ)上給出了實(shí)現(xiàn)高速外部總線(xiàn)的方案,以及硬件連接和軟件底層通用接口,解決了QE128連接外部高速總線(xiàn)設(shè)備的問(wèn)題。
引 言
外部總線(xiàn)接口大都出現(xiàn)在功能和價(jià)格較高的高端微處理器中。例如,F(xiàn)reescale半導(dǎo)體公司生產(chǎn)的Coldfire和PowerPC微處理器,在低端的微控制器行列中,一般很少出現(xiàn),主要原因是微控制器一般內(nèi)部包含了Flash和SRAM,而不是像微處理器那樣需要外擴(kuò)大容量存儲(chǔ)器放置代碼和運(yùn)行程序。但是,微控制器也會(huì)遇到需要外擴(kuò)外部總線(xiàn)設(shè)備的情況,筆者在某項(xiàng)目中需要使用MCF51QE128(以下簡(jiǎn)稱(chēng)“QE128”)微控制器連接外部Flash存儲(chǔ)測(cè)試數(shù)據(jù),存取速度要求較高,因此無(wú)法使用串行接口的存儲(chǔ)器,只能使用具有地址線(xiàn)和數(shù)據(jù)線(xiàn)的Flash存儲(chǔ)器。
QE128是Freescale半導(dǎo)體公司推出的Flexis系列的首款產(chǎn)品,具有25 MHz的總線(xiàn)速度和多種外設(shè)模塊;還有一個(gè)特點(diǎn)是,其內(nèi)部包含了與其他微控制器不同的快速GPIO模塊。
1 設(shè)計(jì)思路
使用微控制器中通用I/O模塊模擬實(shí)現(xiàn)外部總線(xiàn)接口是一個(gè)比較好的方法,但目前微控制器中GPIO模塊一般僅包含8個(gè)I/O口,而大容量的存儲(chǔ)芯片一般的地址總線(xiàn)和數(shù)據(jù)總線(xiàn)都是16位或者更高位數(shù)的。這種情況下需要使用2個(gè)GPIO端口組合才能模擬,速度不高。
QE128微控制器中的快速GPIO模塊(RGPIO)是一個(gè)比較特殊的模塊。該模塊直接與處理器的32位內(nèi)部總線(xiàn)連接,支持字節(jié)、字和雙字的訪問(wèn),支持單周期、零等待的數(shù)據(jù)傳輸。這種特性與普通的GPIO有較大區(qū)別。區(qū)別的根本原因在于普通的GPIO模塊都是與微控制器內(nèi)部的從設(shè)備總線(xiàn)連接的。
實(shí)現(xiàn)的關(guān)鍵在于,如何使一個(gè)RGPIO模塊既可以作為地址總線(xiàn)使用,又可以作為數(shù)據(jù)總線(xiàn)使用。通過(guò)對(duì)總線(xiàn)的分析,所有的數(shù)據(jù)通信都由主設(shè)備發(fā)起,然后發(fā)送地址信號(hào),最后發(fā)送數(shù)據(jù)或接收總線(xiàn)數(shù)據(jù),這種操作是有先后順序的。基于這種分析,將RGPIO模塊分時(shí)復(fù)用便可解決此問(wèn)題。
使用QE128快速GPIO實(shí)現(xiàn)外部總線(xiàn)接口的設(shè)計(jì)示意圖如圖1所示。
RGPIO模塊的16個(gè)引腳連接外部設(shè)備的地址總線(xiàn)和數(shù)據(jù)總線(xiàn)(此處需要注意),各信號(hào)線(xiàn)的含義如表1所列。其中的GPIO表示微處理器中方向可以為輸出的通用輸入/輸出引腳。需要注意的是,RGPIO模塊的16個(gè)引腳是與兩個(gè)通用I/O模塊PORTC和PORTE復(fù)用的,所以在原理圖設(shè)計(jì)時(shí),用作控制信號(hào)的GPIO引腳應(yīng)選擇PORTC和PORTE端口之外的GPIO。另外,如果RGPIO需要內(nèi)部上拉,則需要設(shè)置PORTC和PORFE的內(nèi)部上拉寄存器。這一點(diǎn)在軟件設(shè)計(jì)中的外部總線(xiàn)接口初始化函數(shù)Exb_Init中有體現(xiàn)。
2 硬件連接實(shí)例
以Atmel公司的單電壓存儲(chǔ)器AT49LV1024A為例。AT49LV1024A存儲(chǔ)容量為128 KB(64K×16位),工作電壓為3.3 V,可以直接與QE128連接。AT49LV1024A的地址線(xiàn)和數(shù)據(jù)線(xiàn)寬度均為16位,控制信號(hào)包括芯片使能信號(hào)CE、輸出使能信號(hào)OE和寫(xiě)使能信號(hào)WE。
圖2為QE128與AT491LV1024A的硬件連接實(shí)例。在本實(shí)例中,鎖存器使用的是2片TI公司的8路D型鎖存器74HC373.2片74HC373的鎖存使能LE(Latch Enable)引腳相連,通過(guò)QE128的TE信號(hào)控制來(lái)選擇地址總線(xiàn)和數(shù)據(jù)總線(xiàn)。
地址/數(shù)據(jù)信號(hào)外的其他控制信號(hào)使用GPIO控制。本實(shí)例中使用PTF端口的4個(gè)引腳。
3 軟件設(shè)計(jì)
RGPIO模塊常用的寄存器共有以下6個(gè):數(shù)據(jù)方向寄存器RGPIO_DIR、數(shù)據(jù)寄存器RGPIO_DATA、引腳使能寄存器RGPIO_ENB、數(shù)據(jù)位清零寄存器RGPIO_CLR、數(shù)據(jù)位置位寄存器RGPIO_SET和數(shù)據(jù)位翻轉(zhuǎn)寄存器RGPIO_TOG。6個(gè)寄存器均為16位寄存器。其中前面3個(gè)寄存器是其他的GPIO口都具有的,后面3個(gè)寄存器是RGPIO模塊比較有特色的地方。這3個(gè)寄存器與數(shù)據(jù)寄存器RGPIO_DATA的每一位是對(duì)應(yīng)的,將RGPIO_CLR中某一位置為0,則相應(yīng)RGPIO_DATA的對(duì)應(yīng)位就會(huì)清零。類(lèi)似的,將RGPIO_SET或RGPIO_TOG的某一位置1,則會(huì)將RGPIO_DATA對(duì)應(yīng)位置1或反轉(zhuǎn)。相對(duì)于普通MCU中的讀取數(shù)據(jù)至累加器→置位→寫(xiě)入寄存器的操作。RGPIO可以減少操作的時(shí)間,具體比較詳見(jiàn)QE128參考手冊(cè)中RGPIO一章。
了解底層寄存器后,筆者對(duì)外部總線(xiàn)接口實(shí)現(xiàn)的底層函數(shù)做了通用性的封裝,共包括3個(gè)函數(shù):外部總線(xiàn)接口初始化函數(shù)void Exb_Init(void);外部總線(xiàn)寫(xiě)函數(shù)void Exb_QueuedWrite(word*pAddr,word*pData,bytenTransfer);外部總線(xiàn)讀函數(shù)void Exb_QueuedRead(word*pAddr,word*pData,byte nTransfer)。Exb_QueuedWrite函數(shù)進(jìn)行nTransfer次寫(xiě)操作,將數(shù)據(jù)數(shù)組中的數(shù)據(jù)寫(xiě)入地址數(shù)組中的地址。Exb_QueuedRead函數(shù)進(jìn)行nTransfer次讀操作,將地址數(shù)組中地址對(duì)應(yīng)的數(shù)據(jù)讀出放人數(shù)據(jù)數(shù)組中。其中Exb_Init函數(shù)代碼如下:
根據(jù)這3個(gè)通用底層接口函數(shù)便可以編寫(xiě)針對(duì)不同的外部設(shè)備的函數(shù)進(jìn)行操作。本文以對(duì)AT49LV1024A的Flash存儲(chǔ)器進(jìn)行數(shù)據(jù)寫(xiě)入和讀出操作為例,基本滿(mǎn)足常用功能的需要。具體的AT49LV1024A存儲(chǔ)器的命令序列請(qǐng)參考該芯片的技術(shù)手冊(cè)。
結(jié) 語(yǔ)
MCF51QE128微控制器的快速GPIO模塊是具有特色的一個(gè)模塊。本文在對(duì)該模塊進(jìn)行分析的基礎(chǔ)上給出了實(shí)現(xiàn)高速外部總線(xiàn)的方案,以及硬件連接和軟件底層通用接口,解決了QE128連接外部高速總線(xiàn)設(shè)備的問(wèn)題。
欲知詳情,請(qǐng)下載word文檔
下載文檔
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
本文中,小編將對(duì)無(wú)線(xiàn)模塊予以介紹,如果你想對(duì)無(wú)線(xiàn)模塊的詳細(xì)情況有所認(rèn)識(shí),或者想要增進(jìn)對(duì)它的了解程度,不妨請(qǐng)看以下內(nèi)容哦。
關(guān)鍵字:
無(wú)線(xiàn)模塊
寄存器
處理器
最經(jīng)典的2DFF 1-bit同步器如下,下圖結(jié)構(gòu)通常用于單bit控制信號(hào)的異步處理:
關(guān)鍵字:
異步電路
寄存器
GPIO全稱(chēng)General Purpose Input Output即通用輸入/輸出,其實(shí)GPIO的本質(zhì)就是芯片的一個(gè)引腳,通常在ARM中所有的I/O都是通用的。不過(guò)由于每個(gè)開(kāi)發(fā)板上都會(huì)設(shè)計(jì)不同的外圍電路,這就造成GPI...
關(guān)鍵字:
GPIO
芯片
單片機(jī)(Single-Chip Microcomputer)是一種集成電路芯片,是采用超大規(guī)模集成電路技術(shù)把具有數(shù)據(jù)處理能力的中央處理器CPU、隨機(jī)存儲(chǔ)器RAM、只讀存儲(chǔ)器ROM、多種I/O口和中斷系統(tǒng)、定時(shí)器/計(jì)數(shù)器等...
關(guān)鍵字:
單片機(jī)
寄存器
dsPIC33CH/dsPIC33CK系列數(shù)字電源控制器芯片,在目前諸多典型應(yīng)用中都得到了廣泛使用。在閉環(huán)控制中,尤其是電壓模式控制中,對(duì)PWM數(shù)據(jù)寄存器進(jìn)行實(shí)時(shí)更新是必要的一個(gè)動(dòng)作,本文主要就這一話(huà)題做一些分析和討論
關(guān)鍵字:
數(shù)字電源控制器
寄存器
中國(guó),北京 – 2022年5月5日 – Analog Devices, Inc.(Nasdaq:ADI)推出新一代16至24位超高精度逐次逼近寄存器(SAR)模數(shù)轉(zhuǎn)換器(ADC)系列產(chǎn)品,可簡(jiǎn)化儀器儀表、工業(yè)和醫(yī)療健康應(yīng)...
關(guān)鍵字:
ADI
模數(shù)轉(zhuǎn)換器
寄存器
星標(biāo)「嵌入式大雜燴」,一起進(jìn)步!鏈接:https://www.cnblogs.com/jozochen/p/8541714.html一、問(wèn)題復(fù)現(xiàn)穩(wěn)定復(fù)現(xiàn)問(wèn)題才能正確的對(duì)問(wèn)題進(jìn)行定位、解決以及驗(yàn)證。一般來(lái)說(shuō),越容易復(fù)現(xiàn)的問(wèn)...
關(guān)鍵字:
嵌入式開(kāi)發(fā)
函數(shù)
代碼
寄存器
文|周立功日期|2021年11月29日Z(yǔ)LG致遠(yuǎn)電子創(chuàng)始人周立功你用的mcu漲價(jià)了,這還不是最壞的結(jié)果。過(guò)去20多年里芯片漲價(jià),半年后基本上都會(huì)緩和下來(lái)。今年不一樣,接近年底了,還沒(méi)有任何跡象表明明年何時(shí)恢復(fù)供應(yīng),很多企...
關(guān)鍵字:
MCU
寄存器
軟件開(kāi)發(fā)
CK
Q:如果系統(tǒng)中的FPGA/微處理器上只剩下一個(gè)GPIO,該如何進(jìn)行模擬測(cè)量?A:可以使用電壓-頻率轉(zhuǎn)換器代替模數(shù)轉(zhuǎn)換器。在關(guān)注機(jī)器健康和其他物聯(lián)網(wǎng)(IoT)解決方案的現(xiàn)代應(yīng)用中,隨著檢測(cè)功能的日趨普及,對(duì)更簡(jiǎn)單的接口以及...
關(guān)鍵字:
GPIO
測(cè)量溫度
數(shù)字接口
ADC
時(shí)序邏輯電路其任一時(shí)刻的輸出不僅取決于該時(shí)刻的輸入,而且還與過(guò)去各時(shí)刻的輸入有關(guān)。常見(jiàn)的時(shí)序邏輯電路有觸發(fā)器、計(jì)數(shù)器、寄存器等。
關(guān)鍵字:
時(shí)序邏輯電路
寄存器
計(jì)數(shù)器
連接在總線(xiàn)上的設(shè)備與總線(xiàn)的連接電路稱(chēng)為總線(xiàn)接口。
關(guān)鍵字:
總線(xiàn)接口
PCI
PC
所謂64位的計(jì)算機(jī),就是指這臺(tái)計(jì)算機(jī)使用了64位的CPU,相比較32位的CPU來(lái)說(shuō),64位CPU最為明顯的變化就是增加了8個(gè)64位的通用寄存器,內(nèi)存尋址能力提高到64位,以及寄存器和指令指針升級(jí)到64位等?!睘榱颂幚頂?shù)據(jù)...
關(guān)鍵字:
32位
64位
寄存器
控制器(英文名稱(chēng):controller)是指按照預(yù)定順序改變主電路或控制電路的接線(xiàn)和改變電路中電阻值來(lái)控制電動(dòng)機(jī)的啟動(dòng)、調(diào)速、制動(dòng)和反向的主令裝置。由程序計(jì)數(shù)器、指令寄存器、指令譯碼器、時(shí)序產(chǎn)生器和操作控制器組成,它是發(fā)...
關(guān)鍵字:
控制器
寄存器
程序計(jì)數(shù)器
在計(jì)算機(jī)及其他計(jì)算系統(tǒng)中,寄存器是一種非常重要的、必不可少的數(shù)字電路苛件,它通常由觸發(fā)器(D觸發(fā)器)組成,主要作用是用來(lái)暫時(shí)存放數(shù)碼或指令。
關(guān)鍵字:
寄存器
程序計(jì)數(shù)器
IR
寄存器的功能是存儲(chǔ)二進(jìn)制代碼,它是由具有存儲(chǔ)功能的觸發(fā)器組合起來(lái)構(gòu)成的。一個(gè)觸發(fā)器可以存儲(chǔ)1位二進(jìn)制代碼,故存放n位二進(jìn)制代碼的寄存器,需用n個(gè)觸發(fā)器來(lái)構(gòu)成。按照功能的不同,可將寄存器分為基本寄存器和移位寄存器兩大類(lèi)。
關(guān)鍵字:
寄存器
二進(jìn)制
CPU
作?者:道哥,10年嵌入式開(kāi)發(fā)老兵,專(zhuān)注于:C/C、嵌入式、Linux。關(guān)注下方公眾號(hào),回復(fù)【書(shū)籍】,獲取Linux、嵌入式領(lǐng)域經(jīng)典書(shū)籍;回復(fù)【PDF】,獲取所有原創(chuàng)文章(PDF格式)。目錄示例程序目標(biāo)編寫(xiě)驅(qū)動(dòng)程序編寫(xiě)應(yīng)...
關(guān)鍵字:
GPIO
編寫(xiě)
驅(qū)動(dòng)程序
單片機(jī)的特殊功能寄存器SFR,是SRAM地址已經(jīng)確定的SRAM單元,在C語(yǔ)言環(huán)境下對(duì)其訪問(wèn)歸納起來(lái)有兩種方法。1采用標(biāo)準(zhǔn)C的強(qiáng)制類(lèi)型轉(zhuǎn)換和指針來(lái)實(shí)現(xiàn)采用標(biāo)準(zhǔn)C的強(qiáng)制轉(zhuǎn)換和指針的概念來(lái)實(shí)現(xiàn)訪問(wèn)MCU的寄存器,例如:#def...
關(guān)鍵字:
C語(yǔ)言
單片機(jī)
寄存器