crc校驗(yàn)原理分析

crc校驗(yàn)原理分析

ID:45565001

大?。?7.75 KB

頁數(shù):21頁

時(shí)間:2019-11-14

crc校驗(yàn)原理分析_第1頁
crc校驗(yàn)原理分析_第2頁
crc校驗(yàn)原理分析_第3頁
crc校驗(yàn)原理分析_第4頁
crc校驗(yàn)原理分析_第5頁
資源描述:

《crc校驗(yàn)原理分析》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在工程資料-天天文庫。

1、CRC校驗(yàn)校驗(yàn)原理:K循環(huán)校驗(yàn)碼(CRC碼):是數(shù)據(jù)通信領(lǐng)域屮最常用的一種差錯(cuò)校驗(yàn)碼,其特征是信息字段和校驗(yàn)字段的長(zhǎng)度可以任意選定。2、生成CRC碼的基本原理:任意一個(gè)由二進(jìn)制位串組成的代碼都可以和一個(gè)系數(shù)僅為’(T和'1,取值的多項(xiàng)式一一對(duì)應(yīng)。例如:代碼1010111對(duì)應(yīng)的多項(xiàng)式為x6+x4+x2+x+l,而多項(xiàng)式為x5+x3+x2+x+l對(duì)應(yīng)的代碼lOllllo3、CRC碼集選擇的原則:若設(shè)碼字長(zhǎng)度為N,信息字段為K位,校驗(yàn)字段為R位(N二K+R),則對(duì)于CRC碼集中的任一碼字,存在且僅存在一個(gè)R次多項(xiàng)式g(x),使得V(x)=A(x)g(x)=xRm(x)+r(x);其中:m(x

2、)為K次信息多項(xiàng)式,r(x)為R-1次校驗(yàn)多項(xiàng)式,g(x)稱為生成多項(xiàng)式:g(x)=go+gix+g2x2+...+g(R-i>x(R_1>+gRxR發(fā)送方通過指定的g(x)產(chǎn)生CRC碼字,接收方則通過該g(x)來驗(yàn)證收到的CRC碼字。4、CRC校驗(yàn)碼軟件生成方法:借助于多項(xiàng)式除法,其余數(shù)為校驗(yàn)字段。例如:信息字段代碼為:1011001;對(duì)應(yīng)m(x)=x6+x4+x3+l假設(shè)生成多項(xiàng)式為:g(x)=xW+l;則對(duì)應(yīng)g(x)的代碼為:11001xm(x)=xIO+xs+x7+x4對(duì)應(yīng)的代碼記為:10110010000;發(fā)送方:發(fā)岀的傳輸字段為:10110011010信息字段校驗(yàn)字段接收方

3、:使用相同的生成碼進(jìn)行校驗(yàn):接收到的字段/生成碼(二進(jìn)制除法)如果能夠除盡,則止確,CRC校驗(yàn)源碼分析這兩天做項(xiàng)目,需要用到CRC校驗(yàn)。以前沒搞過這東東,以為挺簡(jiǎn)單的。結(jié)果看看別人提供的匯編源程序,屆然看不懂?;藘商鞎r(shí)間研究了一下CRC校驗(yàn),希槊我寫的這點(diǎn)東西能夠幫助和我有同樣困惑的朋友節(jié)省點(diǎn)時(shí)間。先是在網(wǎng)上下了一堆亂七八遭的資料下來,感覺都是一個(gè)模樣,全都是從CRC的數(shù)學(xué)原理開始,一長(zhǎng)串的表達(dá)式看的我頭暈。第一次接觸還真難以理解。這些東西不想在這里講,隨便找一下都是一大把。我想根據(jù)源代碼來分析會(huì)比較好懂一些。費(fèi)了老大功夫,才搞清楚CRC根據(jù)”權(quán)”(即多項(xiàng)表達(dá)式)的不同而相應(yīng)的源代碼

4、也有稍許不同。以下是各種常用的權(quán)。CRC8=X8+X5+X4+1CROCQTT=X16+X12+X5+1CRC16=X16+X15+X5+1CRC12=X12+X11+X3+X2+1CRC32=X32+X26+X23+X22+X16+X12+X11+X10+X8+X7+X5+X4+X2+X1+1以下的源程序全部以COTT為例。其實(shí)本質(zhì)都是一樣,搞明白一種,其他的都是小菜。圖1,圖2說明了CRC校驗(yàn)中CRC值是如何計(jì)算出來的,體現(xiàn)的多項(xiàng)式正是X16+X12+X5+1。SerialData即是需要校驗(yàn)的數(shù)據(jù)。從把數(shù)據(jù)移位開始計(jì)算,將數(shù)據(jù)位(從最低的數(shù)據(jù)位開始)逐位移入反向耦合移位寄存器(這

5、個(gè)名詞我也不懂,覺得蠻酷的,就這樣寫了,嘿)。當(dāng)所有數(shù)據(jù)位都這樣操作后,計(jì)算結(jié)束。此時(shí),16位移位寄存器中的內(nèi)容就是CRC碼。LSB圖1生成CRC?CC1TT的移位寄存器的作用原理

6、cla~

7、cLk~rcii

8、cik1

9、cik~nnk■—

10、dk~

11、cii~~「d~~i

12、』"-k平bgudohK)h_cpjkjnbgk.dop_dckKfl圧JL圖2用于計(jì)算CRC_CC1T1、的移位寄心器的電路配置圖中進(jìn)行XOR運(yùn)算的位與多項(xiàng)式的表達(dá)相對(duì)應(yīng)。X5代表Bit5,X12代表Bit12,1自然是代表BitO,X16比較特別,是指移位寄存器移出的數(shù)據(jù),即圖中的DATAOUT.可以這樣理解,與數(shù)據(jù)

13、位做XOR運(yùn)算的是上次CRC值的Bit15。根據(jù)以上說明,可以依葫蘆畫瓢的寫出以下程序。(程序都是在keilC7.10下調(diào)試的)typedefunsignedcharuchar;typedefunsignedintuint;codeucharcrcbuff[]={0x00,0x00,0x00,0x00,0x06,0x0d,0xd2,0xe3};uintcrc;//CRC碼voidmain(void){uchar*ptr;crc=0;//CRC初值ptr=crcbuff;//指向第一個(gè)Byte數(shù)據(jù)crc=crc16l(ptr,8);while(1);uintcrc16l(uchar*pt

14、r,ucharlen)//ptr為數(shù)據(jù)指針,len為數(shù)據(jù)長(zhǎng)度{uchari;while(len-){for(i=0x80;i!=0;i>>=1){if((crc&0x8000)!=0){crc<<=1;crcA=0x1021;}1-1elsecrc<<=1:1-2if((*ptr&i)!=0)crcA=0x1021;1-3}ptr++;}return(crc);}執(zhí)行結(jié)果crc=OxdbcO;程序1-1,1-2,1-3可以理解成移位前crc的B

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動(dòng)畫的文件,查看預(yù)覽時(shí)可能會(huì)顯示錯(cuò)亂或異常,文件下載后無此問題,請(qǐng)放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫負(fù)責(zé)整理代發(fā)布。如果您對(duì)本文檔版權(quán)有爭(zhēng)議請(qǐng)及時(shí)聯(lián)系客服。
3. 下載前請(qǐng)仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動(dòng)等原因無法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶請(qǐng)聯(lián)系客服處理。