<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          關(guān) 閉

          新聞中心

          EEPW首頁 > 工控自動(dòng)化 > 設(shè)計(jì)應(yīng)用 > MCF51QEl28快速GPIO的外部總線接口設(shè)計(jì)

          MCF51QEl28快速GPIO的外部總線接口設(shè)計(jì)

          作者: 時(shí)間:2010-06-25 來源:網(wǎng)絡(luò) 收藏


          圖2為QEl28與AT49LVl024A的硬件連接實(shí)例。在本實(shí)例中,鎖存器使用的是2片TI公司的8路D型鎖存器74HC373.2片74HC373的鎖存使能LE(Latch Enable)引腳相連,通過QEl28的信號(hào)控制來選擇地址和數(shù)據(jù)。地址/數(shù)據(jù)信號(hào)外的其他控制信號(hào)使用控制。本實(shí)例中使用PTF端口的4個(gè)引腳。

          3 軟件
          R模塊常用的寄存器共有以下6個(gè):數(shù)據(jù)方向寄存器R_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ì)清零。類似的,將RGPIO_SET或RGPIO_TOG的某一位置1,則會(huì)將RGPIO_DATA對(duì)應(yīng)位置1或反轉(zhuǎn)。相對(duì)于普通MCU中的讀取數(shù)據(jù)至累加器→置位→寫入寄存器的操作。RGPIO可以減少操作的時(shí)間,具體比較詳見QEl28參考手冊(cè)中RGPIO一章。
          了解底層寄存器后,筆者對(duì)實(shí)現(xiàn)的底層函數(shù)做了通用性的封裝,共包括3個(gè)函數(shù):總線初始化函數(shù)void Exb_Ink(void);總線寫函數(shù)void Exb QueuedWrite(word * pAddr,word * pData,byte nTransfer);外部總線讀函數(shù)void Exb_QueuedRead(word * DAddr,word * pData,byte nTransfer)。Exb_Queued-Write函數(shù)進(jìn)行nTransfer次寫操作,將數(shù)據(jù)數(shù)組中的數(shù)據(jù)寫入地址數(shù)組中的地址。 Exb_QueuedRead函數(shù)進(jìn)行nTransfer次讀操作,將地址數(shù)組中地址對(duì)應(yīng)的數(shù)據(jù)讀出放入數(shù)據(jù)數(shù)組中。其中Exb_Init函數(shù)代碼如下:

          根據(jù)這3個(gè)通用底層函數(shù)便可以編寫針對(duì)不同的外部設(shè)備的函數(shù)進(jìn)行操作。本文以對(duì)AT49LVl024A的FIash存儲(chǔ)器進(jìn)行數(shù)據(jù)寫入和讀出操作為例,基本滿足常用功能的需要。具體的AT49LVl024A存儲(chǔ)器的命令序列請(qǐng)參考該芯片的技術(shù)手冊(cè)。

          結(jié)語
          微控制器的GPIO模塊是具有特色的一個(gè)模塊。本文在對(duì)該模塊進(jìn)行分析的基礎(chǔ)上給出了實(shí)現(xiàn)高速外部總線的方案,以及硬件連接和軟件底層通用接口,解決了QEl28連接外部高速總線設(shè)備的問題。


          上一頁 1 2 下一頁

          評(píng)論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();