<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

PC機與嵌入式設備通信協議設計原則

Linux大陸 ? 來源:CSDN-RimeLink ? 2023-07-06 11:39 ? 次閱讀

嵌入式設備在運行中需要設置參數,這個工作經常由PC機來實現,需要為雙方通信設計協議,有代表性協議是如下三種:

9e7c85dc-1bae-11ee-962d-dac502259ad0.png

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

一. 簡單性

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

協議一般都需要以下域:幀頭,長度,幀類型,目標地址,源地址,數據,校驗,幀尾。

二. 可擴展

必須保證將來增加功能和更改硬件后協議仍能勝任工作,這往往是通過預留空間來實現,協議的變更應該只是量的增加,不至于引起協議結構的變化。

三. 低耦合

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

四. 穩定性

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

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

五. 高效率

按信息類型區分協議包類別,如:設置網絡信息參數,設置當前運行參數,可以區分開來,方便程序處理。

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

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

六. 易實現

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

七.軟件開發

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

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

接收不定長的數據幀,可以使用狀態機,當接收到“幀尾數據”時向進程發消息。

相關文章:如何高效解析不定長度的協議幀?

小心數據紊亂和超時異常(數據紊亂時需要將狀態機及時復位,超時一般使用定時器監控)。

八. 考慮硬件

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

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

附錄A 一個基于DMA傳輸固定長度的協議實例

9e9cc90a-1bae-11ee-962d-dac502259ad0.jpg

如圖顯示了PC發送數據幀的格式,總長為64字節,是4字節的整倍數,符合絕大部分32位處理器結構體對齊的特性。

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

Len:INT8U,本幀的總數據長度,在圖4即為64

Dst:INT8U,標識目標設備的ID號

Src:INT8U,標識源設備的ID號

Data:56字節的存儲區,內容依賴于具體的通信幀(實例見表2)

Cmd:INT16U,數據幀的類別

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

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

Data域數據結構實例:

9eaf6204-1bae-11ee-962d-dac502259ad0.png

附錄B 一個基于變長格式的UART通信協議實例

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

9ecf9966-1bae-11ee-962d-dac502259ad0.jpg

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    18564

    瀏覽量

    224097
  • 嵌入式
    +關注

    關注

    5006

    文章

    18446

    瀏覽量

    292194
  • 通信協議
    +關注

    關注

    28

    文章

    774

    瀏覽量

    39963
  • 無線通信
    +關注

    關注

    57

    文章

    4303

    瀏覽量

    142747
  • PC機
    +關注

    關注

    2

    文章

    200

    瀏覽量

    28162

原文標題:嵌入式設備與PC通信,協議設計原則!

文章出處:【微信號:Linux大陸,微信公眾號:Linux大陸】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    發問:關于各種通信協議嵌入式的關系

    本人是通信專業學生,想學習一些和通信相關的嵌入式的東西,但具體不清楚應該從哪下手,具體目標是想學習關于802.11,LTE之類的協議,怎么和嵌入式
    發表于 06-09 11:58

    嵌入式系統對通信有什么需求?

    嵌入式系統之間的通信通常有兩種方式:并行通信和串行通信。并行方式傳輸數據速度快,但占用的通信線多,傳輸數據的可靠性隨距離的增加而下降,只適用
    發表于 08-09 08:00

    嵌入式系統的通信過程是什么樣的?

    嵌入式系統之間的通信通常有兩種方式:并行通信和串行通信。并行方式傳輸數據速度快,但占用的通信線多,傳輸數據的可靠性隨距離的增加而下降,只適用
    發表于 11-07 06:28

    TCP通信協議-Labview上位

    現在用單片進行信息采集,通過GPRS模塊上傳到PC,用Labview做上位,TCP通信協議,想請教一下,TCP通信協議和Modbus T
    發表于 12-10 08:58

    嵌入式領域中常用的5種通信協議是什么

    文章目錄嵌入式領域中常用的5種通信協議嵌入式領域中常用的5種通信協議串口協議(UART/USART):串口總線其實就是一種
    發表于 12-14 06:22

    嵌入式系統通信協議及具體程序實現方法是什么

    嵌入式系統通信協議及具體程序實現方法是什么
    發表于 12-20 08:01

    上位通信協議相關的一些知識點分享

    作為開發人員,常常瀏覽一下招聘網站,了解人才市場需求,還是很有必要的。今天瀏覽前程無憂時,發現這樣一個要求:嵌入式相關上位編寫,了解常用通信協議如RS-232、CAN、RS485、I2C等接口
    發表于 12-23 06:30

    三種常見嵌入式設備通信協議是什么?

    三種常見嵌入式設備通信協議是什么?
    發表于 12-23 08:17

    通信協議的相關資料分享

    嵌入式通信協議:分為“大協議”和“小協議”兩種“大協議”:主要用來進行系統外的整個系統之間的通信
    發表于 12-24 08:15

    串口通信協議的相關資料分享

    的建立三、建立STM32與PC之間的通信基礎1、串口助手的使用2、效果呈現一、串口通信協議1、UART簡介嵌入式開發中,UART串口通信協議
    發表于 02-22 07:16

    基于嵌入式的實時通信協議棧研究與設計

    傳統的TCP/IP協議重點在于保證數據傳輸的可靠性及流量控制,而在實時性要求相對較高的嵌入式領域, 其實時性方面的性能顯得不足。為此,對基于TCP/IP協議嵌入式
    發表于 09-23 17:55 ?27次下載

    PC與單片機串口通信協議

    PC與單片機串口通信協議
    發表于 12-26 22:12 ?0次下載

    基于嵌入式網關的socket編程及通信協議

    基于嵌入式網關的socket編程及通信協議
    發表于 08-31 14:59 ?6次下載
    基于<b class='flag-5'>嵌入式</b>網關的socket編程及<b class='flag-5'>通信協議</b>

    三種常見嵌入式設備通信協議

    嵌入式設備PC通訊的通信協議設計經驗 嵌入式設備在運行中需要設置參數,這個工作經常由
    的頭像 發表于 03-06 10:06 ?1.7w次閱讀
    三種常見<b class='flag-5'>嵌入式</b><b class='flag-5'>設備</b><b class='flag-5'>通信協議</b>

    幾種常見嵌入式設備通信協議

    幾種常見嵌入式設備通信協議
    的頭像 發表于 09-18 16:43 ?1199次閱讀
    幾種常見<b class='flag-5'>嵌入式</b><b class='flag-5'>設備</b><b class='flag-5'>通信協議</b>
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>