51内核单片机实现CRC-16校验,同样适用于51内核的其他芯片(只要稍微修改一下PIC芯片同样适用)

这篇博客介绍了如何在51内核的单片机上实现CRC-16校验,提供了三种方法,包括逐位计算、半字节查表和单字节查表计算,并给出了相应的C语言代码实现。每种方法针对不同的运算速度和ROM大小有不同的适用场景。已通过Keil uVision3编译验证。
摘要由CSDN通过智能技术生成

#include "reg52.h"

#define uint8  unsigned char
#define uint16 unsigned int

unsigned char str[]={0x28,0x6D,0x00,0x85,0x00,0x00,0x00,0xCF};

uint16 CRC_16_UP_Bit(uint8 * dat, uint8 len, uint16 oldcrc);
uint16 CRC_16_UP_NiByte(uint8 * dat, uint8 len, uint16 oldcrc);
uint16 CRC_16_UP_Byte(uint8 * dat, uint8 len, uint16 oldcrc);
/*CRC的初始值为0x00,多项式为0xff00,高位在先 */

/*方法一 */
//---------------------------------------
// 功能:逐位计算CRC16(UP_左移正序)
// 输入:
//      uint8 * dat:要计算CRC的数据指针
//      uint8 len  :数据长度
//      uint16 oldcrc:CRC初始值
// 输出:生成的新CRC值
//---------------------------------------
uint16 CRC_16_UP_Bit(uint8 * dat, uint8 len, uint16 oldcrc)
{
   uint8 idata i,j;
   uint16 idata x,crc = oldcrc;
   for(i = 0;i < len;i ++)
   {
       crc = crc ^ (dat[i] << 8);
       for (j = 8;j > 0;j --)
       {
           x = crc & 0x8000;
           crc <<= 1;
           if (x != 0)crc ^= 0xFF00;
       }
   }
   return crc;
}

/*方法二 */
//---------------------------------------
// 半字节CRC16(UP_左移正序) 0xFF00 余式表

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值