衡阳派盒市场营销有限公司

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

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

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

PC機(jī)與嵌入式設(shè)備通信協(xié)議設(shè)計(jì)原則

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

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

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

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

一. 簡單性

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

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

二. 可擴(kuò)展

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

三. 低耦合

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

四. 穩(wěn)定性

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

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

五. 高效率

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

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

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

六. 易實(shí)現(xiàn)

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

七.軟件開發(fā)

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

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

接收不定長的數(shù)據(jù)幀,可以使用狀態(tài)機(jī),當(dāng)接收到“幀尾數(shù)據(jù)”時(shí)向進(jìn)程發(fā)消息。

相關(guān)文章:如何高效解析不定長度的協(xié)議幀?

小心數(shù)據(jù)紊亂和超時(shí)異常(數(shù)據(jù)紊亂時(shí)需要將狀態(tài)機(jī)及時(shí)復(fù)位,超時(shí)一般使用定時(shí)器監(jiān)控)。

八. 考慮硬件

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

審核編輯:湯梓紅

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

    關(guān)注

    68

    文章

    19407

    瀏覽量

    231183
  • 嵌入式
    +關(guān)注

    關(guān)注

    5092

    文章

    19177

    瀏覽量

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

    關(guān)注

    28

    文章

    915

    瀏覽量

    40439
  • 無線通信
    +關(guān)注

    關(guān)注

    58

    文章

    4604

    瀏覽量

    143884
  • PC機(jī)
    +關(guān)注

    關(guān)注

    2

    文章

    201

    瀏覽量

    28663

原文標(biāo)題:嵌入式設(shè)備與PC通信,協(xié)議設(shè)計(jì)原則!

文章出處:【微信號(hào):Linux大陸,微信公眾號(hào):Linux大陸】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    嵌入式領(lǐng)域中常用的5種通信協(xié)議是什么

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

    嵌入式系統(tǒng)通信協(xié)議及具體程序?qū)崿F(xiàn)方法是什么

    嵌入式系統(tǒng)通信協(xié)議及具體程序?qū)崿F(xiàn)方法是什么
    發(fā)表于 12-20 08:01

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

    三種常見嵌入式設(shè)備通信協(xié)議是什么?
    發(fā)表于 12-23 08:17

    串口通信協(xié)議的相關(guān)資料分享

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

    EPA 通信協(xié)議在μC/OS-II嵌入式系統(tǒng)中的設(shè)計(jì)與實(shí)現(xiàn)

    本文提出了一種基于μC/OS-II 嵌入式系統(tǒng)的EPA 通信協(xié)議的實(shí)現(xiàn)方案。簡要介紹了 EPA 通信協(xié)議和模型,針對(duì)在以μC/OS-II 嵌入式系統(tǒng)為平臺(tái)實(shí)現(xiàn)EPA
    發(fā)表于 05-25 15:02 ?18次下載

    嵌入式系統(tǒng)與PC機(jī)的USBUART通信設(shè)計(jì)

    嵌入式系統(tǒng)與PC機(jī)的USBUART通信設(shè)計(jì)  1 概 述   RS232(UART)接口是一種簡單、方便和實(shí)用的通信接口,用途非常廣泛
    發(fā)表于 03-08 10:28 ?1932次閱讀
    <b class='flag-5'>嵌入式</b>系統(tǒng)與<b class='flag-5'>PC</b><b class='flag-5'>機(jī)</b>的USBUART<b class='flag-5'>通信</b>設(shè)計(jì)

    基于嵌入式的實(shí)時(shí)通信協(xié)議棧研究與設(shè)計(jì)

    傳統(tǒng)的TCP/IP協(xié)議重點(diǎn)在于保證數(shù)據(jù)傳輸?shù)目煽啃约傲髁靠刂疲趯?shí)時(shí)性要求相對(duì)較高的嵌入式領(lǐng)域, 其實(shí)時(shí)性方面的性能顯得不足。為此,對(duì)基于TCP/IP協(xié)議嵌入式
    發(fā)表于 09-23 17:55 ?27次下載

    結(jié)合內(nèi)部CAN總線與外部網(wǎng)絡(luò)通信協(xié)議嵌入式系統(tǒng)開發(fā)

    結(jié)合內(nèi)部CAN總線與外部網(wǎng)絡(luò)通信協(xié)議嵌入式系統(tǒng)開發(fā),網(wǎng)絡(luò)通信的技術(shù)資料,很好很實(shí)用。
    發(fā)表于 03-28 10:47 ?10次下載

    PC與單片機(jī)串口通信協(xié)議

    PC與單片機(jī)串口通信協(xié)議
    發(fā)表于 12-26 22:12 ?0次下載

    基于嵌入式網(wǎng)關(guān)的socket編程及通信協(xié)議

    基于嵌入式網(wǎng)關(guān)的socket編程及通信協(xié)議
    發(fā)表于 08-31 14:59 ?6次下載
    基于<b class='flag-5'>嵌入式</b>網(wǎng)關(guān)的socket編程及<b class='flag-5'>通信協(xié)議</b>

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

    嵌入式設(shè)備PC通訊的通信協(xié)議設(shè)計(jì)經(jīng)驗(yàn) 嵌入式設(shè)備在運(yùn)行中需要設(shè)置參數(shù),這個(gè)工作經(jīng)常由
    的頭像 發(fā)表于 03-06 10:06 ?1.7w次閱讀
    三種常見<b class='flag-5'>嵌入式</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>通信協(xié)議</b>

    基于嵌入式環(huán)境的串行幀通信協(xié)議設(shè)計(jì)

    嵌入式系統(tǒng)之間的通信通常有兩種方式:并行通信和串行通信。并行方式傳輸數(shù)據(jù)速度快,但占用的通信線多,傳輸數(shù)據(jù)的可靠性隨距離的增加而下降,只適用
    發(fā)表于 10-14 16:29 ?1441次閱讀
    基于<b class='flag-5'>嵌入式</b>環(huán)境的串行幀<b class='flag-5'>通信協(xié)議</b>設(shè)計(jì)

    單片機(jī)嵌入式系統(tǒng)中的通信協(xié)議

    用途的計(jì)算機(jī)系統(tǒng),通常被嵌入到其他設(shè)備或系統(tǒng)中,用于實(shí)現(xiàn)控制、監(jiān)測、通信等功能。 在嵌入式系統(tǒng)中,單片機(jī)通過與其他
    的頭像 發(fā)表于 04-19 14:08 ?1262次閱讀

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

    幾種常見嵌入式設(shè)備通信協(xié)議
    的頭像 發(fā)表于 09-18 16:43 ?1743次閱讀
    幾種常見<b class='flag-5'>嵌入式</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>通信協(xié)議</b>

    ARM嵌入式通信協(xié)議及應(yīng)用

    隨著科技的飛速發(fā)展,嵌入式系統(tǒng)在各個(gè)領(lǐng)域扮演著越來越重要的角色。ARM處理器因其高性能、低功耗的特點(diǎn),在嵌入式系統(tǒng)中得到了廣泛應(yīng)用。通信協(xié)議作為嵌入式系統(tǒng)的重要組成部分,對(duì)于實(shí)現(xiàn)
    的頭像 發(fā)表于 12-28 09:18 ?320次閱讀
    海尔百家乐官网的玩法技巧和规则 | 利澳百家乐的玩法技巧和规则 | 鸿博线上娱乐| 百家乐官网赌博筹码| 百家乐游戏机技| 娱乐论坛| 澳门百家乐官网官方网站| 太阳城娱乐网sss977| 百家乐官网棋牌正式版| 澳门百家乐公试打法| 六合彩图片| 百家乐官网娱乐网开户| 天博百家乐的玩法技巧和规则| 凯时百家乐官网技巧| 百家乐视频象棋| bet365主页器| 广州百家乐官网桌子| 大发888娱乐城下载最新版| 明升百家乐官网娱乐城| 百家乐破解秘籍| 博九网百家乐官网游戏| 百家乐如何买大小| 澳门百家乐官网免费开户| 百家乐2号技术| 百家乐官网博彩策略论坛| 钱隆百家乐分析| 网上百家乐官网赢钱公式| 大发百家乐的玩法技巧和规则| 香港六合彩开奖现场直播| 如何赢百家乐官网的玩法技巧和规则| 威尼斯人娱乐场首页| 玩百家乐官网平台| 百家乐官网单注打法| 二八杠手法| 百家乐官网娱乐场真人娱乐场| 帝王百家乐的玩法技巧和规则| 百家乐官网怎么下可以赢| 百家乐永利娱乐场| 百家乐官网网站开户| 百家乐赌博游戏平台| 大发888网页版官网|