OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4988|回复: 4

软件实现CRC-32快速校验算法

[复制链接]

3

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
58
金钱
58
注册时间
2014-7-13
在线时间
0 小时
发表于 2014-8-2 10:18:37 | 显示全部楼层 |阅读模式
关于CRC校验的网上资料比较杂乱,而其本身又有较深的数学背景,导致大家通常难以理解其算法。下面分享一段我自己的软件代码,与STM32的CRC计算单元相互印证,希望能够帮助大家理解CRC校验。代码参照IEEE 802.3协议编写,软件实现CRC-32快速校验算法:

(纯属个人研究,如有疏漏之处,还望多多包涵)

/*
  Name: Main.c
  Copyright: Free
  Author: Lulai Zhu
  Date: 
  Description: 
  Calculation of CRC-32
*/

#include <stdio.h>
#include <stdlib.h>

#define POLYNOMIAL    0x04C11DB7    //CRC-32简记式 

typedef unsigned char BYTE;
typedef unsigned long ULONG;

ULONG g_aulTable[256];    //8位数据余式表 

void InitTable(void);                           //初始化余式表 
ULONG CalCrc(const BYTE *pbyData, int iLen);    //计算CRC余式 

int main(void)
{
    BYTE abyData[4] = {0x12, 0x34, 0x56, 0x78};
    ULONG ulCrc = 0x0;
    
    InitTable();
    ulCrc = CalCrc(abyData, 4);
    printf("ulCrc = 0x%08X\n", ulCrc);
    
    system("pause");
    exit(EXIT_SUCCESS);
}

void InitTable(void)
{
     ULONG ulReg = 0x0;                                 //移位寄存器,初始化为0x0 
     int i = 0;
     int j = 0;
     
     for (i = 0; i < 256; i++)                          //总共256个余式 
     {
         ulReg = ((ULONG)i << 24);                      //8位数据左移24位,然后记入寄存器 
         for (j = 0; j < 8; j++)                        //总共8位数据 
         {
             if ((ulReg >> 31) == 0x1)                  //如果寄存器最高位为1 
             {
                  ulReg = (ulReg << 1) ^ POLYNOMIAL;    //寄存器左移1位,并与简记式异或
             }
             else
             {
                  ulReg <<= 1;                          //寄存器左移1位 
             }
         }
         g_aulTable = ulReg;                         //将结果记入余式表 
     }
     
     return;
}

ULONG CalCrc(const BYTE *pbyData, int iLen)
{
      ULONG ulReg = 0xFFFFFFFF;                                             //移位寄存器,初始化为0xFFFFFFFF 
      int i = 0;
      
     /* 通过8位数据余式表,快速计算CRC余式,具体解释请参考:
        http://blog.csdn.net/zhaodm/article/details/3711034 */
      for (i = 0; i < iLen; i++)
      {
          ulReg = (ulReg << 8) ^ g_aulTable[(ulReg >> 24) ^ pbyData];
      }
      
      return ulReg;
}

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

120

主题

7878

帖子

13

精华

资深版主

Rank: 8Rank: 8

积分
12012
金钱
12012
注册时间
2013-9-10
在线时间
427 小时
发表于 2014-8-2 12:29:54 | 显示全部楼层
现在,程序把烂铜烂铁变得智能化了,人呢,一旦离开了这烂铜烂铁就不知道干啥了
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2014-8-2 23:19:27 | 显示全部楼层
谢谢分享....
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

0

主题

9

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2016-1-7
在线时间
3 小时
发表于 2016-1-9 23:11:37 | 显示全部楼层
正在学习CRC,谢谢分享....
回复 支持 反对

使用道具 举报

49

主题

341

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
5265
金钱
5265
注册时间
2012-8-25
在线时间
1025 小时
发表于 2020-12-11 10:19:57 | 显示全部楼层
这个多项式校验为啥不是0呢,用在线crc计算器也是不位0 ,奇怪
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-23 20:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表