《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 其他 > 業(yè)界動(dòng)態(tài) > CAN總線中循環(huán)冗余校驗(yàn)碼的原理及其電路實(shí)現(xiàn)

CAN總線中循環(huán)冗余校驗(yàn)碼的原理及其電路實(shí)現(xiàn)

2008-08-11
作者:李書(shū)瑞, 李 明, 石龍海

  摘? 要: 在CAN網(wǎng)絡(luò)中傳輸報(bào)文時(shí),噪聲干擾或傳輸中斷等因素往往使接收端" title="接收端">接收端收到的報(bào)文出現(xiàn)錯(cuò)碼。為了及時(shí)可靠地把報(bào)文傳輸給對(duì)方并有效地檢測(cè)錯(cuò)誤,需要采用差錯(cuò)控制。詳細(xì)介紹了CAN總線中循環(huán)冗余校驗(yàn)碼的差錯(cuò)控制原理及其實(shí)現(xiàn)方法" title="實(shí)現(xiàn)方法">實(shí)現(xiàn)方法。

  關(guān)鍵詞: 循環(huán)冗余校驗(yàn)? 差錯(cuò)控制? 報(bào)文

?

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

1 CRC碼檢錯(cuò)的工作原理

  CRC碼檢錯(cuò)是將被處理報(bào)文的比特序列當(dāng)作一個(gè)二進(jìn)制多項(xiàng)式A(x)的系數(shù),該系數(shù)除以發(fā)送方和接收方預(yù)先約定好的生成多項(xiàng)式g(x)后,將求得的余數(shù)p(x)作為CRC校驗(yàn)碼附加到原始的報(bào)文上,并一起發(fā)給接收方。接收方用同樣的g(x)去除收到的報(bào)文B(x),如果余數(shù)等于p(x),則傳輸無(wú)誤(此時(shí)A(x)和B(x)相同);否則傳輸過(guò)程中出錯(cuò),由發(fā)送端重發(fā),重新開(kāi)始CRC校驗(yàn),直到無(wú)誤為止。

  上述校驗(yàn)過(guò)程中有幾點(diǎn)需注意:①在進(jìn)行CRC計(jì)算時(shí),采用二進(jìn)制(模2)運(yùn)算法,即加法不進(jìn)位,減法不借位,其本質(zhì)就是兩個(gè)操作數(shù)進(jìn)行邏輯異或運(yùn)算;②在進(jìn)行CRC 計(jì)算前先將發(fā)送報(bào)文所表示的多項(xiàng)式A[x]乘以xn,其中n為生成多項(xiàng)式g[x]的最高冪值。對(duì)二進(jìn)制乘法來(lái)講,A(x)·xn就是將A(x)左移n位,用來(lái)存放余數(shù)p(x),所以實(shí)際發(fā)送的報(bào)文就變?yōu)锳(x)·xn+p(x);③生成多項(xiàng)式g[x]的首位和最后一位的系數(shù)必須為1。

  圖1為CRC校驗(yàn)的工作過(guò)程。

?

  目前已經(jīng)有多種生成多項(xiàng)式被列入國(guó)際標(biāo)準(zhǔn)中,如:CRC-4、CRC-12、CRC-16、CCITT-16、CRC-32等。CAN總線中采用的生成多項(xiàng)式為g(x)=x15+x14+x10+x8+x7+x4+x3+1??梢钥闯?CAN總線中的CRC校驗(yàn)采用的多項(xiàng)式能夠校驗(yàn)七級(jí),比一般CRC校驗(yàn)(CRC-4、CRC-12、CRC-16等)的級(jí)數(shù)(二~五級(jí))要高許多,因而它的檢錯(cuò)能力很強(qiáng),誤判率極低,成為提高數(shù)據(jù)傳輸質(zhì)量" title="傳輸質(zhì)量">傳輸質(zhì)量的有效檢錯(cuò)手段。

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

2.1 硬件電路" title="硬件電路">硬件電路的特點(diǎn)

  在CAN總線中為了產(chǎn)生CRC碼,硬件電路除了具有復(fù)位和時(shí)鐘信號(hào)以外,還需要以下兩個(gè)控制信號(hào)的參與:①填充位解除信號(hào)destuff,它的有效邏輯值是1;②CRC校驗(yàn)的使能信號(hào)enable,有效邏輯值也為1。該硬件電路的特點(diǎn)是采用選擇器和反相器" title="反相器">反相器代替?zhèn)鹘y(tǒng)設(shè)計(jì)中用的異或門(mén),既實(shí)現(xiàn)了比較功能,又降低了生產(chǎn)成本,同時(shí)也為工程師們提供了一種新的設(shè)計(jì)思路。

2.2 硬件電路圖

  圖2即為實(shí)現(xiàn)CRC碼的硬件電路圖。

?

圖中需要說(shuō)明的幾點(diǎn)如下:①使能信號(hào)和填充位解除信號(hào)省略;②crcnxt代表的邏輯值為輸入報(bào)文序列和CRC寄存器的最高位異或的結(jié)果;③標(biāo)號(hào)0~14所指示的為15位CRC寄存器,上升沿觸發(fā);④標(biāo)號(hào)1~6所指示的為選擇器和反相器的組合邏輯,實(shí)現(xiàn)異或功能,該選擇器的邏輯功能為具體結(jié)構(gòu)如圖3所示。

?

2.3 電路工作過(guò)程

  從以上分析可知:①當(dāng)enable=0時(shí),CRC清0;②當(dāng)enable=1、destuff=1時(shí),進(jìn)行正常的CRC計(jì)算;③當(dāng)enable=1而destuff=0時(shí),正在解除填充位,數(shù)據(jù)暫停傳送。

  在各個(gè)控制信號(hào)均有效時(shí),輸入報(bào)文的每一位都是和CRC寄存器的最高位相異或后移入最低位,同時(shí)寄存器的第13、9、7、6、3、2位均和其最高位異或,結(jié)果分別左移一位;其它未進(jìn)行異或操作的寄存器位值也分別左移一位,直到報(bào)文的每一位都移入CRC寄存器為止,此時(shí)寄存器中的值即為計(jì)算得到的CRC碼。

  如果報(bào)文的比特序列長(zhǎng)度為16,則需要左移16次才能對(duì)報(bào)文的每一位均進(jìn)行處理。如果以Ck表示CRC寄存器的第k位位值、Ck′表示移位后的第k位位值(k=0,1,2,3......15),則移位規(guī)律見(jiàn)表1。

?

3 CRC校驗(yàn)碼的軟件實(shí)現(xiàn)

  CRC校驗(yàn)碼用軟件實(shí)現(xiàn)起來(lái)非常方便。鑒于目前的資料中介紹的方法多使用C語(yǔ)言、匯編語(yǔ)言等實(shí)現(xiàn),而缺乏用硬件描述語(yǔ)言實(shí)現(xiàn),這里給出CRC碼的Verilog HDL之行為級(jí)描述程序。

  本程序在Verilog_XL下編譯通過(guò),同時(shí)在Synopsis上成功進(jìn)行了綜合及優(yōu)化。

  //用Verilog HDL 實(shí)現(xiàn)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^15 h' 4599:

?????????????????????????????????? else

???????? ?????????????????? crc<= {crc(13:0)1'b0}:

???????????????????? end

????????????? end

  endmodule

4 仿真波形

  假設(shè)發(fā)送的是一個(gè)標(biāo)準(zhǔn)格式的遠(yuǎn)程幀,需求的數(shù)據(jù)字節(jié)為8,標(biāo)識(shí)符序列為10101011000,則對(duì)上述程序仿真后的波形如圖4所示。crc序列從第20位開(kāi)始輸出。

?

  CRC校驗(yàn)碼的檢錯(cuò)能力很強(qiáng),并且由于CRC碼檢錯(cuò)的軟件和硬件實(shí)現(xiàn)都很簡(jiǎn)單,因而被廣泛地應(yīng)用于各類數(shù)據(jù)校驗(yàn)中。CRC碼檢錯(cuò)是提高數(shù)據(jù)傳輸質(zhì)量、高效檢錯(cuò)的有力手段。

?

參考文獻(xiàn)

1 陽(yáng)憲惠.現(xiàn)場(chǎng)總線技術(shù)及其應(yīng)用.北京:清華大學(xué)出版,1998

2 http://www.zlgmcu.com/philips/can/about/BOSCH_CAN_V20_cn.pdf

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無(wú)法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問(wèn)題,請(qǐng)及時(shí)通過(guò)電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
性色av香蕉一区二区| 另类综合日韩欧美亚洲| 欧美一区二区三区喷汁尤物| 国产精品99久久久久久久女警 | 欧美午夜精品| 欧美日韩亚洲另类| 欧美日本在线一区| 欧美日韩不卡一区| 欧美日韩麻豆| 国产精品国产亚洲精品看不卡15| 欧美午夜免费影院| 国产精品乱码妇女bbbb| 国产精品久久午夜| 国产精品一区免费观看| 国产欧美三级| 国产主播一区二区三区| 国语自产精品视频在线看抢先版结局 | 久久国产精品99国产精| 欧美一区二区三区视频在线观看 | 亚洲国产精品va在线看黑人| 久久精品国产亚洲aⅴ| 久久精品五月婷婷| 亚洲激情电影中文字幕| 亚洲精品少妇网址| 99国产精品99久久久久久| 妖精视频成人观看www| 麻豆成人综合网| 亚洲激情在线播放| 99国产精品一区| 一区二区三区偷拍| 亚洲欧美一区二区激情| 性色av一区二区三区| 亚洲成人中文| 亚洲精品中文字幕有码专区| 99香蕉国产精品偷在线观看| 一区二区三区欧美视频| 亚洲欧美日韩中文播放| 久久久精品国产免费观看同学| 久久人人97超碰国产公开结果| 免费亚洲电影| 欧美婷婷六月丁香综合色| 国产精品欧美在线| 国产一区二区三区久久久久久久久| 韩国一区二区在线观看| 最新成人av网站| 亚洲一区二区三区视频| 久久成人免费| 一本在线高清不卡dvd| 欧美一区二区在线| 免费在线看成人av| 国产精品99一区| 国内精品视频一区| 日韩午夜电影av| 午夜精品在线看| 日韩视频免费在线| 欧美一区二区三区另类| 欧美成人国产va精品日本一级| 欧美日韩三区四区| 国产一区二区| 亚洲精品一区在线观看香蕉| 午夜国产精品视频| 亚洲日本一区二区三区| 午夜精品久久久99热福利| 美女久久一区| 国产精品日韩欧美大师| 在线播放日韩欧美| 亚洲午夜日本在线观看| 亚洲欧洲一区二区在线观看| 亚洲免费在线观看| 美女日韩欧美| 国产精品视频福利| 亚洲国产一区二区三区在线播| 亚洲一区中文| 亚洲免费电影在线| 久久精品72免费观看| 欧美日韩人人澡狠狠躁视频| 亚洲美女免费视频| 国产亚洲精品bt天堂精选| 亚洲国产美国国产综合一区二区| 亚洲欧美成人一区二区在线电影 | 欧美一站二站| 欧美精品一区二区三区蜜桃| 国产午夜精品一区理论片飘花 | 亚洲第一精品福利| 亚洲欧美日韩久久精品| 欧美激情精品久久久六区热门 | 亚洲视频欧美视频| 免费成人av| 国产一区二区三区久久久久久久久| aa国产精品| 亚洲精品影院| 久久一区二区三区av| 国产精品一区二区三区乱码| 亚洲精品一区在线观看| 最新中文字幕一区二区三区| 久久久久久久尹人综合网亚洲 | 亚洲天天影视| 欧美福利在线观看| 国产亚洲精品一区二555| 亚洲午夜国产成人av电影男同| 日韩香蕉视频| 欧美成人激情视频| 国产主播一区二区三区| 午夜欧美精品久久久久久久| 亚洲男人影院| 欧美亚一区二区| 日韩视频在线一区二区| 亚洲免费观看高清完整版在线观看熊| 久久午夜激情| 激情综合亚洲| 久久精品成人一区二区三区| 久久成人av少妇免费| 国产精品欧美一区二区三区奶水 | 亚洲性人人天天夜夜摸| 欧美精品久久久久久久| 亚洲高清视频中文字幕| 亚洲二区在线视频| 久久亚洲精品一区二区| 国产一区三区三区| 欧美尤物巨大精品爽| 久久久久久久久久久一区| 国产主播一区二区三区四区| 欧美影院久久久| 久久在线免费观看| 尤物99国产成人精品视频| 久久狠狠婷婷| 麻豆精品国产91久久久久久| 有坂深雪在线一区| 最新成人在线| 欧美丰满少妇xxxbbb| 亚洲精品久久久久久久久久久久| 亚洲免费电影在线| 欧美日韩一区二区视频在线观看| 日韩亚洲在线| 亚洲欧美中文字幕| 国产麻豆精品视频| 久久av免费一区| 卡通动漫国产精品| 亚洲国产成人av在线| 99精品国产一区二区青青牛奶 | 亚洲一区二区欧美| 久久精品国产亚洲一区二区| 激情视频一区二区| 日韩视频一区二区三区在线播放| 欧美精品在线视频观看| 中文网丁香综合网| 欧美在线三区| 激情六月婷婷久久| 99国产精品久久久久久久| 欧美日韩中文在线观看| 亚洲在线视频网站| 久久综合国产精品台湾中文娱乐网| 精品51国产黑色丝袜高跟鞋| 亚洲精品国产欧美| 欧美午夜免费影院| 久久不射中文字幕| 欧美黑人国产人伦爽爽爽| 99香蕉国产精品偷在线观看| 欧美制服丝袜第一页| 影音国产精品| 亚洲校园激情| 黑人巨大精品欧美黑白配亚洲 | 久久亚洲一区二区| 亚洲激情女人| 欧美一区成人| 狠狠入ady亚洲精品经典电影| 亚洲国产精品视频一区| 欧美日韩麻豆| 久久激情综合| 欧美三级黄美女| 久久精品99国产精品日本| 欧美日韩亚洲国产精品| 欧美主播一区二区三区| 欧美日本免费| 午夜视频在线观看一区| 欧美激情一区二区三区成人 | 午夜在线一区二区| 欧美精品电影在线| 午夜在线观看欧美| 欧美精品在线观看播放| 午夜精品久久久久久99热| 欧美韩日亚洲| 欧美一级在线亚洲天堂| 欧美日韩三级| 亚洲国产精品视频| 国产精品日韩一区二区| 亚洲人成网站色ww在线| 国产精品伊人日日| 一本色道久久综合狠狠躁篇的优点| 国产日韩在线一区| 亚洲一区二区精品| 在线观看中文字幕不卡| 欧美一区2区视频在线观看| 亚洲精品孕妇| 免播放器亚洲| 欧美专区日韩专区| 国产精品视频自拍| 在线视频精品一| 亚洲福利精品| 久久久久久久一区二区三区|