#include "reg52.h"
#define uint8 unsigned char
unsigned char str[]={0x28,0x6D,0x00,0x85,0x00,0x00,0x00,0xCF};
uint8 CRC_8_UP_NiByte(uint8 * dat, uint8 len, uint8 oldcrc);
uint8 CRC_8_UP_Byte(uint8 * dat, uint8 len, uint8 oldcrc);
uint8 CRC_8_UP_Bit(uint8 * dat, uint8 len, uint8 oldcrc);
/*CRC的初始值为0x00,多项式为0xff,高位在先 */
/*方法一 */
//---------------------------------------
// 半字节CRC8(UP_左移正序) 0xFF 余式表
//---------------------------------------
uint8 code CRC_8_UP_NiByte_Tab[ 16 ] = {
0x00 , 0xFF , 0x01 , 0xFE ,
0x02 , 0xFD , 0x03 , 0xFC ,
0x04 , 0xFB , 0x05 , 0xFA ,
0x06 , 0xF9 , 0x07 , 0xF8
};
//---------------------------------------
// 功能:半字节查表计算CRC8(UP_左移正序)
// 输入:
// uint8 * dat:要计算CRC的数据指针
// uint8 len :数据长度
// uint8 oldcrc:CRC初始值
// 输出:生成的新CRC值
//------------------

这篇博客介绍了如何在51内核单片机上实现CRC-8校验,提供了三种方法:半字节查表、单字节查表和逐位计算,并给出了详细代码。适合不同运算速度和ROM大小的单片机选择。
最低0.47元/天 解锁文章
4517

被折叠的 条评论
为什么被折叠?



