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

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

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

嵌入式中通訊協(xié)議設(shè)計(jì)規(guī)律分析

454398 ? 來源:CSDN 博主 ? 作者:coolbacon 許雪松 ? 2020-12-20 11:43 ? 次閱讀

公司里做項(xiàng)目,嵌入式系統(tǒng)大大小小,到處都是。因?yàn)槎际且粋€(gè)系統(tǒng)里的,所以都需要通訊,既然通訊就涉及到協(xié)議問題。

談及協(xié)議,很多工程師覺得協(xié)議的設(shè)計(jì)相對(duì)簡(jiǎn)單,主要是報(bào)文的設(shè)計(jì)。大多數(shù)時(shí)候,協(xié)議的應(yīng)用場(chǎng)景簡(jiǎn)單,沒有復(fù)雜的交互。這么做的確也是沒什么太大的問題。然而,就是這么簡(jiǎn)單的場(chǎng)景,仍有一些協(xié)議會(huì)在實(shí)際中發(fā)生意想不到的問題。歸根結(jié)蒂,還是沒有把握協(xié)議涉及的規(guī)律。下面我們簡(jiǎn)單的聊聊協(xié)議設(shè)計(jì)的規(guī)律。

協(xié)議設(shè)計(jì)中面臨的問題:

1.設(shè)計(jì)者大多數(shù)情況下,從應(yīng)用出發(fā),僅僅考慮了基本需求的滿足,沒有考慮擴(kuò)展需求的滿足;

2.從osi七層理論上,我們往往設(shè)計(jì)的協(xié)議時(shí)站在比較高層的角度去設(shè)計(jì),往往忽視了RS485/RS232, I2C, CAN, ETHERNET等物理層承載特點(diǎn),設(shè)計(jì)缺乏對(duì)具體應(yīng)用的針對(duì)性,導(dǎo)致潛在問題的產(chǎn)生;

3.容錯(cuò)和效率的考慮不足。

基本需求肯定是完成系統(tǒng)的基本功能。然而可能因?yàn)樾枨蠖x的不完整,系統(tǒng)設(shè)計(jì)人員沒有前瞻性;協(xié)議中沒有定義版本號(hào),沒有對(duì)協(xié)議兼容性的測(cè)試,導(dǎo)致老產(chǎn)品和新產(chǎn)品協(xié)議不兼容,而又無法采用簡(jiǎn)單的軟件辦法解決。這是個(gè)常見問題,最簡(jiǎn)單的辦法是在握手協(xié)議中增加協(xié)議的版本號(hào),用以判斷是否對(duì)該協(xié)議支持以及為后續(xù)的軟件做兼容準(zhǔn)備。協(xié)議看似好像只有報(bào)文設(shè)計(jì),就像一個(gè)人一樣,他在父母的眼里永遠(yuǎn)是個(gè)孩子,在自己的孩子面前是父母,在朋友面前是朋友。我相信所有這些側(cè)面合起來才是一個(gè)完整的人。UML 從不同的角度去觀察系統(tǒng)會(huì)得到不同的圖。協(xié)議也是如此,協(xié)議的報(bào)文只是協(xié)議靜態(tài)特性的一個(gè)方面,協(xié)議還有更重要的動(dòng)態(tài)特性。如出錯(cuò)后怎么辦,重發(fā)?重發(fā)幾次?節(jié)點(diǎn)損壞如何從網(wǎng)絡(luò)中剔除?怎么樣才是一個(gè)完整的通訊過程?持續(xù)的時(shí)間是多少?最壞情況下是怎么樣的?最好的情況下是什么樣的?誰發(fā)起通訊?重要的協(xié)議可能要保證非??煽?,如何確定接受者接收的完全正確,并且可靠執(zhí)行?往往這些問題已經(jīng)超出了對(duì)報(bào)文自身的考慮,而是對(duì)系統(tǒng)解決方法的一種設(shè)計(jì)。這里有個(gè)小例子,一個(gè)RS485的半工通訊,主機(jī)向從機(jī)發(fā)送數(shù)據(jù),希望從機(jī)可靠保存該數(shù)據(jù);從機(jī)接收到該數(shù)據(jù)驗(yàn)證完畢后,寫入自身的存儲(chǔ)裝置,然后再回應(yīng)主機(jī),寫入成功或者失敗。但這里有個(gè)問題,rs485是個(gè)主/從結(jié)構(gòu),無法同時(shí)發(fā)送數(shù)據(jù),只能由主機(jī)點(diǎn)名從機(jī)回應(yīng)。如果寫入時(shí)間過長(zhǎng),從機(jī)回應(yīng)報(bào)文的時(shí)間也必定過長(zhǎng);如果從機(jī)很多的話,這個(gè)時(shí)間就經(jīng)不起浪費(fèi)了??赡苄薷臑?,從機(jī)收到主機(jī)的信息后,立即應(yīng)答收到。主機(jī)再分發(fā)其他從機(jī)的數(shù)據(jù),分發(fā)完畢后,再由主機(jī)采用查詢協(xié)議查詢從機(jī)寫入的成功與否。 當(dāng)然,也可以采用一些系統(tǒng)級(jí)的辦法,只要從機(jī)收到數(shù)據(jù)后,從機(jī)一定保證數(shù)據(jù)寫入成功,那么這個(gè)問題也變得簡(jiǎn)單了。主機(jī)也不用再查詢寫入是否成功了。軟件的設(shè)計(jì)也就相對(duì)簡(jiǎn)單很多。

RS485/RS232也有雙工通訊,但在實(shí)際中用得少。這里除了省線材之外,恐怕最重要的是因?yàn)镽S485/RS232不帶沖突檢測(cè),要么采用大家輪樁做主機(jī),要么一個(gè)主機(jī),點(diǎn)名讓大家發(fā)言的辦法。所以,通訊采用一問一答的方法比較多,這比較符合半工的工作狀態(tài)。當(dāng)然不排除一些雙工的應(yīng)用場(chǎng)景。實(shí)際應(yīng)用中,大多數(shù)還是采用半工的辦法。這里協(xié)議的設(shè)計(jì)主要考慮單點(diǎn)較多;多播和單播,因?yàn)椴荒艽_定從機(jī)是否接收成功,所以重要的協(xié)議在多播和廣播之后還要查詢,這個(gè)是很麻煩的事情。軟件過程因此而復(fù)雜很多。RS485/RS232的通訊有自己的檢測(cè)錯(cuò)誤的辦法,比如說奇偶校驗(yàn),奇偶校驗(yàn)是一種簡(jiǎn)單的錯(cuò)誤校驗(yàn),并不能100%的擋住錯(cuò)誤;對(duì)于可靠地協(xié)議,可能還是要設(shè)計(jì)自己的CRC或者校驗(yàn)和等方法。但CRC校驗(yàn)雖然可以用查表的辦法,但計(jì)算時(shí)間比奇偶校驗(yàn)和校驗(yàn)和等方法計(jì)算量還是過大了些。在一些實(shí)時(shí)性和低端應(yīng)用場(chǎng)合,可能時(shí)間開銷大了些。所以,如果報(bào)文不是過大,還是可以考慮奇偶校驗(yàn)和校驗(yàn)和;如果過大,先考慮crc8,再考慮crc16和crc32,不要一竿子切。

I2C的通訊一般只用于板級(jí),但現(xiàn)在也有用于現(xiàn)場(chǎng)總線的趨勢(shì)。I2C設(shè)計(jì)之初是支持多主多從,兩個(gè)主機(jī)可以同時(shí)發(fā)送信息,仲裁獲勝的主機(jī)獲得總線,繼續(xù)發(fā)送。有仲裁不代表可以同時(shí)雙向發(fā)送信息,即主機(jī)和從機(jī)的地位還是不同的,主機(jī)點(diǎn)名從機(jī)回應(yīng)信息;雖然現(xiàn)在的CPU所帶的I2C硬件同時(shí)支持主模式和從模式,但在同一時(shí)刻,這兩個(gè)模式是不相容的。對(duì)于一個(gè)節(jié)點(diǎn)要么是主要么是從,而每次通訊都是由主發(fā)起,從被動(dòng)接收,這就導(dǎo)致了和rs232無本質(zhì)的區(qū)別。且,I2C的物理層協(xié)議也決定了,其通訊方式也沒有rs232靈活,只能工作在半工狀態(tài)。兩個(gè)CPU傳遞一些簡(jiǎn)單的信息,在CPU無多余的rs232情況下,還是非常有用得。由于是板級(jí)的通訊,信號(hào)的完整性保證了以后,基本上不可能存在錯(cuò)誤,也不需要額外的校驗(yàn)方法了。

Ethernet和CAN總線類似,所有節(jié)點(diǎn)對(duì)等,無主從之說,誰都可以發(fā)起信息。由于沖突的檢測(cè),使得仲裁失敗的節(jié)點(diǎn)稍后重試,物理層完成,不需要軟件參與,因而給協(xié)議設(shè)計(jì)帶來了極大的便利。比如說,先前的那個(gè)問題,一個(gè)廣播協(xié)議出去,不再像 Rs232/rs485那樣,再去一一查詢確認(rèn)。有問題的設(shè)備直接上報(bào)問題就好。大大的簡(jiǎn)便了問題的處理。RS232/RS485的節(jié)點(diǎn)如果發(fā)生問題,需要上報(bào),也只能等到主機(jī)點(diǎn)名時(shí)才能有機(jī)會(huì)上報(bào)。Ethernet/Can就不用了,發(fā)生問題后,直接主動(dòng)上傳。可以確保問題和緊急情況的及時(shí)處理。如果Ethernet是基于TCP的協(xié)議,效率低了,但卻保證了很多特性,數(shù)據(jù)的順序到達(dá),可靠性等等。IP 層以下的協(xié)議有很大的問題就是不能保證數(shù)據(jù)的順序到達(dá),多個(gè)路徑的長(zhǎng)短會(huì)影響協(xié)議到達(dá)的順序,有些系統(tǒng)在設(shè)計(jì)時(shí)為了效率,采用UDP或者M(jìn)AC層直接通訊。那么最好還是采用較為保守的策略,防止協(xié)議報(bào)文先后到達(dá)產(chǎn)生不必要的錯(cuò)誤。Ethernet物理層 帶有CRC32校驗(yàn),自己再做校驗(yàn)實(shí)在沒必要。

協(xié)議的效率是個(gè)較復(fù)雜的話題,以RS232為例,RS232如果1個(gè)起始位置,1個(gè)停止位置,沒有奇偶校驗(yàn)。那么發(fā)送一個(gè)字節(jié)需要10Bit,對(duì)于9600bps的波特率,1秒鐘最多傳輸960個(gè)字節(jié)。大約是1ms一個(gè)字節(jié)。如果停止位加長(zhǎng),協(xié)議一次性運(yùn)送的有用的字節(jié)數(shù)還要更低。除去必要的幀頭,幀尾,地址,校驗(yàn)信息,真正有用得信息除以總的總線上運(yùn)送的字節(jié)數(shù),就是協(xié)議的帶載能力。很顯然,如果我用多播和廣播,明顯地提高效率。對(duì)于RS232這種,廣播也許并不是個(gè)好的選擇,尤其是回頭確認(rèn)一遍。也許提高波特率是個(gè)不錯(cuò)的主意。這隨之而來的問題是,1Mbps的通訊系統(tǒng),1Start,1stop, non-parity, 1個(gè)字節(jié)只需要10us,這么快的中斷不是普通的CPU能承受的。所以,可能需要DMA來接收。DMA 接收的話,就牽涉到變長(zhǎng)的協(xié)議和定長(zhǎng)的協(xié)議。變長(zhǎng)的協(xié)議要?jiǎng)討B(tài)的判斷是否收到一個(gè)完整的包,而定長(zhǎng)的協(xié)議,對(duì)于高速的RS232有無可比擬的優(yōu)勢(shì)。大大降低計(jì)算的復(fù)雜度。定長(zhǎng)的協(xié)議就牽涉到協(xié)議的長(zhǎng)度。我們一般把最頻繁出現(xiàn)的協(xié)議的長(zhǎng)度作為全部協(xié)議報(bào)文的長(zhǎng)度。對(duì)于超長(zhǎng)的協(xié)議,由于使用次數(shù)不多,拆成多條定長(zhǎng)協(xié)議吧報(bào)文完成。比如說,我們的系統(tǒng)控制命令長(zhǎng)度為所有協(xié)議的長(zhǎng)度,因?yàn)?0%的協(xié)議報(bào)文都是系統(tǒng)控制命令。而20%的報(bào)文是其他出現(xiàn)頻率較低的報(bào)文,如系統(tǒng)固件升級(jí)報(bào)文,本身固件的大小就很大,就算超長(zhǎng)的報(bào)文也不可能容納。砍成與控制命令報(bào)文等同的長(zhǎng)度。看似比較零散,每包卻都有各自獨(dú)立性。都可以做單獨(dú)的報(bào)文發(fā)送,前后的耦合性降到最低,也就是說,雖然大協(xié)議被拆分成小的等長(zhǎng)協(xié)議報(bào)文,每個(gè)等長(zhǎng)報(bào)文在發(fā)送過程中出錯(cuò),可以單獨(dú)再發(fā)送,整個(gè)通信序列無需重置。通過合理的設(shè)計(jì),協(xié)議的效率自然而然的就被提升了。

Ethernet的設(shè)計(jì)相對(duì)寬松,其底層太強(qiáng)大了。很多工作都做了,所以,等長(zhǎng)不等長(zhǎng)對(duì)Ethernet系統(tǒng)無所謂。關(guān)鍵要解決Ethernet的通信模型問題。如果是嵌入式服務(wù)器,TCP 保持半開鏈接不能太耗費(fèi)資源。如果是UDP或者mac層的協(xié)議,需要對(duì)協(xié)議序列的先后到達(dá)順序進(jìn)行解耦,防止出現(xiàn)不必要的問題。如果一個(gè)大協(xié)議包,需要拆成三個(gè)包發(fā)送,三個(gè)包順序任意無影響;任意包發(fā)生錯(cuò)誤,只需要將錯(cuò)誤包重發(fā)成功即可。Ethernet由于速度高,協(xié)議帶載能力可以得到很好的補(bǔ)充。另外,由于Ethernet是一個(gè)完美支持多播和廣播的網(wǎng)絡(luò),實(shí)際中使用廣播太多造成了廣播風(fēng)暴,導(dǎo)致網(wǎng)絡(luò)性能急劇下降,所以現(xiàn)在分了虛擬局域網(wǎng),就是為了抑制廣播風(fēng)暴,提高效率。實(shí)際使用中還是要盡量的合理設(shè)計(jì)系統(tǒng),避免過多的廣播協(xié)議的使用,以免拖慢整個(gè)網(wǎng)絡(luò)系統(tǒng)。

編輯:hfy


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

    評(píng)論

    相關(guān)推薦

    SIP協(xié)議嵌入式Linux的實(shí)現(xiàn)

    嵌入式系統(tǒng)由于本身資源的限制,現(xiàn)有的SIP協(xié)議直接應(yīng)用于嵌入式便攜設(shè)備還有困難。為滿足SIP協(xié)議嵌入式系統(tǒng)
    發(fā)表于 10-12 12:22 ?2238次閱讀
    SIP<b class='flag-5'>協(xié)議</b>在<b class='flag-5'>嵌入式</b>Linux<b class='flag-5'>中</b>的實(shí)現(xiàn)

    嵌入式SIP協(xié)議棧怎么設(shè)計(jì)?

    SIP服務(wù)器或其他網(wǎng)絡(luò)服務(wù)器進(jìn)行交互。同時(shí)SIP易于擴(kuò)展,支持用戶移動(dòng)性,能夠充分滿足設(shè)備對(duì)移動(dòng)性服務(wù)的需求,而且SIP簡(jiǎn)單靈活,計(jì)算量小,尤其適合在嵌入式應(yīng)用環(huán)境應(yīng)用。因此,將SIP引入到嵌入式應(yīng)用
    發(fā)表于 10-29 08:14

    如何在ARM處理器實(shí)現(xiàn)SMTP協(xié)議嵌入式遠(yuǎn)程通訊

    如何在ARM處理器實(shí)現(xiàn)SMTP協(xié)議嵌入式遠(yuǎn)程通訊?
    發(fā)表于 06-04 06:38

    嵌入式C語言環(huán)境下的CAN總線通訊協(xié)議的相關(guān)資料下載

    本文轉(zhuǎn)載在我的微信公眾號(hào):古德曼汽車工業(yè)。希望關(guān)注本專欄的朋友,也能一并關(guān)注微信公眾號(hào)。原文地址:嵌入式C語言環(huán)境下的CAN總線通訊協(xié)議相信本公眾號(hào)的讀者對(duì)CAN通訊
    發(fā)表于 12-15 08:23

    OEM嵌入式通訊模塊介紹

    1OEM嵌入式通訊模塊介紹OEM嵌入式通訊模塊是一款適用于工業(yè)以太網(wǎng)和現(xiàn)場(chǎng)總線協(xié)議嵌入式IC模
    發(fā)表于 12-20 07:19

    嵌入式通訊接口對(duì)比

    1. 嵌入式通訊接口嵌入式系統(tǒng),我們熟知的通訊接口無非有串口,SPI,IIC,CAN,USB。都是用于數(shù)據(jù)的交互,串口在工業(yè)上使用的是R
    發(fā)表于 01-14 07:25

    嵌入式VTL應(yīng)用程序與內(nèi)核通訊的設(shè)計(jì)

    嵌入式虛擬磁帶庫(VTL)的設(shè)計(jì),應(yīng)用程序與內(nèi)核之間的通訊是一個(gè)核心問題。本文提出了基于共享磁盤和共享內(nèi)存的應(yīng)用程序與內(nèi)核之間的通訊方案,實(shí)現(xiàn)了
    發(fā)表于 05-25 15:24 ?14次下載

    嵌入式TCPIP協(xié)議分析與研究

    嵌入式系統(tǒng)中大量存在的是8/16 位低速處理器,在進(jìn)行Internet 接入時(shí),由于本身 資源的限制,很難實(shí)現(xiàn)完整的TCP/IP 協(xié)議。文章闡述了嵌入式系統(tǒng)接入Internet 的方法,
    發(fā)表于 06-13 11:46 ?9次下載

    嵌入式系統(tǒng)TCP/IP 協(xié)議的精簡(jiǎn)與實(shí)現(xiàn)

    通過對(duì)TCP/IP 協(xié)議分析,結(jié)合嵌入式系統(tǒng)的特點(diǎn),挑選出一套精簡(jiǎn)、實(shí)用的TCP/IP協(xié)議子集,并詳細(xì)介紹各協(xié)議層的實(shí)現(xiàn)過程。為
    發(fā)表于 08-22 08:42 ?18次下載

    嵌入式系統(tǒng)SMTP協(xié)議通訊實(shí)現(xiàn)

    本文介紹了在網(wǎng)絡(luò)時(shí)代的嵌入式系統(tǒng)發(fā)展?fàn)顩r,結(jié)合網(wǎng)絡(luò)協(xié)議SMTP 協(xié)議自身的特點(diǎn)及其應(yīng)用,提出了在嵌入式系統(tǒng)中提供SMTP 支持的具體流程和
    發(fā)表于 09-22 10:53 ?17次下載

    在ARM處理器實(shí)現(xiàn)SMTP協(xié)議嵌入式遠(yuǎn)程通訊模式

      在本課題中,通過SMTP協(xié)議的方式提供了一種新的嵌入式遠(yuǎn)程通訊模式。即在ARM處理器實(shí)現(xiàn)SMTP協(xié)議,并通過雙絞線連接到Interne
    發(fā)表于 06-25 10:31 ?635次閱讀
    在ARM處理器<b class='flag-5'>中</b>實(shí)現(xiàn)SMTP<b class='flag-5'>協(xié)議</b>的<b class='flag-5'>嵌入式</b>遠(yuǎn)程<b class='flag-5'>通訊</b>模式

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

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

    關(guān)于嵌入式系統(tǒng)通訊協(xié)議設(shè)計(jì)的規(guī)律淺析

    談及協(xié)議,很多工程師覺得協(xié)議的設(shè)計(jì)相對(duì)簡(jiǎn)單,主要是報(bào)文的設(shè)計(jì)。大多數(shù)時(shí)候,協(xié)議的應(yīng)用場(chǎng)景簡(jiǎn)單,沒有復(fù)雜的交互。這么做的確也是沒什么太大的問題。然而,就是這么簡(jiǎn)單的場(chǎng)景,仍有一些協(xié)議會(huì)在
    發(fā)表于 12-06 16:33 ?638次閱讀

    嵌入式系統(tǒng)LXT971A型網(wǎng)絡(luò)通訊接口電路的應(yīng)用分析

    介紹LXT971A型網(wǎng)絡(luò)通訊接口電路的內(nèi)部結(jié)構(gòu)和引腳功能,給出在嵌入式系統(tǒng)采用LXT971A與MPC860型網(wǎng)絡(luò)通訊處理器進(jìn)行網(wǎng)絡(luò)通訊的硬
    的頭像 發(fā)表于 06-22 14:21 ?3342次閱讀
    <b class='flag-5'>嵌入式</b>系統(tǒng)<b class='flag-5'>中</b>LXT971A型網(wǎng)絡(luò)<b class='flag-5'>通訊</b>接口電路的應(yīng)用<b class='flag-5'>分析</b>

    嵌入式開發(fā)串口通訊方案

    嵌入式開發(fā),經(jīng)常會(huì)用到串口通訊。面對(duì)不同應(yīng)用場(chǎng)景,需要不同的方案。
    的頭像 發(fā)表于 05-23 11:48 ?2434次閱讀