新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 嵌入式環(huán)境下串行幀通信的設(shè)計與實(shí)現(xiàn)

嵌入式環(huán)境下串行幀通信的設(shè)計與實(shí)現(xiàn)

作者: 時間:2011-02-17 來源:網(wǎng)絡(luò) 收藏

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

本文引用地址:http://butianyuan.cn/article/151026.htm

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ū)ο缶幊痰姆椒?,把鏈路層代碼封裝在一個類中,向應(yīng)用程序提供一些較為簡單的功能接口,如發(fā)送數(shù)據(jù),接收數(shù)據(jù),檢測對端是否可達(dá)等,就可以很好地解決易用性問題。另外當(dāng)數(shù)據(jù)發(fā)送失敗時,應(yīng)當(dāng)以返回值或事件方式通知應(yīng)用程序,當(dāng)有應(yīng)用層數(shù)據(jù)需要處理時,最好以回調(diào)函數(shù)或事件方式激活應(yīng)用層處理程序,以避免應(yīng)用程序低效的循環(huán)檢測。通過在協(xié)議設(shè)計和協(xié)議實(shí)現(xiàn)兩個方面同時進(jìn)行優(yōu)化,該協(xié)議在實(shí)際應(yīng)用過程中表現(xiàn)出極好的可靠性和一定的通用性,可供參考借鑒。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

上一頁 1 2 下一頁

關(guān)鍵詞: 嵌入式 通信

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉