CAN總線(xiàn)中循環(huán)冗余校驗碼的原理及其電路實(shí)現
在CAN系統中為保證報文傳輸的正確性,需要對通信過(guò)程進(jìn)行差錯控制。目前常用的方法是反饋重發(fā),即一旦收到接收端發(fā)出的出錯信息,發(fā)送端便自動(dòng)重發(fā),此時(shí)的差錯控制只需要檢錯功能。常用的檢錯碼兩類(lèi):奇偶校驗碼和循環(huán)冗余校驗碼。奇偶校驗碼是一種最常見(jiàn)的檢錯碼,其實(shí)現方法簡(jiǎn)單,但檢錯能力較差;循環(huán)冗余校驗碼的編碼也很簡(jiǎn)單且誤判率低,所以在通信系統中獲得了廣泛的應用。下面介紹CAN網(wǎng)絡(luò )中循環(huán)冗余校驗碼(即CRC碼)的原理和實(shí)現方法。

1 CRC碼檢錯的工作原理

1 CRC碼檢錯的工作原理
CRC碼檢錯是將被處理報文的比特序列當作一個(gè)二進(jìn)制多項式A(x)的系數,該系數除以發(fā)送方和接收方預先約定好的生成多項式g(x)后,將求得的余數P(x)作為CRC校驗碼附加到原始的報文上,并一起發(fā)給接收方。接收方用同樣的g(x)去除收到的報文B(x),如果余數等于p(x),則傳輸無(wú)誤(此時(shí)A(x)和B(x)相同);否則傳輸過(guò)程中出錯,由發(fā)送端重發(fā),重新開(kāi)始CRC校驗,直到無(wú)誤為止。
上述校驗過(guò)程中有幾點(diǎn)需注意:①在進(jìn)行CRC計算時(shí),采用二進(jìn)制(模2)運算法,即加法不進(jìn)位,減法不借位,其本質(zhì)就是兩個(gè)操作數進(jìn)行邏輯異或運算;②在進(jìn)行CRC計算前先將發(fā)送報文所表示的多項式A(x)乘以xn,其中n為生成多項式g(x)的最高冪值。對二進(jìn)制乘法來(lái)講,A(x)?xn就是將A(x)左移n位,用來(lái)存放余數p(x),所以實(shí)際發(fā)送的報文就變?yōu)锳(x)?xn+p(x);③生成多項式g(x)的首位和最后一位的系數必須為1。
圖1為CRC校驗的工作過(guò)程。
目前已經(jīng)有多種生成多項式被列入國際標準中,如:CRC-4、CRC-12、CRC-16、CCITT-16、CRC-32等。CAN總線(xiàn)中采用的生成多項式為g(x)=x15+x14+x10+x8+x7+x4+x3+1??梢钥闯?,CANU叫線(xiàn)中的CRC校驗采用的多項式能夠校驗七級,比一般CRC校驗(CRC-4、CRC-12、CRC-16等)的級數(二~五級)要高許多,因而它的檢錯能力很強,誤判率極低,成為提高數據傳輸質(zhì)量的有效檢錯手段。

2 CRC碼的電路實(shí)現

2 CRC碼的電路實(shí)現
2.1 硬件電路的特點(diǎn)
在CAN總線(xiàn)中為了產(chǎn)生CRC碼,硬件電路除了具有復位和時(shí)鐘信號以外,還需要以下兩個(gè)控制信號的參與:①填充位解除信號destuff,它的有效邏輯值是1;②CRC檢驗的使能信號enable,有效邏輯也為1。該硬件電路的特點(diǎn)是采用選擇器和反相器代替傳統設計中用的異或門(mén),既實(shí)現了比較功能,又降低了生產(chǎn)成本,同時(shí)也為工程師們提供了一種新的設計思路。
2.2 硬件電路圖
圖2即為實(shí)現CRC碼的硬件電路圖。
圖中需要說(shuō)明的幾點(diǎn)如下:①使能信號和填充位解除信號省略;②crcnxt代表的邏輯值為輸入報文序列和CRC寄存器的最高位異或的結果;③標號0~14所指示的為15位CRC寄存器,上升沿觸發(fā);④標號1~6所指示的為選擇器和反相器的組合邏輯,實(shí)現異或功能,該選擇器的邏輯功能為Y=AB+AC,具體結構如圖3所示。
2.3 電路工作過(guò)程
從以上分析可知:①當enable=0時(shí),CRC清0;②當enable=1、destuff=1時(shí),進(jìn)行正常CRC計算;③當enable=1而destuff=0時(shí),正在解除填充時(shí),數據暫停傳送。
在各個(gè)控制信號均有效時(shí),輸入報文的每一位都是和CRC寄存器的最高位相異和后移入最低位,同時(shí)寄存器的第13、9、7、6、3、2位均和其最高位異或,結果分別左移一位;其它未進(jìn)行異或操作的寄存器位值也分別左移一位,直到報文的每一位都移入CRC寄存器為止,此時(shí)寄存器中的值取為計算得到的CRC碼。
如果報文的比特序列長(cháng)度為16,則需要左移16次才能對報文的每一位均進(jìn)行處理。如果以Ck表示CRC寄存器的第k位位值、Ck‘表示移位后的第k位位值(k=0,1,2,3……15),則移位規律見(jiàn)表1。
表1 移位規律表
表1 移位規律表
3 CRC校驗碼的軟件實(shí)現
CRC校驗用軟件實(shí)現起來(lái)非常方便。鑒于目前的資料中介紹的方法多使用C語(yǔ)言、匯編語(yǔ)言等實(shí)現,而缺乏用硬件描述語(yǔ)言實(shí)現,這里給出CRC碼的Verilog HDL之行為級描述程序。
本程序在Verilog_XL下編譯通過(guò),同時(shí)在Synopsis上成功進(jìn)行了綜合及優(yōu)化。
//用Verilog HDL實(shí)現CRC碼
module crc(clk,rst,enable,destuff,datain,crc);
input clk;
input rst;
input enable;
input destuff;
input datain;
output[14:0]crc;
reg[14:0]crc;
wire crcnxt=datain^crc[14];
always@(posedge rst or posedge clk)
begin
if(rst)crc=0;
else if(enable destuff)
begin
if(crcnxt)
crc=crc^15h‘4599;
else
crc={crc[13:0],1‘b0};
end
end
endmodule

4 仿真波形
假設發(fā)送的是一個(gè)標準格式的遠程幀,需求的數據字節為8,標識符序列為10101011000,則對上述程序仿真后的波形如圖4所示。Crc序列從第20位開(kāi)始輸出。
CRC校驗碼的檢錯能力很強,并且由于CRC碼檢錯的軟件和硬件實(shí)現都很簡(jiǎn)單,因而被廣泛地應用于各類(lèi)數據校驗中。CRC碼檢錯是提高數據傳輸質(zhì)量、高效檢錯的有力手段。
DIY機械鍵盤(pán)相關(guān)社區:機械鍵盤(pán)DIY
評論