標(biāo)準(zhǔn)
根據(jù)應(yīng)用環(huán)境與習(xí)慣的不同,CRC又可分為以下幾種標(biāo)準(zhǔn):
?、貱RC-12碼;
?、贑RC-16碼;
?、跜RC-CCITT碼;
?、蹸RC-32碼。
CRC-12碼通常用來傳送6-bit字符串。
CRC-16及CRC-CCITT碼則是用來傳送8-bit字符串,其中CRC-16為美國采用,而CRC-CCITT為歐洲國家所采用。
CRC-32碼大都被采用在一種稱為Point-to-Point的同步傳輸中。
生成過程
下面以最常用的CRC-16為例來說明其生成過程。
CRC-16碼由兩個字節(jié)構(gòu)成,在開始時CRC寄存器的每一位都預(yù)置為1,然后把CRC寄存器與8-bit的數(shù)據(jù)進(jìn)行異或(異或:二進(jìn)制運算 相同為0,不同為1;0^0=0;0^1=1;1^0=1;1^1=0),
之后對CRC寄存器從高到低進(jìn)行移位,在最高位(MSB)的位置補零,而最低位(LSB,移位后已經(jīng)被移出CRC寄存器)如果為1,則把寄存器與預(yù)定義的多項式碼進(jìn)行異或,否則如果LSB為零,則無需進(jìn)行異或。重復(fù)上述的由高至低的移位8次,第一個8-bit數(shù)據(jù)處理完畢,用此時CRC寄存器的值與下一個8-bit數(shù)據(jù)異或并進(jìn)行如前一個數(shù)據(jù)似的8次移位。所有的字符處理完成后CRC寄存器內(nèi)的值即為最終的CRC值。
計算過程
1.設(shè)置CRC寄存器,并給其賦值FFFF(hex)。
2.將數(shù)據(jù)的第一個8-bit字符與16位CRC寄存器的低8位進(jìn)行異或,并把結(jié)果存入CRC寄存器。
3.CRC寄存器向右移一位,MSB補零,移出并檢查LSB。
4.如果LSB為0,重復(fù)第三步;若LSB為1,CRC寄存器與多項式碼相異或。
5.重復(fù)第3與第4步直到8次移位全部完成。此時一個8-bit數(shù)據(jù)處理完畢。
6.重復(fù)第2至第5步直到所有數(shù)據(jù)全部處理完成。
7.最終CRC寄存器的內(nèi)容即為CRC值。
常用的CRC循環(huán)冗余校驗標(biāo)準(zhǔn)多項式如下:
CRC(12位) =X12+X11+X3+X2+X+1
CRC(16位) = X16+X15+X2+1
CRC(CCITT) = X16+X12 +X5+1
CRC(32位) = X32+X26+X23+X16+X12+X11+X10+ X8+X7+X5+X4+X2+X+1
以CRC(16位)多項式為例,其對應(yīng)校驗二進(jìn)制位列為1 1000 0000 0000 0101。
注意:這兒列出的標(biāo)準(zhǔn)校驗多項式都含有(X+1)的多項式因子;各多項式的系數(shù)均為二進(jìn)制數(shù),所涉及的四則運算仍遵循對二取模的運算規(guī)則。
(注:對二取模的四則運算指參與運算的兩個二進(jìn)制數(shù)各位之間凡涉及加減運算時均進(jìn)行XOR異或運算,即:1 XOR 1=0,0 XOR 0=0,1 XOR 0=1,0 XOR 1=1,即相同為0,不同為1)
(全球TMT2022年8月30日訊)近日,浪潮M6服務(wù)器的帶外管理模塊固件BMC獲得了由中國網(wǎng)絡(luò)安全審查技術(shù)與認(rèn)證中心發(fā)布的IT產(chǎn)品信息安全認(rèn)證EAL4證書,這表明浪潮M6系列服務(wù)器在產(chǎn)品及信息安全保障方面均獲得頂級認(rèn)...
關(guān)鍵字: 信息安全 網(wǎng)絡(luò)安全 ASSURANCE CRCdsPIC33CH/dsPIC33CK系列數(shù)字電源控制器芯片,在目前諸多典型應(yīng)用中都得到了廣泛使用。在閉環(huán)控制中,尤其是電壓模式控制中,對PWM數(shù)據(jù)寄存器進(jìn)行實時更新是必要的一個動作,本文主要就這一話題做一些分析和討論
關(guān)鍵字: 數(shù)字電源控制器 寄存器中國,北京 – 2022年5月5日 – Analog Devices, Inc.(Nasdaq:ADI)推出新一代16至24位超高精度逐次逼近寄存器(SAR)模數(shù)轉(zhuǎn)換器(ADC)系列產(chǎn)品,可簡化儀器儀表、工業(yè)和醫(yī)療健康應(yīng)...
關(guān)鍵字: ADI 模數(shù)轉(zhuǎn)換器 寄存器外部數(shù)據(jù)總線是中央處理器CPU(Central Processing Unit)的一部分,是CPU與外部數(shù)據(jù)傳輸?shù)耐ǖ?。外部?shù)據(jù)總線一次可傳輸二進(jìn)制數(shù)據(jù)的位數(shù)越大,CPU與外部交換數(shù)據(jù)的能力越強。
關(guān)鍵字: 外部數(shù)據(jù)線 CPU 二進(jìn)制