CRC8校验分析(修正版)

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

CRC即循环冗余校验码(Cyclic Redundancy Check):是数据通信领域中最常用的一种差错校验码,其特征是信息字段和校验字段的长度可以任意选定。(网上流行的这一篇文章,前后两种算法得出来的CRC校验码并不一样,经过多次比对,发现查表法算出来的是正确的.一般性算法却不对,最后总结出来的是每一字节的被除数要反过来读取,算完后余数[即CRC码]也要反过来读取才对,不知何故,如果你懂,请发博文告诉大家.)

CRC校验可以简单地描述为:例如我们要发送一些数据(信息字段),为了避免一些干扰以及在接收端的对读取的数据进行判断是否接受的是真实的数据,这时我们就要加上校验数据(即CRC校验码),来判断接收的数据是否正确。在发送端,根据要传送的k位二进制码序列,以一定的规则(CRC校验有不同的规则。这个规则,在差错控制理论中称为“生成多项式”。)产生一个校验用的r位校验码(CRC码),附在原始信息后边,构成一个新的二进制码序列数共

k+r位,然后发送出去。在接收端,根据信息码和CRC码之间所遵循的规则(即与发送时生成CRC校验码相同的规则)进行检验,校验采用计算机的模二除法,即除数和被除数(即生成多项式)做异或运算,进行异或运算时除数和被除数最高位对齐,进行按位异或运算,若最终的数据能被除尽,则传输正确;否则,传输错误。

CRC8即最终生成的CRC校验码为1字节,其生成多项式,生成多项式为g(x)=x8+x5+x4+1,相当于g(x)=1·x8+0·x7+0·x6+1·x5+1·x4+0·x3+0·x2+0·x1+1·x0,即对应的二进制数为100110001。

CRC8校验算法:

1.CRC8校验的一般性算法:

例如:信息字段代码为: 0X01 0X02 ————对应m(x)=x8+x

(00000001) (00000010)

反过来读取,即为10000000 01000000

生成多项式为:g(x)=x8+x5+x4+1 ————对应g(x)的二进制代码为:100110001

现在我们将要对2字节数据0x0102生成CRC8校验码,并最终将生成的1字节CRC校验码跟在0x0102的后面,即0x01 02 ##,(##即8为CRC码),最终生成的3字节数据就是经CRC8校验生成的数据。

先计算x8m(x)=x16+x9,对应的2进制数为:10000000 01000000 00000000 。可以看到这样运算所得到的结果其实就是将信息字段代码的数左移8位。因为最终要将生成的8位CRC8校验码附在信息字段的后面,所以要将信息字段的数左移8位。最后用x8m(x)得到的二进制数对生成多项式g(x)进行模二运算,最终的余数(其二进制数的位数一定比生成多项式g(x)的位数小)就是所要的CRC8校验码。

10000000 01000000 00000000

^10011000 1

---------------------------

11000 11000000 00000000

^10011 0001

---------------------------

1011 11010000 00000000

^1001 10001

---------------------------

10 01011000 00000000

^10 0110001

---------------------------

111010 00000000

^100110 001

---------------------------

11100 00100000

^10011 0001

---------------------------

1111 00110000

^1001 10001

---------------------------

110 10111000

^100 110001

---------------------------

10 01111100

^10 0110001

---------------------------

00011110

对x8m(x)做模二运算取余得00011110,再反过来读取,即为01111000(0x78),这个8位的二进制数就是CRC8校验码。所以,经CRC8校验后研发送的数据就是0x010278。

2.CRC8校验在DS18B20中的应用:

以上分析的是常规的CRC8校验方法。在DS18B20中,有两处用到CRC。一是DS18B20的8字节的序列号,最后一字节是前面七个字节的CRC码,这是为了保证序列号的唯一性与正确性;另一个是在DS18B20内部9字节的高速温度存储器,其第9字节是前面8个字节的CRC 校验码,这是为了温度数据传输的正确性。而在DS18B20中生成CRC码所用到的方法不同于常规生成算法,它采用的是逆序CRC信息单元编码算法,该CRC的生成是由DS18B20中的多项式寄存器通过其中所包含的移位寄存器以及异或门对输入该多项式寄存器的每一位二进制数做一定的运算所得到的CRC码(可以查看Maxim官网上DS18B20的应用笔记Note27,专门介绍DS18B20CRC详细生成过程)。在此列举两种DS18B20CRC校验的C程序。

A.按位运算方法

[cpp]view plaincopyprint?

1. /********************************************************/

2. /*DS18B20的CRC8校验程序*/

3. /********************************************************/

4. u char calcrc_1byte(uchar abyte)

5. {

6. uchar i,crc_1byte;

7. crc_1byte=0; //设定crc_1byte初值为0

8. for(i = 0; i < 8; i++)

9. {

10. if(((crc_1byte^abyte)&0x01))

11. {

12. crc_1byte^=0x18;

13. crc_1byte>>=1;

14. crc_1byte|=0x80;

15. }

16. else

17. crc_1byte>>=1;

18. abyte>>=1;

19. }

20. return crc_1byte;

21. }

22. uchar calcrc_bytes(uchar *p,uchar len)

23. {

24. uchar crc=0;

25. while(len--) //len为总共要校验的字节数

26. {

27. crc=calcrc_1byte(crc^*p++);

28. }

29. return crc; //若最终返回的crc为0,则数据传输正确

30. }

相关文档
最新文档