小羽哟 2014-03-12 11:25 采纳率: 0%
浏览 2245

请教下,crc检测问题? 我debug。还是不知道错误,o(︶︿︶)o 唉

/************************************************

  • FUNCTION: *
  • 单字节的 crc验证 *
  • INPUT: *
  • R 余数 *
  • PARAMETER: *
  • POLY:生成多项式 *
  • MSB:最高位 *
  • crc:源信息码 *
  • crc_r:余数(crc码) * ************************************************/

#include
#define POLY 0xEDB88320
#define MSB 0x80000000

typedef unsigned long CRC32;
typedef unsigned char BYTE;

CRC32 crc_test(BYTE crc, int len);

int main(int argc, char **argv)
{

CRC32 result;
BYTE crc_num[] = {0x49,0x48,0x44,0x52,0x00,0x00,0x00,0xC8,0x00, 0x00,0x00,0x96,0x08,0x03,0x00,0x00, 0x00};
//printf("%d\n", (int)crc_test(0xb3));
result = crc_test(crc_num, sizeof(crc_num));
printf("0x%x\n", (int)result);

return 0;

}

CRC32 crc_test(BYTE *crc, int len)
{
int i, lens;
CRC32 crc_t = 0, current;

for (lens=0; lens<len; lens++)
{
    current = crc[lens] << 32;

    for (i=0; i<8; i++)
    {
        if ( (CRC32)(current ^ crc_t) < 0 )
        {
            crc_t = (crc_t<<1) ^ POLY;
        }
        else{
            crc_t <<= 1;
        }

        if ( (*crc) & i )
        {
            crc_t ^= POLY;
        } 

        current <<= 1; 
    }
}
return crc;

}

由0x49,0x48,0x44,0x52,0x00,0x00,0x00,0xC8,0x00, 0x00,0x00,0x96,0x08,0x03,0x00,0x00, 0x00得出的
crc码,正确的应该是:AC 02 37 2B

我的计算 错啦 不过位数一样 求教!!~~

  • 写回答

2条回答

  • 赵4老师 2014-03-13 05:25
    关注

    /************************************************
    FUNCTION:
    单字节的 crc验证
    INPUT:
    R 余数
    PARAMETER:
    POLY:生成多项式
    MSB:最高位
    num:初始化为 信息码,之后是余数
    ************************************************/
    #include
    #define POLY 0x19u
    #define MSB 0x80000000u
    typedef unsigned int BYTE;

    BYTE crc_test(BYTE num);

    int main() {
    printf("%u\n", crc_test(0xb3u));
    return 0;
    }

    BYTE crc_test(BYTE num) {
    num <<= 4;
    while (num>POLY) {
    //printf("\n");
    if (num & MSB) {
    //printf("\n");
    num = (num<<1)^POLY;
    } else {
    num <<= 1;
    }
    }
    return num;
    }
    /*crc 单字节检测*/

    评论

报告相同问题?

悬赏问题

  • ¥15 MATLAB yalmip 可转移负荷的简单建模出错,如何解决?
  • ¥15 数学的三元一次方程求解
  • ¥20 iqoo11 如何下载安装工程模式
  • ¥15 本题的答案是不是有问题
  • ¥15 关于#r语言#的问题:(svydesign)为什么在一个大的数据集中抽取了一个小数据集
  • ¥15 C++使用Gunplot
  • ¥15 这个电路是如何实现路灯控制器的,原理是什么,怎么求解灯亮起后熄灭的时间如图?
  • ¥15 matlab数字图像处理频率域滤波
  • ¥15 在abaqus做了二维正交切削模型,给刀具添加了超声振动条件后输出切削力为什么比普通切削增大这么多
  • ¥15 ELGamal和paillier计算效率谁快?