新聞中心

CRC校驗源碼分析

作者: 時間:2012-05-16 來源:網(wǎng)絡(luò) 收藏

 }

本文引用地址:http://m.butianyuan.cn/article/149046.htm

  ptr++;

  }

  return(crc);

  }

  0x8408 就是 CCITT 的反轉(zhuǎn)多項式。

  套用別人資料上的話

  “反轉(zhuǎn)多項式是指在數(shù)據(jù)通訊時,信息字節(jié)先傳送或接收低位字節(jié),如重新排位影響 計算速度,故設(shè)反轉(zhuǎn)多項式。”

  如

  code uchar crcbuff [] = { 0x00,0x00,0x00,0x00,0x06,0x0d,0xd2,0xe3};

  反過來就是

  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;

  如想驗證是否正確,可改

  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; 符合 的原理。

  請注意 0x5f1d 在數(shù)組中的排列中低位在前,正是反相運算的特點。不過當(dāng)時是把我搞的暈頭轉(zhuǎn)向。

  在用半字節(jié)查表法進行反相運算要特別注意一點,因為是右移,所以 移出的 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;


上一頁 1 2 3 下一頁

關(guān)鍵詞: 分析 源碼 校驗 CRC

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉