8位循环冗余检验crc校验说明.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
/****************************************************************************** ** 软件名称:CRC 算法说明 ** 功能描述: 最近看的CRC-8 资料,分享如下 ** 公司名称: ROBAM ** 作 者:顾长超 ** 芯 片: ** 日 期: 2017-8-1 ** 修改日期: ******************************************************************************/ 第一部分 //===========================CRC-8 原理说明================================== //CRC(Cyclic Redundancy Check):是数据通信领域中最常用的一种差错校验码, //其特征是信息字段和校验字段的长度可以任意选定。 //CRC 校验可以简单地描述为:例如我们要发送一些数据(信息字段), //为了避免一些干扰以及 在接收端的对读取的数据进行判断是否接受的是真实的数据, //这时我们就要加上校验数据(即CRC 校验码),来判断接收的数据是否正确。 //在发送端,根据要传送的k 位二进制码序列,以一定的规则(CRC 校验有不同的规则。 //这个规则,在差错控制理论中称为生成多项式。)产生一个校验用的r 位校验码(CRC 码), //附在原始信息后边,构成一个新的二进制码序列数共k+r 位,然后发送出去。在接收端, //根据信息码和CRC 码之间所遵循的规则(即与发送时生成CRC 校验码相同的规则)进行检 验, //校验采用计算机的模二除法,即除数和被除数(即生成多项式)做异或运算, //进行异或运算时除数和被除数最高位对齐,进行按位异或运算,若最终的数据能被除尽, //则传输正确;否则,传输错误。 //CRC-8 即最终生成的 CRC 校验码为 1 字节,其生成多项式,生成多项式为 g(x)=x^8+x^5+x^4+x^0, //相当于g(x)=1·x^8+0·x^7+0·x^6+1·x^5+1·x^4+0·x^3+0·x^2+0·x^1+1·x^0, //即对应的二进制数为100110001。 //=============================CRC-8 校验算法======================= //a.信息字段代码为: m(x) = 0x0102 = x^8+x^1 = 1 0000,0010 //b.多项式为:g(x) =x^8+x^5+x^4+x^0= 0x0131 = 100110001 //高位对齐: 1 0000,0010 0000,0000 //注:0x01028 (m(x)左移8 位) 100110001 //^ g(x)^m(x) 做模二运算,最终的余数就是所要的CRC8 校验码 -----------------------------------------//(其二进制数的位数一定比生成多项式g(x)的位数小) 000110011100110001 // ^ 高位为1 对齐 ------------------------------------------------------------- 01010100100000 100110001 // ^ ------------------------------------------------------------- 0011000110000 100110001 // ^ ------------------------------------------------------------- 01011110100 100110001 // ^ ------------------------------------------------------------- 0010010110 //最后生成的只有 8 位就是所要的 CRC8 校验码,前面的 0 不算,以 1 为准 = 0x96 第二部分 //==============================SHT3X 规格书验证============================== // 代码如下: static u8t SHT3X_CalcCrc(u8t data[], u8t nbrOfBytes) { u8t bit; // bit mask u8t crc = 0xFF; // calculated checksum u8t byteCtr; // byte counter // calculat

文档评论(0)

137****0427 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档