码迷,mamicode.com
首页 > 编程语言 > 详细

一个简短的CRC32计算程序 C语言

时间:2019-08-29 09:52:56      阅读:572      评论:0      收藏:0      [点我收藏+]

标签:const   程序   oid   完整   ddr   方便   turn   嵌入式系统   crc   

一个简单的CRC32计算程序

一、简介

CRC32多用于短数据的完整性校验,一般存放于EMMC的数据结构,或者于其他设备通信时经常会用到,这里提供一个非常短小使用的CRC32校验程序,它占用较小的内存与代码体积,非常方便porting到STM32、ARM等嵌入式系统中。

二、使用方法

使用方法非常简单,只要call crc32函数即可。参数3可以传入CRC32初始值,方便计算多段连续数据的CRC32。

参数1:DATA Address

参数2:DATA Length

参数3:CRC32 Initial Value

三、代码

uint32_t crc32_for_byte(uint32_t r) {
  for(int j = 0; j < 8; ++j)
    r = (r & 1? 0: (uint32_t)0xEDB88320L) ^ r >> 1;
  return r ^ (uint32_t)0xFF000000L;
}

void crc32(const void *data, size_t n_bytes, uint32_t* crc) {
  static uint32_t table[0x100];
  if(!*table)
    for(size_t i = 0; i < 0x100; ++i)
      table[i] = crc32_for_byte(i);
  for(size_t i = 0; i < n_bytes; ++i)
    *crc = table[(uint8_t)*crc ^ ((uint8_t*)data)[i]] ^ *crc >> 8;
}


一个简短的CRC32计算程序 C语言

标签:const   程序   oid   完整   ddr   方便   turn   嵌入式系统   crc   

原文地址:https://www.cnblogs.com/smilingsusu/p/11425609.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!