crc冗余校验;嵌入式端;查表法,文件crc

本文详细介绍了在嵌入式系统中使用查表法和直接计算方式计算文件CRC的方法,包括8位、16位和32位CRC的计算步骤,以及表的生成和使用。重点讨论了完整和精简计算的区别,以及如何利用预计算的表减少计算量。
摘要由CSDN通过智能技术生成

1.简介

本文主要介绍在嵌入式系统上进行文件crc计算的方式,本文不涉及初始化,结果异或值,输入反转,输出反转等内容。

以下所有的视图,均是以大端模式查看的,且不是网络传输过程中的计算,即没有发生高低位的翻转。

1.1 crc计算方式

直接计算和查表法两种方式,这里主要讨论查表法;

1.2 直接计算

按照计算过程是否将完整的crc多项式写出来,分为完整的计算过程和精简的计算过程。

1.2.1 完整的计算

如生成多项式为:x8 + x5 + x4 + 1 ,则其对应的多项式为0x131,如果省略掉最高位,则写为0x31。

下面用这个多项式计算一个字节0x41的crc值:

由上图可知,计算的结果为0x0c,与标准结果计算一致。

1.2.2 精简的计算

由于上述多项式可以精简的写为0x31,多项式的首位1被省略。计算过程可以精简为下图,计算结果也是一样的。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值