新聞中心

        EEPW首頁 > 模擬技術 > 設計應用 > MCF51QE128快速GPIO的外部總線接口設計

        MCF51QE128快速GPIO的外部總線接口設計

        作者: 時間:2010-06-28 來源:網(wǎng)絡 收藏




        地址/數(shù)據(jù)信號外的其他控制信號使用控制。本實例中使用PTF端口的4個引腳。

        3 軟件設計

        R模塊常用的寄存器共有以下6個:數(shù)據(jù)方向寄存器R_DIR、數(shù)據(jù)寄存器RGPIO_DATA、引腳使能寄存器RGPIO_ENB、數(shù)據(jù)位清零寄存器RGPIO_CLR、數(shù)據(jù)位置位寄存器RGPIO_SET和數(shù)據(jù)位翻轉寄存器RGPIO_TOG。6個寄存器均為16位寄存器。其中前面3個寄存器是其他的GPIO口都具有的,后面3個寄存器是RGPIO模塊比較有特色的地方。這3個寄存器與數(shù)據(jù)寄存器RGPIO_DATA的每一位是對應的,將RGPIO_CLR中某一位置為0,則相應RGPIO_DATA的對應位就會清零。類似的,將RGPIO_SET或RGPIO_TOG的某一位置1,則會將RGPIO_DATA對應位置1或反轉。相對于普通MCU中的讀取數(shù)據(jù)至累加器→置位→寫入寄存器的操作。RGPIO可以減少操作的時間,具體比較詳見QE參考手冊中RGPIO一章。

        了解底層寄存器后,筆者對外部總線接口實現(xiàn)的底層函數(shù)做了通用性的封裝,共包括3個函數(shù):外部總線接口初始化函數(shù)void Exb_Init(void);外部總線寫函數(shù)void Exb_QueuedWrite(word*pAddr,word*pData,bytenTransfer);外部總線讀函數(shù)void Exb_QueuedRead(word*pAddr,word*pData,byte nTransfer)。Exb_QueuedWrite函數(shù)進行nTransfer次寫操作,將數(shù)據(jù)數(shù)組中的數(shù)據(jù)寫入地址數(shù)組中的地址。Exb_QueuedRead函數(shù)進行nTransfer次讀操作,將地址數(shù)組中地址對應的數(shù)據(jù)讀出放人數(shù)據(jù)數(shù)組中。其中Exb_Init函數(shù)代碼如下:



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



        結 語

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

        上一頁 1 2 下一頁

        關鍵詞: GPIO MCF 128 51

        評論


        相關推薦

        技術專區(qū)

        關閉
        主站蜘蛛池模板: 新和县| 定安县| 广平县| 文山县| 武宣县| 萍乡市| 泸州市| 青龙| 五寨县| 义马市| 宣汉县| 类乌齐县| 阿合奇县| 汾阳市| 五寨县| 高尔夫| 科尔| 柯坪县| 来宾市| 宿迁市| 南京市| 基隆市| 揭西县| 金门县| 博客| 蒙山县| 北川| 瑞昌市| 榆社县| 百色市| 白沙| 肥城市| 榆林市| 曲阳县| 信阳市| 天门市| 阳原县| 徐水县| 蛟河市| 昌图县| 武乡县|