CRC校驗(yàn)源碼學(xué)習(xí)
}
ptr++;
}
return(crc);
}
0x8408 就是 CCITT 的反轉(zhuǎn)多項(xiàng)式。
套用別人資料上的話
“反轉(zhuǎn)多項(xiàng)式是指在數(shù)據(jù)通訊時(shí),信息字節(jié)先傳送或接收低位字節(jié),如重新排位影響 CRC計(jì)算速度,故設(shè)反轉(zhuǎn)多項(xiàng)式。”
如
code uchar crcbuff [] = { 0x00,0x00,0x00,0x00,0x06,0x0d,0xd2,0xe3};
反過來(lái)就是
code uchar crcbuff_fan[] = {0xe3,0xd2,0x0d,0x06,0x00,0x00,0x00,0x00};
crc = 0;
ptr = crcbuff_fan;
crc = crc16r(ptr,8);
執(zhí)行結(jié)果 crc = 0x5f1d;
如想驗(yàn)證是否正確,可改
code uchar crcbuff_fan_result[] = {0xe3,0xd2,0x0d,0x06,0x00,0x00,0x00,0x00,0x1d,0x5f};
ptr = crcbuff_fan_result;
crc = crc16r(ptr,10);
執(zhí)行結(jié)果 crc = 0; 符合 CRC 校驗(yàn)的原理。
請(qǐng)注意 0x5f1d 在數(shù)組中的排列中低位在前,正是反相運(yùn)算的特點(diǎn)。不過當(dāng)時(shí)是把我搞的暈頭轉(zhuǎn)向。
在用半字節(jié)查表法進(jìn)行反相運(yùn)算要特別注意一點(diǎn),因?yàn)槭怯乙疲?CRC 移出的 4Bit與數(shù)據(jù) XOR 的操作是在 CRC 的高位端。因此余式表的產(chǎn)生是要以下列數(shù)組通過修改函數(shù)crc16r 產(chǎn)生。
code uchar ban_fan[]=
{0,0x10,0x20,0x30,0x40,0x50,0x60,0x70,0x80,0x90,
0xa0,0xb0,0xc0,0xd0,0xe0,0xf0};
得出余式表
code uint fan_yushi[16]={
0x0000, 0x1081, 0x2102, 0x3183,
0x4204, 0x5285, 0x6306, 0x7387,
0x8408, 0x9489, 0xa50a, 0xb58b,
0xc60c, 0xd68d, 0xe70e, 0xf78f
};
uint ban_fan_crc(uchar *ptr,uchar len)
{
uchar da;
while(len--!=0)
{
da = (uchar)(crc0x000f);
crc >>= 4;
crc ^= fan_yushi [da^(*ptr0x0f)];
da = (uchar)(crc0x000f);
crc >>= 4;
crc ^= fan_yushi [da^(*ptr/16)];
ptr++;
}
return(crc);
}
主程序中
crc = 0;
ptr = crcbuff_fan;
crc = ban_fan_crc(ptr,8);
執(zhí)行結(jié)果 crc = 0x5f1d;
評(píng)論