0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

三種常見嵌入式設(shè)備通信協(xié)議

Q4MP_gh_c472c21 ? 2018-03-06 10:06 ? 次閱讀

嵌入式設(shè)備與PC通訊的通信協(xié)議設(shè)計經(jīng)驗

嵌入式設(shè)備在運行中需要設(shè)置參數(shù),這個工作經(jīng)常由PC機來實現(xiàn),需要為雙方通信設(shè)計協(xié)議,有代表性協(xié)議是如下三種:

表1 三種常見通信協(xié)議

從上表可以看到,一般嵌入式設(shè)備內(nèi)存和運算性能都有限,因此固定二進制是首選通信協(xié)議。

一. 簡單性

保證協(xié)議是一個簡單的方案,晦澀難懂往往意味著實現(xiàn)困難和容易出錯。協(xié)議的結(jié)構(gòu)宜采用平面方式,每個域作用明確,數(shù)據(jù)域盡可能設(shè)計得長度和位置固定,注釋詳盡,文檔清晰,實例豐富,讓人盡快上手和理解。

協(xié)議一般都需要以下域:幀頭,長度,幀類型,目標(biāo)地址,源地址,數(shù)據(jù),校驗,幀尾。

二. 可擴展

必須保證將來增加功能和更改硬件后協(xié)議仍能勝任工作,這往往是通過預(yù)留空間來實現(xiàn),協(xié)議的變更應(yīng)該只是量的增加,不至于引起協(xié)議結(jié)構(gòu)的變化。

三. 低耦合

理想情況下每個協(xié)議包是原子信息,即本協(xié)議包不與其他協(xié)議包牽連,以防止通訊丟幀和設(shè)置牽連帶來的錯誤。

四. 穩(wěn)定性

協(xié)議包長度適宜:太小包含的信息過少,協(xié)議包的種類繁多,容易引起通訊混亂和牽連錯誤;太大包含的信息過多,可讀性較差,組幀和解幀的工作困難,還會帶來通訊易受干擾的缺陷,一般協(xié)議長度以最小原子性信息為標(biāo)尺。

協(xié)議必須包括校驗機制,以便于接收方判別協(xié)議包正確完整接收,如果出錯需要較好的機制來確保通訊成功(如重傳)。

五. 高效率

按信息類型區(qū)分協(xié)議包類別,如:設(shè)置網(wǎng)絡(luò)信息參數(shù),設(shè)置當(dāng)前運行參數(shù),可以區(qū)分開來,方便程序處理。

將同種操作編碼為一個子集是一種高效手段,如Read操作,編碼為0x0010,Write操作,編碼為0x0020。

數(shù)據(jù)盡可能設(shè)計成同構(gòu)模式,如果實在有差異,至少將同類型數(shù)據(jù)放置在一起,這樣程序可以充分利用指針和線性尋址加速處理。

六. 易實現(xiàn)

盡量減少復(fù)雜算法的使用,如,通訊鏈路穩(wěn)定,數(shù)據(jù)幀的校驗碼可以由CheckSum代替CRC。除非資源非常緊張,否則不要將過多的信息擠壓在一個數(shù)據(jù)里,因為它會帶來可讀性差和實現(xiàn)困難。

七.軟件開發(fā)

盡可能地讓硬件ISR完成驅(qū)動工作,不要讓“進程”參與復(fù)雜的時序邏輯,否則處理器將步履蹣跚且邏輯復(fù)雜!如:

接收固定長度的數(shù)據(jù)幀,可以使用DMA,每接收完一幀DMA_ISR向進程發(fā)消息。小心處理DMA斷層異常(接收的數(shù)據(jù)幀長度正常但數(shù)據(jù)錯誤,數(shù)據(jù)為上幀的后半部分+本幀的前半部分)。

接收不定長的數(shù)據(jù)幀,可以使用狀態(tài)機,當(dāng)接收到“幀尾數(shù)據(jù)”時向進程發(fā)消息。小心數(shù)據(jù)紊亂和超時異常(數(shù)據(jù)紊亂時需要將狀態(tài)機及時復(fù)位,超時一般使用定時器監(jiān)控)。

八. 考慮硬件

如果通信鏈路是高速總線(如SPORT可達(dá)100Mbps),一般設(shè)計成一幀產(chǎn)生一次中斷,它通過長度觸發(fā)的DMA來實現(xiàn),需要將協(xié)議設(shè)計成固定長度,如附錄A。它具備高效率,但靈活性較差。

如果通信鏈路是低速總線(如UART一般100kbps),一般接收一字節(jié)產(chǎn)生一次中斷,可以將協(xié)議設(shè)計成變長幀,如附錄B。它具備高靈活性,但效率較低。

附錄A 一個基于DMA傳輸固定長度的協(xié)議實例。

圖1顯示了PC發(fā)送數(shù)據(jù)幀的格式,總長為64字節(jié),是4字節(jié)的整倍數(shù),符合絕大部分32位處理器結(jié)構(gòu)體對齊的特性。

0x3C:INT8U,幀頭,可見字符’<’

Len:INT8U,本幀的總數(shù)據(jù)長度,在圖4即為64

Dst:INT8U,標(biāo)識目標(biāo)設(shè)備的ID號

Src:INT8U,標(biāo)識源設(shè)備的ID號

Data:56字節(jié)的存儲區(qū),內(nèi)容依賴于具體的通信幀(實例見表2)

Cmd:INT16U,數(shù)據(jù)幀的類別

CS:INT8U, 對它前面所有數(shù)據(jù)(62字節(jié))進行8位累加和校驗

0x7D:INT8U, 幀尾,可見字符’}’

圖1 PC發(fā)送數(shù)據(jù)幀

表2 Data域數(shù)據(jù)結(jié)構(gòu)實例

附錄B 一個基于變長格式的UART通信協(xié)議實例。

PC與iWL880A(一種無線通信產(chǎn)品,詳見www.rimelink.com)通信幀采用變長格式,如下圖所示。大部分設(shè)備(常見為PC機)對于接收以“回車符”的機制很好處理,協(xié)議中的Tail就等于0x0D(換行符)。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5059

    文章

    18973

    瀏覽量

    302033
  • 通信協(xié)議
    +關(guān)注

    關(guān)注

    28

    文章

    840

    瀏覽量

    40215

原文標(biāo)題:嵌入式設(shè)備與PC通訊的通信協(xié)議設(shè)計經(jīng)驗

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    PROFINET通信協(xié)議是什么

    PROFINET通信協(xié)議是一專為工業(yè)自動化領(lǐng)域設(shè)計的基于以太網(wǎng)的實時通信協(xié)議。以下是對PROFINET通信協(xié)議的詳細(xì)解析,包括其定義、特點、體系結(jié)構(gòu)、工作原理、
    的頭像 發(fā)表于 09-25 18:13 ?785次閱讀

    SPI通信協(xié)議的基本概念和工作模式

    接口設(shè)計,在嵌入式系統(tǒng)、微控制器與各種外圍設(shè)備之間的通信中占據(jù)重要地位。以下是對SPI通信協(xié)議的詳細(xì)解析,內(nèi)容涵蓋其基本概念、通信原理、信號
    的頭像 發(fā)表于 09-09 17:04 ?787次閱讀

    簡單認(rèn)識UART通信協(xié)議

    UART(Universal Asynchronous Receiver/Transmitter,通用異步收發(fā)傳輸器)通信協(xié)議是一常見的串行通信協(xié)議,廣泛應(yīng)用于計算機、
    的頭像 發(fā)表于 07-25 18:07 ?1287次閱讀

    嵌入式系統(tǒng)怎么學(xué)?

    操作系統(tǒng)的基本概念和原理,掌握常見的RTOS,如FreeRTOS、uC/OS等,以實現(xiàn)對嵌入式系統(tǒng)的任務(wù)調(diào)度和資源管理。 6、通信協(xié)議:學(xué)習(xí)常用的通信協(xié)議,如UART、SPI、I2C
    發(fā)表于 07-02 10:10

    plc常見三種通訊協(xié)議有哪些

    這一目標(biāo),PLC采用了多種通信協(xié)議。以下是三種常見的PLC通信協(xié)議的詳細(xì)介紹: Modbus協(xié)議 Modbus
    的頭像 發(fā)表于 07-01 10:12 ?1954次閱讀

    簡單認(rèn)識UART串行通信協(xié)議

    在電子通信領(lǐng)域,UART(Universal Asynchronous Receiver/Transmitter,通用異步收發(fā)傳輸器)是一非常常見的串行通信協(xié)議。它被廣泛應(yīng)用于各種
    的頭像 發(fā)表于 05-27 16:09 ?1903次閱讀

    IOT(物聯(lián)網(wǎng))的七大通信協(xié)議之Http協(xié)議

    一、什么是http協(xié)議?嵌入式HTTP協(xié)議是一輕量級的通信協(xié)議,專為嵌入式系統(tǒng)設(shè)計,用于實現(xiàn)
    的頭像 發(fā)表于 05-24 08:11 ?2379次閱讀
    IOT(物聯(lián)網(wǎng))的七大<b class='flag-5'>通信協(xié)議</b>之Http<b class='flag-5'>協(xié)議</b>

    嵌入式系統(tǒng)軟硬件基礎(chǔ)知識大全

    可以存儲臨時數(shù)據(jù)。了解這些存儲器的特點和層次結(jié)構(gòu),有助于我們優(yōu)化嵌入式系統(tǒng)的性能和存儲需求。嵌入式系統(tǒng)的外設(shè)接口和通信協(xié)議是其與外部世界交互的關(guān)鍵。常見的接口類型包括UART、SPI、
    發(fā)表于 05-09 14:12

    UART串口通信協(xié)議是什么?

    ,廣泛應(yīng)用于嵌入式領(lǐng)域。 在UART串口通信協(xié)議中,數(shù)據(jù)以字節(jié)的形式進行傳輸。發(fā)送和接收端的通信流程如下: 1、通信波特率設(shè)置:發(fā)送端和接收端需要
    的頭像 發(fā)表于 03-19 17:26 ?1187次閱讀

    嵌入式工程師需要掌握哪些技術(shù)?

    嵌入式系統(tǒng)通常需要與其他設(shè)備或系統(tǒng)進行通信。了解常見通信協(xié)議,如UART、SPI、I2C、CAN和Ethernet等,以及它們的工作原理
    發(fā)表于 03-04 16:38

    嵌入式Linux開發(fā)的三種方式

    嵌入式Linux開發(fā)主要有三種方式:裸機開發(fā)、SDK開發(fā)和驅(qū)動開發(fā)。
    的頭像 發(fā)表于 01-22 14:22 ?899次閱讀

    三種TPL菊花鏈通信協(xié)議的差別

    在這個數(shù)字化時代,汽車行業(yè)正朝著智能化、電動化的方向飛速發(fā)展。而為了確保汽車電池管理系統(tǒng)的穩(wěn)定運行,NXP推出了TPL菊花鏈通信協(xié)議,在電池管理系統(tǒng)與電池模塊之間構(gòu)建了一條高效、可靠的通信橋梁。
    的頭像 發(fā)表于 12-22 13:38 ?1.2w次閱讀
    <b class='flag-5'>三種</b>TPL菊花鏈<b class='flag-5'>通信協(xié)議</b>的差別

    從Profinet到CCLink:工業(yè)通信協(xié)議的轉(zhuǎn)換實踐

    準(zhǔn)確的解決方案。 隨著工業(yè)技術(shù)的發(fā)展,不同的通信協(xié)議在工業(yè)設(shè)備通信中發(fā)揮著重要作用。Profinet和CCLinkIE是兩常見的工業(yè)
    發(fā)表于 12-15 14:26

    從Profinet到CCLink:工業(yè)通信協(xié)議的轉(zhuǎn)換實踐

    隨著工業(yè)技術(shù)的發(fā)展,不同的通信協(xié)議在工業(yè)設(shè)備通信中發(fā)揮著重要作用。Profinet和CCLinkIE是兩常見的工業(yè)
    的頭像 發(fā)表于 12-15 14:24 ?590次閱讀
    從Profinet到CCLink:工業(yè)<b class='flag-5'>通信協(xié)議</b>的轉(zhuǎn)換實踐

    介紹一下I2C和SPI兩常見通信協(xié)議之間區(qū)別

    在與ECU或者嵌入式相關(guān)的工作中, 我們肯定會接觸到各種通信協(xié)議, 很多協(xié)議有很多類似的地方, 也容易混淆. 本文來介紹一下兩常見
    的頭像 發(fā)表于 11-30 16:50 ?3186次閱讀
    介紹一下I2C和SPI兩<b class='flag-5'>種</b><b class='flag-5'>常見</b>的<b class='flag-5'>通信協(xié)議</b>之間區(qū)別