新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > DSP與51單片機的一種高速通信實現方案

        DSP與51單片機的一種高速通信實現方案

        作者: 時間:2011-11-05 來源:網絡 收藏

          下面討論一下89C52對雙口RAM的讀寫過程。當89C52對雙口RAM進行讀數據時,由圖3可知此時A0應為低電平,不妨假設地址為0x1000h,則存儲在雙口RAM中該地址處的16位數據同時被讀出,由于高8位數據線與89C52的8位數據線直接相連,所以高8位數據被立即讀入89C52中。同時,根據圖3中各信號的相互邏輯關系不難判斷,U3的使能信號LE有效(高電平),OE無效(低電平),因而低8位數據被送入U3 中鎖存起來。接著89C52再進行一次讀操作,這時地址變為0x1001h,由于A0變成高電平,雙口RAM的讀使能信號變成無效電平,所以此次讀操作對雙口RAM不產生影響。再來看U3的使能信號LE和OE的變化情況,顯然LE變成了無效電平,而OE變成了有效電平,上次被鎖存的數據(即雙口RAM的低8位數據)被送入89C52。當89C52對雙口RAM進行寫入操作時,注意此時A0應為高電平,不妨假設地址為0x100Ch,同樣可根據圖3判斷U2的使能信號LE和OE均為有效電平,因而數據被同時寫入雙口RAM中(即此時雙口RAM的高8位數據和低8位相同);接著89C52再進行一次寫操作,此時地址變為0x100Dh,由于A0變成低電平,U2的片選為無效電平,U2被封鎖,數據寫入雙口RAM的高8位。從上面的分析可知,利用最低地址位A0的不同電平,89C52通過兩次連續的讀或寫操作,成功地實現了對雙口RAM中數據的讀或寫,只不過是讀入時是先讀入高8位,后讀入低8位;而寫入則是先寫入低8位,后寫入高8位。

        4 軟件實現方案
          雙口RAM必須采用一定的機制來協調左右兩邊CPU對它的讀寫操作,否則會出現讀寫數據的錯誤。通常可以用中斷、硬件、令牌和軟件這四種方式來協調雙方,本文采用的是軟件方式。從上面的分析中我們可以得知,在接口電路中實際上已經利用89C52的最低地址位A0把雙口RAM的存儲空間分為奇、偶地址兩個空間。其中,奇地址空間專供89C52寫,偶地址空間專供89C52讀。那么我們只需對TMS320C32的軟件作相應處理即可,也就是說,TMS320C32對雙口RAM的奇地址空間只讀,對偶地址空間只寫。這樣就避免了TMS320C32和89C52對雙口RAM同一地址單元的寫入操作。另外,在對雙口RAM進行訪問之前,CPU首先對本端的BUSY信號進行查詢,只有本端/BUSY信號無效時才進行讀寫操作,進一步保證了數據讀寫的可靠性。


        5 結束語
          通過雙口RAM實現雙CPU之間的數據通信,極大地提高了數據傳輸速度和可靠性,滿足了控制系統的實時、高速的控制要求。本文所設計的89C52與雙口RAM之間的接口電路簡單實用,成功解決了它們總線匹配的問題,對其他類似需要總線擴展的系統也有一定的參考價值。


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 赣榆县| 沅江市| 清苑县| 松原市| 永和县| 遵义县| 鹤岗市| 赫章县| 荃湾区| 内乡县| 南江县| 大关县| 黔南| 武强县| 淮北市| 桐乡市| 山阴县| 兴和县| 奇台县| 北辰区| 元阳县| 县级市| 新余市| 会昌县| 黔南| 永胜县| 泰来县| 闸北区| 宁强县| 阿城市| 四平市| 沙洋县| 镶黄旗| 大埔县| 且末县| 宁都县| 抚州市| 罗田县| 曲阜市| 伽师县| 扎囊县|