引言
Cortex-M3是ARM公司推出的32位處理器,,使用了最新一代的ARMv7架構(gòu),,具有高性能、低功耗和低成本的優(yōu)點(diǎn),。對(duì)那些對(duì)功耗與成本敏感,、但又要求較高性能的嵌入式應(yīng)用來(lái)說(shuō),Correx-M3無(wú)疑是最佳解決方案,;而對(duì)成本要求苛刻,、運(yùn)算能力要求不高的設(shè)備來(lái)說(shuō),嵌入成熟穩(wěn)定的8051處理器,,已經(jīng)成為了業(yè)內(nèi)的流行做法,。目前,越來(lái)越多的嵌入式系統(tǒng)同時(shí)使用了上述兩種MCU,,因此如何使Cortex-M3與8051之間可以高效地進(jìn)行信息交互,,是實(shí)現(xiàn)設(shè)計(jì)目標(biāo)的關(guān)鍵。
1 方案設(shè)計(jì)
要進(jìn)行信息交互,,離不開(kāi)物理接口,。在嵌入式應(yīng)用中,目前常用的接口有UART,、SPI和I2C等串行接口,。UART接口只需兩根數(shù)據(jù)線就可以工作,時(shí)序控制簡(jiǎn)單,,大部分設(shè)備都整合了這種接口,。而且,經(jīng)過(guò)電平轉(zhuǎn)換后UART的TTL電平可以轉(zhuǎn)換成RS232電平,,RS232接口是計(jì)算機(jī)標(biāo)準(zhǔn)配置的通信接口,,可以通過(guò)超級(jí)終端查看串口的數(shù)據(jù),便于使用PC機(jī)對(duì)線路進(jìn)行檢測(cè)分析,。因此,,本設(shè)計(jì)采用UART接口作為Cortex-M3與C51之間的通信接口,。
考慮到各種需求,本文設(shè)計(jì)了一種基于UART接口的,,用于Cortex-M3和C51之間的通信協(xié)議,,使Cortex-M3與C51之間可以高效地進(jìn)行信息交互。當(dāng)兩個(gè)MCU之間需要進(jìn)行通信的時(shí)候,,發(fā)送方把原始數(shù)據(jù)下放給通信協(xié)議,,通信協(xié)議按照特定格式把數(shù)據(jù)打包,通過(guò)UART接口發(fā)送給對(duì)方,。接收方收到數(shù)據(jù)時(shí),,MCU運(yùn)行相應(yīng)的通信協(xié)議,把數(shù)據(jù)解包,,就可以得到發(fā)送方的原始數(shù)據(jù),,將其交付給上層程序。體系結(jié)構(gòu)如圖1所示,。
如果使用其他串行接口,,原理大體相同,只需對(duì)硬件作相應(yīng)改動(dòng),,即對(duì)接口控制模塊稍作修改即可投入使用,。
下面以實(shí)際工程中某種多媒體系統(tǒng)為例詳細(xì)說(shuō)明。該系統(tǒng)采用了以Cortex-M3為內(nèi)核的STM32處理器和嵌入了C51核的MST776視頻處理芯片,,使用UART接口進(jìn)行通信,。
2 具體實(shí)現(xiàn)
2.1 硬件設(shè)置
具體的器件不同,UART的工作方式也有所區(qū)別,,主要表現(xiàn)在波特率,、停止位,、數(shù)據(jù)字長(zhǎng)度等參數(shù)上,。當(dāng)兩個(gè)器件用UART連接時(shí),所有參數(shù)必須完全一致,,否則通信很容易出錯(cuò)。在此,,要特別注意波特率的設(shè)置:當(dāng)線路質(zhì)量好的時(shí)候,,波特率可以設(shè)置得高點(diǎn),以獲得較高的傳輸速率,;線路質(zhì)量差的時(shí)候,,就要減小波特率,以降低誤碼率,。
本設(shè)計(jì)中,,STM32與MST776都整合了UART接口,,只需配置少量電阻;同時(shí),,線纜長(zhǎng)度不超過(guò)20 cm,,使用環(huán)境的電磁干擾小,波特率可以設(shè)置為38 400bps,,甚至更高,。另外,考慮到C51的處理速度較低,,因此波特率不應(yīng)設(shè)置得太高,,避免造成C51側(cè)數(shù)據(jù)溢出,進(jìn)而造成死機(jī),。
本設(shè)計(jì)只需使用兩根數(shù)據(jù)線來(lái)實(shí)現(xiàn)兩個(gè)MCU之間的互連,,把STM32上選定的UART接口的TX與對(duì)端的UART接口的RX相連,把RX與對(duì)端的UART接口的TX相連,。
2.2 軟件設(shè)計(jì)
2.2.1數(shù)據(jù)幀解析
Cortex-M3側(cè)和C51側(cè)采用同樣的數(shù)據(jù)幀格式,,以簡(jiǎn)化編程的難度,增強(qiáng)程序的可移植性,。數(shù)據(jù)幀由起始標(biāo)識(shí)符,、數(shù)據(jù)長(zhǎng)度、類型ID,、通信內(nèi)容,、循環(huán)冗余校驗(yàn)碼構(gòu)成,如圖2所示,。
(1)起始標(biāo)識(shí)符
起始標(biāo)識(shí)符的作用主要是用于定界,,把不同的數(shù)據(jù)幀在一連串的數(shù)據(jù)中分離開(kāi)來(lái)。起始標(biāo)識(shí)符內(nèi)的數(shù)據(jù)不能與數(shù)據(jù)幀中可能出現(xiàn)的任何數(shù)據(jù)相同,,否則會(huì)引起歧義,,導(dǎo)致定界失敗,造成數(shù)據(jù)錯(cuò)誤,。在本例中,,為2個(gè)字節(jié),選用0xFF+0xAA,,因?yàn)樵摻M合與其他數(shù)據(jù)具有排他性,,不會(huì)引起歧義。
(2)數(shù)據(jù)長(zhǎng)度
數(shù)據(jù)長(zhǎng)度的計(jì)算方法為,,從該位開(kāi)始,,到最后一個(gè)數(shù)據(jù)位結(jié)束,也就是CRC校驗(yàn)位之前的一個(gè)字節(jié),。雖然使用Length位可以表示很長(zhǎng)的數(shù)據(jù)幀,,但在應(yīng)用中應(yīng)盡量采用短幀,,以避免各種干擾因素造成少數(shù)數(shù)據(jù)位出錯(cuò),導(dǎo)致大量數(shù)據(jù)無(wú)效,,影響通信效率,。同時(shí),應(yīng)該設(shè)置一個(gè)最大發(fā)送長(zhǎng)度,,以便設(shè)置超時(shí)重傳計(jì)時(shí)器的值,。本例采用1個(gè)字節(jié),最大幀長(zhǎng)為260個(gè)字節(jié),。
(3)類型ID
根據(jù)實(shí)際需要,,類型ID可以采用1個(gè)或多個(gè)字節(jié),用于表示該數(shù)據(jù)幀的作用類型,。本例中,,采用1個(gè)字節(jié),可以表示256種作用類型,,例如設(shè)備參數(shù)幀(如音量),、線路探測(cè)幀或應(yīng)答幀。
(4)通信內(nèi)容
通信內(nèi)容與類型ID結(jié)合,,表達(dá)特定意義,。相同的Data,但I(xiàn)D不同的話,,表達(dá)的信息不一樣,。根據(jù)不同的ID,Data的長(zhǎng)度可能會(huì)有所不同,。
(5)循環(huán)冗余校驗(yàn)碼
循環(huán)冗余校驗(yàn)碼用于校驗(yàn)接收到的數(shù)據(jù)是否在傳輸過(guò)程中出錯(cuò),。本例中采用CRC-16算法,占2個(gè)字節(jié),,對(duì)從起始標(biāo)識(shí)符開(kāi)始到最后一個(gè)通信內(nèi)容位的所有數(shù)據(jù)進(jìn)行運(yùn)算,,把得到的結(jié)果附在最后。
2.2.2 收發(fā)流程
發(fā)送流程:將要發(fā)送的數(shù)據(jù)添加起始標(biāo)識(shí)符和長(zhǎng)度后,,計(jì)算CRC-16校驗(yàn)碼,,附在最后,形成一個(gè)完整的數(shù)據(jù)幀,,然后通過(guò)UART發(fā)送出去,。發(fā)送完畢后啟動(dòng)超時(shí)重傳計(jì)時(shí)器。
接收流程:當(dāng)接收到一個(gè)字節(jié)的數(shù)據(jù)時(shí),,根據(jù)系統(tǒng)狀態(tài)采取不同的操作,。當(dāng)數(shù)據(jù)上交后,,上層程序根據(jù)類型ID和通信內(nèi)容來(lái)作出相應(yīng)的響應(yīng),。具體流程如圖3所示,。
2.2.3 線路檢測(cè)機(jī)制
雖然本例中的UART接口是一種有線通信,而且線纜長(zhǎng)度不超過(guò)20 cm,,但仍有可能出現(xiàn)插口松脫,、線纜銅芯斷裂等情況,造成線路中斷,。對(duì)于轉(zhuǎn)換成RS232電平的應(yīng)用,,雖然RS232的最大傳輸距離不超過(guò)15 m,但如果在惡劣的環(huán)境中使用,,仍無(wú)法完全避免線路發(fā)生中斷,。因
此,有效的線路檢測(cè)機(jī)制是必需的,。
本設(shè)計(jì)中,,當(dāng)本端系統(tǒng)狀態(tài)為Null時(shí),每間隔1 s就發(fā)送一個(gè)線路探測(cè)幀,,類型ID=0x00,,通信內(nèi)容=0x55。同時(shí),,如果本端在5 s內(nèi)收不到任何新數(shù)據(jù)或者線路探測(cè)幀,,則表明線路中斷,向上層程序發(fā)送線路中斷報(bào)告,。對(duì)于需要交互秒時(shí)間信息的應(yīng)用,,線路探測(cè)幀可以省略,只檢測(cè)秒時(shí)間信息就可以達(dá)到線路探測(cè)的目的,。
2.2.4 校正機(jī)制
因?yàn)榇型ㄐ牌毡榇嬖谡`碼的問(wèn)題,,因此簡(jiǎn)單有效的校正機(jī)制是必須的。由于采用的是點(diǎn)到點(diǎn)的串行接口,,數(shù)據(jù)幀都是按照發(fā)送的先后順序到達(dá)接收端,,不會(huì)出現(xiàn)后一幀比前一幀早到的情況,只需要采用CRC-16和簡(jiǎn)單的ARQ機(jī)制,,再加上超時(shí)重傳機(jī)制,,就可以提供高可靠的數(shù)據(jù)傳輸。
接收方收到一個(gè)完整的數(shù)據(jù)幀之后,,必須給發(fā)送方返回一個(gè)ACK幀,,該幀的類型ID=0xFF。通信內(nèi)容根據(jù)校驗(yàn)的結(jié)果有所不同:校驗(yàn)正確的,,Data=1,;校驗(yàn)失敗的,Data=0,。
發(fā)送方發(fā)送完一個(gè)完整的數(shù)據(jù)幀之后,,啟動(dòng)超時(shí)重傳計(jì)時(shí)器,。如果在計(jì)時(shí)器超時(shí)之前沒(méi)有收到ACK幀,或者收到的ACK幀的Data為0,,就重發(fā)上一個(gè)數(shù)據(jù)幀,;當(dāng)收到ACK幀之后,計(jì)時(shí)器歸零,。發(fā)送方只有在收到Data為1的ACK幀后,,才能發(fā)送下一個(gè)數(shù)據(jù)幀。當(dāng)連續(xù)超時(shí)5次時(shí),,表明線路中斷,,向上層程序發(fā)送線路中斷報(bào)告。
ACK幀和線路檢測(cè)幀無(wú)須應(yīng)答,。發(fā)送這兩種幀之后,,無(wú)須設(shè)置超時(shí)重傳計(jì)時(shí)器。
2.2.5 接口控制
接口控制主要管理UART接口的收發(fā),,在此采用中斷的方式來(lái)實(shí)現(xiàn),。若有數(shù)據(jù)需要發(fā)送,則必須等發(fā)送緩存為空時(shí),,才能把數(shù)據(jù)寫入到發(fā)送緩存,,否則會(huì)把舊的數(shù)據(jù)覆蓋掉,造成數(shù)據(jù)丟失,。當(dāng)數(shù)據(jù)寫入結(jié)束后,,產(chǎn)生一個(gè)發(fā)送中斷,通知MCU把數(shù)據(jù)通過(guò)UART接口發(fā)送出去,。當(dāng)收到一個(gè)數(shù)據(jù)時(shí),,UART產(chǎn)生一個(gè)中斷信號(hào),通知MCU把數(shù)據(jù)放入接收緩存,,保存完成后清除中斷信號(hào),,等待接收下一個(gè)數(shù)據(jù)。只需修改接口控制部
分,,就可以適用于不同的硬件接口,。
3 實(shí)驗(yàn)結(jié)果以及分析
為了驗(yàn)證本串行通信協(xié)議的有效性,連接STM32和MST776的UART接口,,在這兩個(gè)MCU上運(yùn)行本通信協(xié)議,,并在線纜上引出兩個(gè)探測(cè)點(diǎn),使用MAX232芯片進(jìn)行電平轉(zhuǎn)換,,然后接到PC機(jī)的RS232接口上,,進(jìn)行數(shù)據(jù)檢測(cè)。通過(guò)Windows的超級(jí)終端,可以在PC機(jī)上看到UART接口收發(fā)數(shù)據(jù)的狀況,。同時(shí),,通過(guò)JTAG接口可以看到通信協(xié)議向上層程序交付的數(shù)據(jù)。
實(shí)驗(yàn)結(jié)果表明,,本通信協(xié)議工作正常,收發(fā)數(shù)據(jù)正確,,校正機(jī)制和線路檢測(cè)機(jī)制都工作良好,。運(yùn)行本通信協(xié)議后,兩個(gè)MCU都沒(méi)有出現(xiàn)數(shù)據(jù)溢出,、死機(jī)等情況,。這表明本文設(shè)計(jì)的串口通信協(xié)議能夠?qū)崿F(xiàn)預(yù)期的功能,令Cortex-M3與C51之間可以有效地進(jìn)行信息交互,。
結(jié)語(yǔ)
本文基于Cortex-M3與C51之間的通信需求,,設(shè)計(jì)了一種基于數(shù)據(jù)幀的通信協(xié)議,使得兩個(gè)MCU間可以進(jìn)行有效的信息交互,。本設(shè)計(jì)已經(jīng)在某型多媒體系統(tǒng)上得到應(yīng)用,,使用效果很好,表現(xiàn)非常穩(wěn)定,。本設(shè)計(jì)具有良好的可移植性和通用性,,在另一個(gè)嵌入式項(xiàng)目中,經(jīng)過(guò)對(duì)程序的少量修改,,也在SPI接口上得到了應(yīng)用,。