《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計應(yīng)用 > 采用SPI接口實現(xiàn)雙DSP雙向通信和同步
采用SPI接口實現(xiàn)雙DSP雙向通信和同步
來源:微型機與應(yīng)用2010年第24期
王 杰,王小鵬,趙國輝
(蘭州交通大學(xué) 電子與信息工程學(xué)院,甘肅 蘭州730070)
摘要: 為了實現(xiàn)兩片TMS320F2812 DSP之間的雙向數(shù)據(jù)通信和同步,給出了運用TMS320F2812 DSP內(nèi)部集成的串行SPI外設(shè)接口模塊實現(xiàn)雙DSP控制器雙向數(shù)據(jù)通信和任務(wù)同步的硬件電路設(shè)計和軟件協(xié)議實現(xiàn)方案,經(jīng)過實驗驗證方案能滿足兩片DSP之間高效率、高可靠的雙向數(shù)據(jù)通信和任務(wù)同步,最后提出了在通信過程中出現(xiàn)故障的解決方案。成功解決了兩個DSP控制器的雙向數(shù)據(jù)通信和任務(wù)同步的問題。
關(guān)鍵詞: DSP SPI 雙向通信 同步 TMS320F2812
Abstract:
Key words :

摘  要: 為了實現(xiàn)兩片TMS320F2812 DSP之間的雙向數(shù)據(jù)通信和同步,給出了運用TMS320F2812 DSP內(nèi)部集成的串行SPI外設(shè)接口模塊實現(xiàn)雙DSP控制器雙向數(shù)據(jù)通信和任務(wù)同步的硬件電路設(shè)計和軟件協(xié)議實現(xiàn)方案,經(jīng)過實驗驗證方案能滿足兩片DSP之間高效率、高可靠的雙向數(shù)據(jù)通信和任務(wù)同步,最后提出了在通信過程中出現(xiàn)故障的解決方案。成功解決了兩個DSP控制器的雙向數(shù)據(jù)通信和任務(wù)同步的問題。
關(guān)鍵詞: DSP;SPI;雙向通信;同步

    在載人航天、無人機、火控雷達(dá)等尖端技術(shù)領(lǐng)域的作動系統(tǒng)中,常用雙控制器余度技術(shù)來提高系統(tǒng)的可靠性。兩個控制器之間就需要一種高效可靠的數(shù)據(jù)通信以保證在同一時間執(zhí)行相同的周期任務(wù)。利用SPI接口可以實現(xiàn)數(shù)據(jù)雙向通信,TMS320F2812 DSP芯片內(nèi)部集成了一個SPI模塊,方案提出了一種基于SPI通信接口的兩片DSP的雙向通信和任務(wù)同步,兩片DSP中固定一片作為SPI通信主機,另一片作為SPI通信從機[1],最后提出通信故障的解決辦法。
1 DSP SPI外設(shè)接口模塊和SPI通信原理
1.1 SPI外設(shè)接口模塊

    TMS320F2812 DSP芯片內(nèi)部集成了一個SPI模塊,其數(shù)據(jù)傳輸速率和字符長度是可編程的,最高傳輸速率可達(dá)10 Mb/s ,支持主/從模式通信[2]。SPI外設(shè)模塊和DSP CPU間的接口如圖1所示,包括4個外部引腳,采用低速外設(shè)時鐘LSPCLK作為時鐘源,具有兩個獨立的外設(shè)中斷請求信號(SPIINT/RXINT和TXINT),提供了12個寄存器實現(xiàn)SPI模塊的配置和控制。

    SPI之間的通信主要有以下4個外部引腳:
    SPISOMI:對于主設(shè)備,該引腳為數(shù)據(jù)輸入;對于從設(shè)備,該引腳為數(shù)據(jù)輸出;
    SPISIMO:對于主設(shè)備,該引腳為數(shù)據(jù)輸出;對于從設(shè)備,該引腳為數(shù)據(jù)輸入;
    SPISTE:主設(shè)備向從設(shè)備發(fā)送的使能引腳;
    SPICLK:SPI接口的串行時鐘引腳,由主設(shè)備向從設(shè)備提供同步時鐘。
1.2 SPI通信原理
    SPI接口可配置為兩種模式,分別為主控制模式和從控制模式。圖2給出了兩個控制器(主控制器和從控制器)之間采用SPI接口的連接關(guān)系。主控制器通過發(fā)出SPICLK信號來啟動數(shù)據(jù)傳輸,主從控制器能同時發(fā)送和接收數(shù)據(jù)。

    在主控制器模式下,SPI通過SPICLK引腳為整個串行通信網(wǎng)絡(luò)提供時鐘。此時,要發(fā)送的串行數(shù)據(jù)從引腳SPISIMO移出,并在引腳SPISOMI上接收數(shù)據(jù)。在系統(tǒng)應(yīng)用中,主控制器的引腳SPISTE用來控制從控制器的片選信號。在主設(shè)備與從設(shè)備之間進(jìn)行數(shù)據(jù)通信時,主設(shè)備將SPISTE置成低電平,使能從設(shè)備,此時,從設(shè)備的串行數(shù)據(jù)從SPISOMI 引腳移出,從SPISIMO引腳移入。當(dāng)數(shù)據(jù)傳輸完畢后,SPISTE引腳置為高電平。
    寫數(shù)據(jù)到SPIDAT或SPITXBUF,啟動SPISIMO引腳發(fā)送數(shù)據(jù),首先發(fā)送SPIDAT寄存器的最高有效位MSB,接收到的數(shù)據(jù)通過SPISOMI引腳移入SPIDAT的最低有效位LSB。當(dāng)傳輸完特定的數(shù)據(jù)位后,接收到的數(shù)據(jù)被存到SPIRXBUF寄存器中,以被讀取使用。當(dāng)設(shè)定數(shù)據(jù)長度不足16 bit時,SPIRXBUF寄存器中存放的接收數(shù)據(jù)采用右對齊格式;而發(fā)送數(shù)據(jù)則需要采用左對齊格式寫入寄存器SPIDAT或SPITXBUF[3]。圖3為SPI數(shù)據(jù)傳輸格式。

2 系統(tǒng)硬件接口設(shè)計
    系統(tǒng)采用TI公司TMS320F2812 DSP芯片作為控制器,利用SPI接口實現(xiàn)控制器數(shù)據(jù)通信和任務(wù)同步,即同一系統(tǒng)在同一時刻執(zhí)行相同的任務(wù)。其內(nèi)部集成一個SPI外設(shè)模塊,要實現(xiàn)SPI數(shù)據(jù)傳輸只需要配置幾個相應(yīng)寄存器即可。
    SPI的傳輸只能由主控制器發(fā)起,主控制為從控制器提供時鐘和使能信號。本設(shè)計利用DSP內(nèi)部集成外設(shè)模塊,當(dāng)主控制器發(fā)送數(shù)據(jù)時,通過SPISTE使能從控制器,繼而開始SPI的傳輸。如果在通信過程中,需要從控制器主動向主控制器發(fā)送數(shù)據(jù),只能采用主控制器發(fā)送偽數(shù)據(jù)的形式為從控制器提供時鐘和使能信號。
3 系統(tǒng)軟件設(shè)計
3.1 軟件實現(xiàn)的同步設(shè)計

    實現(xiàn)任務(wù)同步的主要思想是網(wǎng)絡(luò)通信中的應(yīng)答模式,具體流程圖如圖4所示。通信過程中,SPI有可能受到外界干擾導(dǎo)致數(shù)據(jù)傳輸錯誤,而同步過程又是一個死等過程,采用SPI的軟件復(fù)位可以解決這一問題,在通信過程中若發(fā)現(xiàn)接收不到正確ACK信號就進(jìn)行軟件復(fù)位重新開始發(fā)送,這種方法在實踐中得到了驗證,效果很好。

3.2 軟件通信協(xié)議設(shè)計
    基于SPI的通信有兩種情況:由SPI主方發(fā)起通信,以及由SPI的從方發(fā)起通信。本方案中,采用主動發(fā)送數(shù)據(jù),中斷接收數(shù)據(jù)。通過配置SPI寄存器,設(shè)置數(shù)據(jù)長度和通信速率,使能增強型FIFO發(fā)送和接收,采用7級中斷接收數(shù)據(jù),即每接收完7個數(shù)據(jù)后觸發(fā)一次中斷,可以從中斷中讀取SPIRXBUF里面的數(shù)據(jù)。由于SPI本身并未規(guī)定數(shù)據(jù)的開始和結(jié)束,在實際通信過程中,需要對主控制器和從控制器之間的通信做一個接口通信協(xié)議[4]。
    在設(shè)計中,采用包的方式發(fā)送數(shù)據(jù),在前面發(fā)送一個包頭,里面包含奇偶校驗(1 bit)、數(shù)據(jù)類型(8 bit)和包長(數(shù)據(jù)長度4 bit),在包的后面發(fā)送實際應(yīng)用數(shù)據(jù),實際數(shù)據(jù)的長度和類型可以根據(jù)包頭確定。圖5所示為包的數(shù)據(jù)幀結(jié)構(gòu)。

    在這種情況下,一次SPI的傳輸過程可描述如下:主控制器首先發(fā)送包頭,告知從控制器此次傳輸?shù)念愋鸵约皵?shù)據(jù)的長度。當(dāng)傳輸完7個數(shù)據(jù)后,進(jìn)行中斷接收,先判斷第一個字的奇偶校驗位,如果錯誤則進(jìn)行軟件復(fù)位,重新接收并判斷;若正確則對數(shù)據(jù)長度和數(shù)據(jù)類型進(jìn)行檢驗,按照規(guī)定的數(shù)據(jù)長度和數(shù)據(jù)類型讀取到特定的變量中,如果此次接收的數(shù)據(jù)類型沒有和規(guī)定數(shù)據(jù)類型對應(yīng)上,也認(rèn)為數(shù)據(jù)傳輸錯誤,進(jìn)行軟件復(fù)位,重新接收并判斷。主從都采取中斷接收數(shù)據(jù),主控制器采取主動發(fā)送,而從控制器是在產(chǎn)生中斷后,在中斷服務(wù)子程序里先讀取數(shù)據(jù)然后發(fā)送特定數(shù)據(jù),主從的接收模式判斷完全一樣。通信過程中,有時需要從控制器主動發(fā)送一組數(shù)據(jù),需要主控制器為從控制器提供時鐘和使能信號,從控制器才可以發(fā)送數(shù)據(jù),運用主控制器發(fā)送偽數(shù)據(jù)的方式可以解決這個問題。在軟件協(xié)議中,規(guī)定SPI第一個字(包頭)全零(0X0000)為偽數(shù)據(jù),當(dāng)包頭接收到偽數(shù)據(jù)時,不判斷奇偶校驗、數(shù)據(jù)長度和數(shù)據(jù)類型,直接丟棄。
3.3 通信故障處理方案
    實際應(yīng)用系統(tǒng),SPI的通信環(huán)境復(fù)雜,可能會影響SPI的傳輸,由于SPI 是一個串行數(shù)據(jù)的傳輸,一旦出現(xiàn)故障如果不加以排除就會影響到以后的數(shù)據(jù)傳輸,因此這個問題必須加以解決。這個方案中,根據(jù)奇偶校驗和數(shù)據(jù)類型的判斷可以發(fā)現(xiàn)SPI 通信是否出現(xiàn)故障,若判斷發(fā)現(xiàn)故障后要對故障進(jìn)行消除和隔離,以免影響以后數(shù)據(jù)傳輸。
    軟件可以實現(xiàn)故障消除和隔離,采用SPI的軟件復(fù)位功能,可以在判斷錯誤后,先進(jìn)行復(fù)位然后使能,可以通過設(shè)置SPI FIFO發(fā)送緩沖寄存器SPIFFTX中的SPIRST位進(jìn)行設(shè)置,寫0時復(fù)位SPI的發(fā)送和接收通道,但FIFO寄存器的配置保持不變,寫1時,SPI FIFO恢復(fù)發(fā)送和接收通道,不影響SPI寄存器配置。
4 實驗結(jié)果
    本方案中,DSP的主頻為120 MHz,采用SPI的低速時鐘30 MHz,數(shù)據(jù)的傳輸速率配置為7.5 Mb/s。測試結(jié)果表明,SPI能很好地滿足兩片DSP之間的高速通信。在實際的測試應(yīng)用中發(fā)現(xiàn),在正常情況下,SPI通信正常,沒有通信錯誤發(fā)生;但在外界的某些干擾下,就會出現(xiàn)通信錯誤,例如在DSP實際應(yīng)用系統(tǒng)中,用到DSP控制電機,當(dāng)電機換向運行或轉(zhuǎn)速比較高時就會影響SPI的傳輸,會出現(xiàn)數(shù)據(jù)傳輸錯誤,這時需進(jìn)行軟件復(fù)位。選擇7.5 Mb/s的通信速率是進(jìn)行多次對比設(shè)置的,如果速率低,出現(xiàn)錯誤的概率就大,系統(tǒng)不穩(wěn);若速率過快,會影響數(shù)據(jù)傳輸,丟失數(shù)據(jù)。
    SPI接口實現(xiàn)簡單、I/O資源占用少、傳輸速度快[5-6],從軟硬件方面解決了實際應(yīng)用系統(tǒng)中的SPI雙向數(shù)據(jù)傳輸、任務(wù)同步和SPI通信故障等問題,成功實現(xiàn)了兩片DSP之間的雙向通信,且用軟件代替硬件實現(xiàn)了任務(wù)同步,還對SPI通信故障提出解決方案??蛇\用于多控制器之間的高速數(shù)據(jù)傳輸和同步。
參考文獻(xiàn)
[1] 宋曄,蔡慧,趙榮祥,等.采用SPI接口實現(xiàn)TMS320F240 DSP之間的通信[J].機電工程,2005,22(5):31-33.
[2] TMS320F2810,TMS320F2812 digital signal processors data manual[Z],2003.
[3] TMS320F28x DSP serial peripheral interface(SPI) reference guide[Z],2003.
[4] 梁永明,羅漢文,黃建國,等.DSP嵌入式系統(tǒng)中SPI協(xié)議的一種實現(xiàn)方法[J].電子技術(shù),2004,31(11):15-17.
[5] 毛建權(quán),季曉勇.基于SPI的DSP與MCU雙向通信的設(shè)計與實現(xiàn)[J].科學(xué)技術(shù)與工程,2007,7(15):3191-3193.
[6] 孫麗明.TMS320F2812原理及其C語言程序開發(fā)[M].北京:清華大學(xué)出版社,2008.

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲美女av网站| 性欧美18~19sex高清播放| 欧美高清视频一区| 亚洲综合日韩在线| 亚洲国产日韩欧美一区二区三区| 在线亚洲国产精品网站| 亚洲缚视频在线观看| 国产欧美精品久久| 欧美日韩精品欧美日韩精品一| 久久久久久久激情视频| 亚洲尤物在线视频观看| 亚洲激情校园春色| 午夜影视日本亚洲欧洲精品| 在线看不卡av| 国产亚洲成av人在线观看导航| 欧美日韩视频在线| 欧美国产成人在线| 久久五月激情| 久久av资源网站| 国产美女搞久久| 亚洲美女视频| 性欧美8khd高清极品| 99热这里只有成人精品国产| 亚洲国产精品专区久久 | 久久人人爽人人爽| 先锋影音网一区二区| 亚洲一区二区三区免费视频| 99精品国产一区二区青青牛奶| 亚洲一区制服诱惑| 亚洲欧洲一区二区三区在线观看 | 欧美精品网站| 欧美精品成人| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久免费视频在线| 久久人人爽人人爽爽久久| 亚洲欧美日韩综合国产aⅴ| 亚洲一区二区三区国产| 在线中文字幕一区| 亚洲小说春色综合另类电影| 亚洲一级片在线观看| 日韩视频免费| 在线性视频日韩欧美| 亚洲视屏在线播放| 亚洲欧美国产不卡| 亚洲欧美成人精品| 欧美在线网址| 久久久久成人精品| 久久一区二区三区四区| 另类欧美日韩国产在线| 女同一区二区| 欧美精品一区二区三| 欧美日韩美女| 国产精品老牛| 国产日韩精品在线播放| 国产一区二区主播在线| 精品白丝av| 狠狠久久综合婷婷不卡| 亚洲国产精品久久久久秋霞不卡| 亚洲欧洲在线看| 一本色道久久综合精品竹菊| 亚洲图片在区色| 欧美一区二区三区四区在线观看| 久久国产精品久久精品国产| 亚洲激情视频| 亚洲午夜免费福利视频| 午夜精品影院在线观看| 欧美一级视频一区二区| 久久全国免费视频| 亚洲欧美日韩视频二区| 美女在线一区二区| 欧美日韩亚洲高清一区二区| 国产一二精品视频| 亚洲国产一区二区三区在线播| 最新亚洲一区| 亚洲免费精彩视频| 午夜国产一区| 亚洲狼人精品一区二区三区| 亚洲一二三四区| 久久精品人人做人人爽| 欧美福利视频在线| 国产精品久久久久久模特 | 国产日韩欧美自拍| 亚洲国产精品va在线观看黑人| 99国产精品久久久| 欧美一区二区三区精品| 99精品99| 久久精品毛片| 欧美日韩裸体免费视频| 国产婷婷色一区二区三区| 欧美日韩亚洲国产精品| 国产亚洲精品美女| 亚洲精品一二| 久久精品国亚洲| 在线亚洲美日韩| 久久一区精品| 国产精品盗摄久久久| 在线观看日韩av电影| 99天天综合性| 亚洲国产成人tv| 午夜宅男欧美| 欧美精品一区在线| 国产一区二区日韩精品| 99riav1国产精品视频| 久久激情视频免费观看| 亚洲女人av| 欧美国产欧美综合 | 91久久夜色精品国产九色| 亚洲欧美日韩精品久久久久| 亚洲精品一二三| 久久精品最新地址| 欧美视频一区二区在线观看| 在线看无码的免费网站| 午夜精彩视频在线观看不卡| 亚洲伦伦在线| 久久婷婷麻豆| 小嫩嫩精品导航| 欧美在线视频免费| 夜夜精品视频一区二区| 麻豆成人小视频| 国产欧美一区二区在线观看| 日韩一级精品视频在线观看| 亚洲二区在线视频| 欧美中日韩免费视频| 欧美日韩一区二区免费在线观看| 国产一区二区三区久久 | 一区二区国产日产| 亚洲日本精品国产第一区| 久久久久久国产精品一区| 国产精品一区二区久久久| 亚洲九九精品| 亚洲黄色高清| 久久久久一区| 国产欧美一区视频| 亚洲午夜在线| 亚洲欧美一级二级三级| 亚洲自拍偷拍色片视频| 国产精品男人爽免费视频1| 亚洲素人一区二区| 欧美一区激情| 激情成人av| 亚洲免费久久| 欧美日韩亚洲激情| 亚洲一区二区三区中文字幕在线 | 久久精品夜色噜噜亚洲a∨| 久久婷婷激情| 亚洲日本欧美| 亚洲一区精品视频| 国产欧美日韩三级| 亚洲国产精品久久| 欧美精品综合| 亚洲一区久久久| 久久久久久午夜| 亚洲国内自拍| 亚洲欧美国产视频| 国内外成人在线视频| 亚洲精品男同| 国产精品久久久久久超碰| 欧美亚洲日本网站| 老牛国产精品一区的观看方式| 亚洲国产欧美国产综合一区| 亚洲先锋成人| 欧美凹凸一区二区三区视频| 日韩一级黄色大片| 欧美专区在线观看一区| 激情丁香综合| 亚洲性夜色噜噜噜7777| 国户精品久久久久久久久久久不卡| 亚洲美女电影在线| 国产精品乱码人人做人人爱| 亚洲国产精品毛片| 欧美系列电影免费观看| 欧美在线免费| 欧美日韩精品久久久| 欧美一级艳片视频免费观看| 欧美激情精品久久久久久变态| 亚洲一区二区三区免费视频| 麻豆freexxxx性91精品| 一区二区三区四区五区精品视频| 久久人人看视频| 制服诱惑一区二区| 免费成人网www| 亚洲一区影院| 欧美乱妇高清无乱码| 欧美一区二区三区在线观看| 欧美日韩色婷婷| 亚洲国产精品va在看黑人| 国产精品久久久久久久久婷婷 | 久久精彩视频| 亚洲麻豆视频| 久久这里有精品15一区二区三区| av成人老司机| 欧美.com| 欧美伊人久久| 国产精品久久久久久av福利软件| 亚洲精品一区中文| 国模私拍视频一区| 午夜精彩视频在线观看不卡 | 久久资源在线| 亚洲在线视频一区| 欧美日韩午夜在线|