串口通信校驗方式:奇偶校驗、累加和校驗
利用串口傳輸數(shù)據(jù)時,近距離傳輸還好,遠距離傳輸由于線路長度影響,可能會使信號在傳輸過程中出現(xiàn)不可預(yù)知的錯誤,為了達到通信的穩(wěn)定性,在遠距離通信時一般要引入一種校驗方式來去除干擾。
這里主要介紹幾種常見的校驗方式,也是我們串口通訊板子上需要添加的幾種校驗方式。
即奇校驗ODD,偶校驗EVEN,累加和校驗,CRC循環(huán)碼冗余碼校驗
方便簡單的奇偶校驗
奇偶校驗需要一位校驗位,即使用串口通信的方式2或方式3(8位數(shù)據(jù)位+1位校驗位)。
奇校驗(odd parity):讓傳輸?shù)臄?shù)據(jù)(包含校驗位)中1的個數(shù)為奇數(shù)。
即:如果傳輸字節(jié)中1的個數(shù)是偶數(shù),則校驗位為“1”,奇數(shù)相反。
以發(fā)送字符:10101010為例
偶校驗(even parity):讓傳輸?shù)臄?shù)據(jù)(包含校驗位)中1的個數(shù)為偶數(shù)。
即:如果傳輸字節(jié)中1的個數(shù)是偶數(shù),則校驗位為“0”,奇數(shù)相反。
還是以發(fā)送字符:10101010為例
數(shù)據(jù)和校驗位發(fā)送給接受方后,接收方再次對數(shù)據(jù)中1的個數(shù)進行計算,如果為奇數(shù)則校驗通過,表示此次傳輸過程未發(fā)生錯誤。如果不是奇數(shù),則表示有錯誤發(fā)生,此時接收方可以向發(fā)送方發(fā)送請求,要求重新發(fā)送一遍數(shù)據(jù)。
優(yōu)缺點:
奇偶校驗的檢錯率只有50%,因為只有奇數(shù)個數(shù)據(jù)位發(fā)生變化能檢測到,如果偶數(shù)個數(shù)據(jù)位發(fā)生變化則無能為力了╮(╯﹏╰)╭
奇偶校驗每傳輸一個字節(jié)都需要加一位校驗位,對傳輸效率影響很大。
奇偶校驗只能發(fā)現(xiàn)錯誤,但不能糾正錯誤,也就是說它只能告訴你出錯了,但不能告訴你怎么出錯了,一旦發(fā)現(xiàn)錯誤,只好重發(fā)。
雖然奇偶校驗有很多缺點,但因為其使用起來十分簡單,故目前仍被廣泛使用。
應(yīng)用:
如何用編程確定一個字節(jié)中“1”個數(shù)的奇偶性?我們可以利用二進制數(shù)相加的特點:
0+0=0、1+0=1、1+1=0
可以看出,如果我們將一個字節(jié)的所有位相加
有奇數(shù)個“1”的字節(jié)的和為1
有偶數(shù)個“1”的字節(jié)的和為0
由此即可通過編程完成判斷。實際應(yīng)用中,實現(xiàn)方法很多,但這是相對簡單的一種,這里不再贅述。
累加和校驗
所謂的累加和校驗有很多種,最常見的一種是在每次通信數(shù)據(jù)包最后都加一個字節(jié)的校驗數(shù)據(jù),這個校驗字節(jié)里的數(shù)據(jù)是通信數(shù)據(jù)包里所有數(shù)據(jù)的不進位累加和。例如:
接收方接收到數(shù)據(jù)后同樣對一個數(shù)據(jù)包的數(shù)據(jù)進行不進位累加和計算,如果累加出的結(jié)果與校驗位相同的話就認為傳輸?shù)臄?shù)據(jù)沒有錯誤。
優(yōu)缺點:
實現(xiàn)起來方便簡單,被廣泛運用。
檢錯率一般,例如一個字節(jié)多1,一個字節(jié)少1,則會出現(xiàn)誤判。
和奇偶校驗一樣,只能發(fā)現(xiàn)錯誤,但不能糾正錯誤。
另外,累加和校驗的數(shù)據(jù)傳輸格式可以表示為:通訊數(shù)據(jù)+校驗數(shù)據(jù)。這與我們之后要說的CRC循環(huán)冗余碼校驗是相同的。
審核編輯 :李倩
-
串口通信
+關(guān)注
關(guān)注
34文章
1632瀏覽量
56142 -
串口傳輸
+關(guān)注
關(guān)注
0文章
33瀏覽量
1903
原文標題:FPGA學習-串口通信校驗方式:奇偶校驗、累加和校驗
文章出處:【微信號:gh_9d70b445f494,微信公眾號:FPGA設(shè)計論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
串口通信奇偶校驗問題
奇偶校驗碼
奇偶校驗碼,奇偶校驗碼原理是什么?
stm32串口奇偶校驗
stm32 usart奇偶校驗如何配置

增強FIFO模式下的奇偶校驗
FPGA奇偶校驗的基本原理及實現(xiàn)方法

評論