基于E2P读写的CRC-16校验

本文主要介绍了在E2P读写过程中,遇到的CRC-16校验错误问题。通过详细解析CRC校验原理,包括CRC码的生成与计算方法,展示了如何在实际应用中进行CRC-4和CRC-16的校验。同时,提供了基于CRC-16的E2P读写操作示例代码,用于确保数据完整性和正确性。
摘要由CSDN通过智能技术生成

    在调试客户使用平台下测试出E2P读CRC校验码的BUG。在客户重复上电的情况下,读E2P CRC校验数据不匹配,导致设置默认参数数据进行系统初始化。此问题开始没有重视,最终测试到时CRC校验出错。

以下是CRC原理,算法可以不用太了解。



一、什么是CRC校验
    
循环校验码(Jyclic Redundancy Check,简称CRC码): 是数据通信领域中最常用的一种差错校验码,其特征是信息字段和校验字段的长度可以任意选定。


二、CRC校验计算
      CRC码是由两部分组成,前部分是信息码,就是需要校验的信息,后部分是校验码,如果CRC码共长n个bit,信息码长k个bit,它的编码规则是:
      1、首先将原信息码(kbit)左移r位(k+r=n),对应多项式为m(x)。
      2、运用一个生成R次多项式g(x)(也可看成二进制数)用模2除上面的式子,得到的
余数就是校验码,r=R。
      
非常简单,要说明的:模2除就是在除的过程中用模2加,模2加实际上就是我们熟悉的异或运算,就是加法不考虑进位,公式是:    
      
0+0=1+1=0,1+0=0+1=1,即‘异’则真,‘非异’则假。
      由此得到定理:a+b+b=a 也就是
‘模2减’和‘模2加’直值表完全相同。 
      有了加减法就可以用来定义模2除法,于是就可以用生成多项式g(x)生成CRC校验码。
      例如:代码
1010111对应的多项式为x6+x4+x2+x+1,而多项式为x5

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值