CRC-8/MAXIM验证实战记录

使用的CRC-8/MAXIM: 

参数模型: x8+x5+x4+1 

在调试MAXIM一款ds2401芯片的时候,crc的验证

成功代码记录:

环境采用了啊哈C编译 代码来自网络

  1. #include <stdio.h>  
  2. #include <stdlib.h>  
  3.   
  4. //CRC8  CRC 校验的等效多项式是: CRC = x8 + x5 + x4 + 1 DS2401  
  5. /* 
  6. 测试用例 
  7. 使用的CRC-8/MAXIM:  
  8. 参数模型: x8+x5+x4+1  
  9. 多项式(hex):31  
  10. 计算CRC初始值(hex):00  
  11. 计算结果异或值(hex): 00 
  12.  
  13. 输入Ascii:123456789  
  14. 结果(hex):A1  
  15. */  
  16. unsigned char CRC8Calculate(void *pBuf ,unsigned pBufSize)  
  17. {  
  18.     unsigned char retCRCValue=0x00;  
  19.     unsigned char *pData;  
  20.     int i=0;  
  21.     unsigned char pDataBuf=0;  
  22.   //  retCRCValue=0x01;  
  23.     pData=(unsigned char *)pBuf;  
  24.    // pDataBuf=pData[0];  
  25.    // cout<<hex<<pDataBuf<<endl;  
  26.   
  27.      while(pBufSize--)  
  28.      {  
  29.          pDataBuf=*pData++;  
  30.          for(i=0;i<8;i++)  
  31.          {  
  32.              if((retCRCValue^(pDataBuf))&0x01)  
  33.              {  
  34.                  retCRCValue^=0x18;  
  35.                  retCRCValue>>=1;  
  36.                  retCRCValue|=0x80;  
  37.              //    printf("i=%d;retCRCValue=%x\n",i,retCRCValue);  
  38.              }  
  39.              else  
  40.              {  
  41.                    retCRCValue>>=1;  
  42.              //     printf("i=%d;retCRCValue=%x\n",i,retCRCValue);  
  43.              }  
  44.             pDataBuf>>=1;  
  45.          }  
  46.      }  
  47.      return retCRCValue;  
  48. }     
  49.   
  50.   
  51.   
  52. int main()  
  53. {  
  54. #if 0  
  55. //输入Ascii:123456789   
  56. //结果(hex):A1   
  57.     unsigned char tempbuffer[15]={0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39,0x00,0x00,0x00,0x00 };  
  58.     int i=0;  
  59.     tempbuffer[10]=CRC8Calculate(tempbuffer,9);  
  60.       
  61. #endif  
  62.   
  63.     unsigned char tempbuffer[15]={0x02,0x24,0x8b,0x00,0x10,0x00,0x00,0x38,0x39,0x00,0x00,0x00,0x00 };  
  64.     int i=0;  
  65.     tempbuffer[10]=CRC8Calculate(tempbuffer,7);  
  66.   
  67.     for(i=0;i<15;i++)  
  68.     {  
  69.        printf("%x ",tempbuffer[i]);  
  70.     }  
  71.     printf("\n");  
  72.       
  73.       
  74.       
  75.       
  76.       
  77.     system("pause");  
  78.     return 0;  
  79. }  
  程序运行:

逻辑分析仪:




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值