《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > 嵌入式環(huán)境下串行幀通信的設(shè)計(jì)與實(shí)現(xiàn)
嵌入式環(huán)境下串行幀通信的設(shè)計(jì)與實(shí)現(xiàn)
現(xiàn)代電子技術(shù)
陳 樂,唐 波,盧 力 國防科學(xué)技術(shù)大學(xué)
摘要: 在嵌入式環(huán)境下,因設(shè)備間通信距離較遠(yuǎn),多采用串行通信方式,但許多串行通信協(xié)議只適用于協(xié)議設(shè)計(jì)時(shí)的應(yīng)用系統(tǒng)環(huán)境,不具有通用性,且有些協(xié)議存在通信失敗的風(fēng)險(xiǎn)。通過分析設(shè)備間的通信需求,設(shè)計(jì)了一種分層的串行幀通信協(xié)議,該協(xié)議簡單可靠,能適應(yīng)多種系統(tǒng)環(huán)境。在嵌入式Linux系統(tǒng)環(huán)境下,該協(xié)議在實(shí)際應(yīng)用系統(tǒng)中運(yùn)行穩(wěn)定。
Abstract:
Key words :

摘要:在嵌入式環(huán)境下,因設(shè)備間通信距離較遠(yuǎn),多采用串行通信" title="串行通信">串行通信方式,但許多串行通信協(xié)議只適用于協(xié)議設(shè)計(jì)" title="協(xié)議設(shè)計(jì)">協(xié)議設(shè)計(jì)時(shí)的應(yīng)用系統(tǒng)環(huán)境,不具有通用性,且有些協(xié)議存在通信失敗的風(fēng)險(xiǎn)。通過分析設(shè)備間的通信需求,設(shè)計(jì)了一種分層的串行幀通信協(xié)議,該協(xié)議簡單可靠,能適應(yīng)多種系統(tǒng)環(huán)境。在嵌入式Linux系統(tǒng)" title="嵌入式Linux系統(tǒng)">嵌入式Linux系統(tǒng)環(huán)境下,該協(xié)議在實(shí)際應(yīng)用系統(tǒng)中運(yùn)行穩(wěn)定。
關(guān)鍵詞:串行通信;協(xié)議設(shè)計(jì);嵌入式Linux系統(tǒng);應(yīng)用層;鏈路層

    嵌入式系統(tǒng)之間的通信通常有兩種方式:并行通信和串行通信。并行方式傳輸數(shù)據(jù)速度快,但占用的通信線多,傳輸數(shù)據(jù)的可靠性隨距離的增加而下降,只適用于近距離的數(shù)據(jù)傳送。在遠(yuǎn)距離數(shù)據(jù)通信中,一般采用串行通信方式,它具有占用通信線少、成本低等優(yōu)點(diǎn)。目前RS 232串口是PC機(jī)與通信工業(yè)中應(yīng)用最廣泛的一種串行接口,它應(yīng)用于點(diǎn)對點(diǎn)通信模式,實(shí)際使用中多采用最簡單的三線方式連接,即兩端設(shè)備的串口只連接收、發(fā)、地三根線,即可實(shí)現(xiàn)簡單的全雙工通信。通信協(xié)議是兩端設(shè)備數(shù)據(jù)交換的語言,是通信可靠性的保證,在保證功能的前提下,通信協(xié)議應(yīng)該力求簡潔。

1 系統(tǒng)通信需求
    本系統(tǒng)主要完成野外環(huán)境下時(shí)間間隔測量和瞬態(tài)數(shù)據(jù)采集的功能,系統(tǒng)內(nèi)各模塊均選用三星公司的S3C2440" title="S3C2440">S3C2440芯片為處理器,操作系統(tǒng)使用嵌入式Linux。模塊間通信的主要任務(wù)為控制命令的下發(fā)與應(yīng)答、工作狀態(tài)和采集數(shù)據(jù)的上報(bào)等,對通信的可靠性要求較高,無數(shù)據(jù)加密需求。
    根據(jù)系統(tǒng)軟硬件情況設(shè)定串口工作參數(shù)如下:115 200波特率,8位數(shù)據(jù)位,1位停止位,奇校驗(yàn)、無流控。波特率的設(shè)置需要綜合考慮所選用芯片的串口性能、串口連接線長度、傳輸數(shù)據(jù)的最大幀長和應(yīng)用過程中的誤碼率等;無流控則是由于串口使用三線方式連接。

2 通信協(xié)議的分層結(jié)構(gòu)
    為保證不同設(shè)備之間通信協(xié)議的通用性,降低實(shí)現(xiàn)的復(fù)雜度,將通信協(xié)議為分上下兩層:上層為應(yīng)用層,規(guī)范了設(shè)備間應(yīng)用程序通信使用的應(yīng)用層數(shù)據(jù)格式;下層為鏈路層" title="鏈路層">鏈路層,提供物理線路數(shù)據(jù)的發(fā)送與接收,應(yīng)用層數(shù)據(jù)拆分與合并、封裝與解封裝以及錯(cuò)誤檢測功能。協(xié)議應(yīng)用層部分根據(jù)各設(shè)備功能的不同使用不同的數(shù)據(jù)格式,而鏈路層部分則完全通用。應(yīng)用層通信過程如圖1所示。

 a.JPG


    發(fā)方設(shè)備按照約定的應(yīng)用層數(shù)據(jù)格式構(gòu)造應(yīng)用層數(shù)據(jù),交由鏈路層進(jìn)行數(shù)據(jù)的拆分、封裝、校驗(yàn),再將生成的數(shù)據(jù)以數(shù)據(jù)幀的形式發(fā)送至物理線路;收方設(shè)備則從物理線路上接收數(shù)據(jù),進(jìn)行幀定位、解封裝、錯(cuò)誤檢測、數(shù)據(jù)合并等,最后將應(yīng)用層數(shù)據(jù)上交給應(yīng)用層處理。收發(fā)方設(shè)備的應(yīng)用層可根據(jù)用戶需求的變化,不斷修改應(yīng)用層數(shù)據(jù)格式,并利用鏈路層提供的功能接口完成通信功能,故該通信協(xié)議設(shè)計(jì)的關(guān)鍵在于鏈路層,以下著重闡述鏈路層的設(shè)計(jì)與實(shí)現(xiàn)。

3 鏈路層設(shè)計(jì)
    鏈路層主要包含以下功能:數(shù)據(jù)拆分與合并、數(shù)據(jù)封裝與解封裝、數(shù)據(jù)幀的發(fā)送和接收以及錯(cuò)誤檢測與重發(fā)機(jī)制。
3.1 數(shù)據(jù)拆分與合并
    數(shù)據(jù)拆分即是把過長的應(yīng)用層數(shù)據(jù)分成幾部分,用多幀數(shù)據(jù)幀發(fā)送,接收端收到后再進(jìn)行數(shù)據(jù)合并,上交給應(yīng)用層處理。過長的應(yīng)用層數(shù)據(jù)如果不進(jìn)行拆分,可能導(dǎo)致數(shù)據(jù)幀超出設(shè)計(jì)的緩沖區(qū)大小,也可能造成發(fā)送時(shí)間太長導(dǎo)致超時(shí)錯(cuò)誤。這個(gè)長度需要根據(jù)實(shí)際需求合理設(shè)置,當(dāng)數(shù)據(jù)幀傳輸出現(xiàn)錯(cuò)誤時(shí),這幀數(shù)據(jù)就需要重新傳輸,長度太大將造成較大開銷;長度太小,封裝時(shí)產(chǎn)生的開銷字節(jié)所占比例又太高,影響傳輸效率。
3.2 數(shù)據(jù)封裝與解封裝
    數(shù)據(jù)封裝即是以一定格式把拆分后的應(yīng)用層數(shù)據(jù)加上功能指示、數(shù)據(jù)長度等字段,以便對方收到后知道如何處理。數(shù)據(jù)封裝格式及功能指示字段含義如表1,表2所示。

 b.JPG
3.3 幀發(fā)送與接收
    鏈路層以幀為單位進(jìn)行數(shù)據(jù)收發(fā),一種普遍的界定幀起始與結(jié)束的方法是:在待發(fā)送數(shù)據(jù)的頭部和尾部加入特殊的起始碼和結(jié)束碼,如果在數(shù)據(jù)中出現(xiàn)了這個(gè)碼型,就必須在數(shù)據(jù)發(fā)送前進(jìn)行轉(zhuǎn)義處理,把它轉(zhuǎn)換成其他碼型,否則將導(dǎo)致幀定位錯(cuò)誤,數(shù)據(jù)通信失敗。很多協(xié)議實(shí)現(xiàn)者為求實(shí)現(xiàn)簡單沒有進(jìn)行這種轉(zhuǎn)義,存在通信失敗的風(fēng)險(xiǎn),其實(shí)在點(diǎn)對點(diǎn)協(xié)議(PPP協(xié)議)中的描述了一種轉(zhuǎn)義處理方法,經(jīng)簡化后,實(shí)現(xiàn)起來也并不復(fù)雜,描述如下:
    數(shù)據(jù)發(fā)送方在幀首處發(fā)送0x7E作為起始碼,逐字節(jié)發(fā)送封裝后的數(shù)據(jù),遇到0x7E時(shí),發(fā)送0x7D,0x5E字節(jié)序列,遇到0x7D時(shí),發(fā)送0x7 D,0x5D字節(jié)序列,最后在幀尾處發(fā)送0x7E作為結(jié)束碼;
    數(shù)據(jù)接收方在串口數(shù)據(jù)流中搜索第一個(gè)0x7E作為幀起始(連續(xù)的0x7E則以最后一個(gè)為幀起始),逐字節(jié)接收數(shù)據(jù),遇到0x7D時(shí),跳過不處理,而把該字節(jié)的后一個(gè)字節(jié)加上0x20,直到遇到0x7E認(rèn)為幀結(jié)束。
    在鏈路幀發(fā)送前,應(yīng)使用CRC16算法對封裝數(shù)據(jù)進(jìn)行校驗(yàn),校驗(yàn)多項(xiàng)式為,校驗(yàn)值寫入校驗(yàn)字段中;在鏈路幀接收后,先對其進(jìn)行校驗(yàn),如果檢驗(yàn)成功再進(jìn)行數(shù)據(jù)解封裝處理,如果校驗(yàn)失敗則按照下述重發(fā)機(jī)制進(jìn)行重發(fā)。
3.4 錯(cuò)誤檢測與重發(fā)機(jī)制
    綜合考慮協(xié)議實(shí)現(xiàn)的簡單性和數(shù)據(jù)收發(fā)的可靠性,決定采用停等協(xié)議進(jìn)行數(shù)據(jù)收發(fā),過程如下:
    發(fā)送方發(fā)送一幀數(shù)據(jù)幀后,設(shè)置一個(gè)最長等待時(shí)間,等待接收對方的確認(rèn)幀或拒絕幀,若收到確認(rèn)幀則發(fā)送下一幀;若收到拒絕幀或者在超時(shí)時(shí)間內(nèi)未收到確認(rèn)幀或拒絕幀,則重發(fā)當(dāng)前幀,因等待超時(shí)而重發(fā)的幀要設(shè)置超時(shí)指示位。當(dāng)連續(xù)收到拒絕幀三次或連續(xù)超時(shí)重發(fā)三次,則認(rèn)為對端不可達(dá),取消當(dāng)前幀的發(fā)送,上報(bào)錯(cuò)誤給應(yīng)用層。
    接收方收到數(shù)據(jù)幀后,當(dāng)超時(shí)指示位為0時(shí),如果校驗(yàn)正確,則發(fā)送確認(rèn)幀,并處理此幀,如果校驗(yàn)錯(cuò)誤,則發(fā)送拒絕幀,不處理該幀;當(dāng)超時(shí)指示位為1時(shí),說明對方未正確收到確認(rèn)幀或拒絕幀,如果上次非重發(fā)幀的校驗(yàn)結(jié)果是正確的,則該幀實(shí)際上已經(jīng)處理過,直接發(fā)送確認(rèn)幀即可;如果上次非重發(fā)幀的校驗(yàn)結(jié)果是錯(cuò)誤的,則根據(jù)校驗(yàn)結(jié)果正常處理該幀。

4 鏈路層實(shí)現(xiàn)
    鏈路層采用C++語言實(shí)現(xiàn),以便于代碼在各模塊程序中復(fù)用。應(yīng)用層數(shù)據(jù)發(fā)送和接收流程如圖2,圖3所示。

 c.JPG

 

5 結(jié)語
      鏈路層的作用是可靠地把應(yīng)用層數(shù)據(jù)發(fā)送到對端設(shè)備,但如果僅僅是這樣,應(yīng)用程序使用起來并不是很方便,如果使用面向?qū)ο缶幊痰姆椒ǎ焰溌穼哟a封裝在一個(gè)類中,向應(yīng)用程序提供一些較為簡單的功能接口,如發(fā)送數(shù)據(jù),接收數(shù)據(jù),檢測對端是否可達(dá)等,就可以很好地解決易用性問題。另外當(dāng)數(shù)據(jù)發(fā)送失敗時(shí),應(yīng)當(dāng)以返回值或事件方式通知應(yīng)用程序,當(dāng)有應(yīng)用層數(shù)據(jù)需要處理時(shí),最好以回調(diào)函數(shù)或事件方式激活應(yīng)用層處理程序,以避免應(yīng)用程序低效的循環(huán)檢測。通過在協(xié)議設(shè)計(jì)和協(xié)議實(shí)現(xiàn)兩個(gè)方面同時(shí)進(jìn)行優(yōu)化,該協(xié)議在實(shí)際應(yīng)用過程中表現(xiàn)出極好的可靠性和一定的通用性,可供參考借鑒。
 

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久久久久亚洲精品中文字幕| 欧美日韩国产一区| 亚洲精品在线电影| 亚洲欧美日韩直播| 夜夜爽av福利精品导航 | 亚洲乱码国产乱码精品精可以看 | 欧美系列亚洲系列| 欧美日韩国产在线| 欧美日韩国产影院| 欧美日韩成人精品| 欧美日韩1区2区| 欧美日韩成人在线播放| 欧美伦理在线观看| 欧美精品导航| 欧美日本视频在线| 欧美日韩免费观看一区| 欧美日韩成人一区二区| 欧美日韩亚洲综合| 欧美视频久久| 国产精品免费观看在线| 国产精品欧美日韩久久| 国产精品日韩在线| 国产网站欧美日韩免费精品在线观看 | 欧美成人免费全部观看天天性色| 模特精品在线| 欧美日本亚洲韩国国产| 国产精品久久久久高潮| 国产精品免费看片| 亚洲午夜一区| 狼狼综合久久久久综合网| 欧美怡红院视频| 久久久久久香蕉网| 欧美aa国产视频| 欧美精品一区二区三| 欧美日韩国产麻豆| 国产精品人人做人人爽| 国产性天天综合网| 亚洲国产精品一区| 一本一本久久a久久精品综合麻豆| 亚洲视频大全| 久久国产精品久久久久久电车 | 噜噜噜91成人网| 欧美国产1区2区| 欧美性色视频在线| 国产一二精品视频| 亚洲黄一区二区三区| 一区二区三区视频在线播放| 性色一区二区| 亚洲精品美女久久久久| 亚洲自拍偷拍色片视频| 久久久午夜电影| 欧美日韩国产一区精品一区| 国产欧美精品一区二区三区介绍| 1000部国产精品成人观看| 一区二区三区精品视频| 欧美怡红院视频一区二区三区| 亚洲日本激情| 亚洲欧美日韩一区二区| 鲁大师影院一区二区三区| 欧美日韩一区综合| 国产一区二区你懂的| 亚洲精品视频一区| 性感少妇一区| 妖精成人www高清在线观看| 欧美在线播放一区二区| 欧美激情二区三区| 国产欧美一区二区三区久久| 91久久精品一区二区别| 欧美一级久久| 亚洲一区二区三区视频| 老**午夜毛片一区二区三区| 国产精品www色诱视频| 在线观看福利一区| 亚洲一区二区少妇| 99re66热这里只有精品4| 久久精品欧美日韩| 国产精品久久久久久久久搜平片 | 欧美电影资源| 国产视频欧美视频| 一区二区免费看| 亚洲激情视频在线| 欧美一级艳片视频免费观看| 欧美精品一区三区在线观看| 国内揄拍国内精品少妇国语| 在线亚洲一区观看| 亚洲级视频在线观看免费1级| 欧美亚洲三区| 欧美日韩一区二区三区免费看| 在线播放日韩| 午夜伦欧美伦电影理论片| 亚洲视频免费观看| 欧美福利视频在线观看| 国产一区日韩一区| 亚洲欧美日韩精品久久| 亚洲视频一区在线| 欧美激情免费在线| 一区免费观看| 欧美亚洲尤物久久| 性欧美办公室18xxxxhd| 欧美三级网址| 亚洲精品女av网站| 亚洲人成亚洲人成在线观看| 久久免费少妇高潮久久精品99| 国产精品亚洲美女av网站| 一区二区三区www| 一区二区三区视频在线看| 欧美成人三级在线| 一区二区三区中文在线观看| 性色av一区二区三区红粉影视| 亚洲欧美日韩精品在线| 欧美揉bbbbb揉bbbbb| 亚洲精品在线视频| 亚洲精品国精品久久99热| 麻豆av福利av久久av| 国内精品一区二区三区| 欧美有码在线视频| 久久久精品动漫| 国内一区二区三区| 亚洲黄色天堂| 欧美福利小视频| 亚洲区欧美区| 夜夜爽99久久国产综合精品女不卡 | 一本久久a久久精品亚洲| 欧美激情一区二区三区在线| 在线日韩欧美| 亚洲精品久久久久久久久久久久久| 欧美xart系列高清| 在线观看中文字幕亚洲| 亚洲欧洲中文日韩久久av乱码| 欧美成人四级电影| 亚洲欧洲日韩女同| 在线一区亚洲| 国产精品美女视频网站| 欧美亚洲免费| 久久综合一区二区三区| 亚洲高清一二三区| 在线视频中文亚洲| 国产精品久久久久77777| 亚洲综合色在线| 久久久精品免费视频| 激情欧美一区二区三区| 91久久精品视频| 欧美日韩精品一区二区| 亚洲丝袜av一区| 久久精品国产精品亚洲综合| 一区二区在线视频| 一个人看的www久久| 国产精品家庭影院| 翔田千里一区二区| 牛人盗摄一区二区三区视频| 亚洲精品视频中文字幕| 午夜精品国产更新| 狠狠色综合一区二区| 亚洲精品一区二区三区av| 欧美日韩日本国产亚洲在线| 亚洲小视频在线| 久久久精品网| 亚洲激情国产| 亚洲免费小视频| 海角社区69精品视频| 日韩午夜在线观看视频| 国产精品热久久久久夜色精品三区| 欧美在线日韩| 欧美精品久久久久久久免费观看 | 久久国产精品久久国产精品| 欧美精品自拍| 亚洲综合第一| 欧美成人精品在线视频| 在线视频日韩| 美女露胸一区二区三区| 日韩午夜免费| 久久精品中文字幕一区| 91久久精品日日躁夜夜躁欧美| 亚洲欧美成人一区二区在线电影| 韩日欧美一区二区三区| 亚洲视频国产视频| 黄色一区二区在线| 亚洲一级一区| 亚洲成色777777女色窝| 亚洲欧美日韩精品一区二区| 永久555www成人免费| 午夜欧美大片免费观看| 亚洲国产成人91精品| 欧美一级免费视频| 亚洲免费电影在线观看| 久久精品中文| 一区二区三区欧美激情| 久久综合亚州| 亚洲欧美日韩综合国产aⅴ| 欧美区一区二| 久久精品九九| 国产精品美女久久久久久2018 | 在线观看成人小视频| 欧美在线视频免费播放| 亚洲精品久久久久久久久| 久久久一二三| 亚洲一区激情| 欧美日韩国产综合网| 亚洲黑丝在线| 国产在线观看一区|