基于查表法的 CRC8 / CRC16 / CRC32校验解析

在嵌入式开发中,CRC(Cyclic Redundancy Check)循环冗余校验算法广泛应用于通信数据校验、Flash 数据完整性检测、Bootloader 升级验证等场景。本文将深入剖析一套完整的 CRC8、CRC16 和 CRC32 实现,并通过查表法(Table Lookup Method)提升运算效率。

一、CRC 原理简述

CRC 的基本思想是:将要校验的数据视为一个长二进制串,并与某一指定的“生成多项式”进行二进制模2除法,所得余数即为 CRC 校验值。

  • CRC8 常用多项式:x^8 + x^2 + x + 1(即 0x07)

  • CRC16 常用多项式:x^16 + x^15 + x^2 + 1(即 0x8005 或 0x1021)

  • CRC32 常用多项式:x³² + x²⁶ + x²³ + ... + x + 1(IEEE 802.3 标准)

二、查表法

在计算 CRC 的过程中,每处理一个字节都涉及到按位移位与异或操作,效率较低。而查表法则是将所有可能的单字节计算结果预先计算出来存入查找表(Lookup Table),运行时每次只需一次查表和一次异或操作即可,大幅提升 CRC 运算效率,非常适合资源受限的嵌入式系统。

查找表生成原理: 以 CRC8 为例,查找表中每个表项表示某一字节初值经过 CRC 算法后所得的中间 CRC 值。我们可以预先对 0x00 ~ 0xFF 的每个字节进行模拟计算,生成 256 项查找表,运行时直接查询即可。

查找表自动生成脚本
对于 CRC 表项,可以参考使用如下 Python 脚本快速生成:

def generate_crc8_table(poly=0x07):table = []for i in range(256):crc = ifor _ in range(8):crc = (crc << 1) ^ poly if (crc & 0x80) else (crc << 1)crc &= 0xFFtable.append(crc)return table

可以将生成结果格式化输出为 C 语言数组,粘贴进工程中。

函数依赖预定义的查找表,如:

const uint8_t crc8_tab[256] = {0x00, 0x5E, 0xBC, ..., 0x53 // 共256项
};const uint16_t crc16_tab[256] = {0x0000, 0x1021, ..., 0x1EF0 // 共256项
};const uint32_t crc32_tab[256] = {0x00000000, 0x04C11DB7, ..., 0x2D02EF8D // 共256项
};

三、代码实现详解

1. CRC8 查表法实现

// 生成多项式:0x07,初始值:0x00,输入不反转,输出不反转
static const uint8_t crc8_table[256] = {// 表项略去,可通过代码生成,见下文
};uint8_t crc8_calc(const uint8_t *data, uint32_t length) {uint8_t crc = 0x00;while (length--) {crc = crc8_table[crc ^ *data++];}return crc;
}

2. CRC16 查表法实现(以 CRC-16-IBM 为例)

// 生成多项式:0x8005,初始值:0x0000
static const uint16_t crc16_table[256] = {// 表项略,可使用工具或代码生成
};uint16_t crc16_calc(const uint8_t *data, uint32_t length) {uint16_t crc = 0x0000;while (length--) {crc = (crc << 8) ^ crc16_table[((crc >> 8) ^ *data++) & 0xFF];}return crc;
}

3. CRC32 查表法实现(IEEE 标准)

static const uint32_t crc32_table[256] = {// 可使用 Python 脚本生成
};uint32_t crc32_calc(const uint8_t *data, uint32_t length) {uint32_t crc = 0xFFFFFFFF;while (length--) {crc = (crc >> 8) ^ crc32_table[(crc ^ *data++) & 0xFF];}return crc ^ 0xFFFFFFFF;
}

四、示例与应用建议

串口通信帧校验

typedef struct {uint8_t header;uint8_t length;uint8_t payload[256];uint8_t crc8;
} uart_frame_t;// 接收处理时:
bool check_frame_crc(const uart_frame_t *frame) {uint8_t calc_crc = crc8_calc((uint8_t*)frame, sizeof(uart_frame_t) - 1);return calc_crc == frame->crc8;
}
  • Flash 校验:通过 CRC 校验 Flash 存储的数据结构完整性。

  • Bootloader 验证:用于 App 区固件完整性验证,保障升级安全。

  • 通信协议校验:如 CAN、UART、SPI 数据包尾部追加 CRC 字段,用于误码检测。

  • 内存镜像验证:设备重启后对 RAM 区数据校验,判断是否需要重新初始化。

查表法 CRC 是一种高效、实用的算法,在嵌入式通信、文件校验、数据链路等场景中不可或缺。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/75580.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二战蓝桥杯所感

&#x1f334; 前言 今天是2025年4月12日&#xff0c;第十六届蓝桥杯结束&#xff0c;作为二战的老手&#xff0c;心中还是颇有不甘的。一方面&#xff0c;今年的题目比去年简单很多&#xff0c;另一方面我感觉并没有把能拿的分都拿到手&#xff0c;这是我觉得最遗憾的地方。不…

基于ueditor编辑器的功能开发之给编辑器图片增加水印功能

用户需求&#xff0c;双击编辑器中的图片的时候&#xff0c;出现弹框&#xff0c;用户可以选择水印缩放倍数、距离以及水印所放置的方位&#xff08;当然有很多水印插件&#xff0c;位置大小透明度用户都能够自定义&#xff0c;但是用户需求如此&#xff0c;就自己写了&#xf…

算法题(123):回文日期

审题&#xff1a; 本题需要我们判断以八位数确定的日期范围中是否存在回文数 思路&#xff1a; 方法一&#xff1a;枚举法 1.确定枚举对象&#xff1a; 对象1&#xff1a;八位数日期&#xff0c;所需枚举次数&#xff1a;10^8 对象2&#xff1a;年&#xff0c;所需枚举次数&…

数据库表的操作

一、数据库的搭建 如上篇文章 二、基础了解 show命令支持模糊匹配 show databases、show tables、 show databases like “” “%”、“_”通配符字符串 三、MySQL数据库表的操作 关系型数据库都是遵循SQL语法进行数据查询和管理的 3.1 SQL介绍 3.1.1 SQL的功能 结构化查询语…

在 Lua 中实现 JSON 与 Table 的相互转换的详细使用方法

在 Lua 中实现 JSON 与 Table 的相互转换是常见的数据序列化需求。以下是详细的实现方案、性能优化技巧及进阶用法&#xff1a; 在 Lua 中实现 JSON 与 Table 的相互转换的详细使用方法-目录 一、常用 JSON 库对比二、基础转换实现1. 使用 lua-cjson&#xff08;高性能 C 库&am…

dbVisitor 规则怎么用?

在数据库操作中&#xff0c;dbVisitor 是一个功能强大的工具&#xff0c;其规则的使用大大简化了 SQL 语句的编写过程。下面将详细介绍 dbVisitor 规则的使用方法并附上具体例子。 一、规则的基本调用 在 dbVisitor 中&#xff0c;SQL 语句可以通过 {...} 的形式来调用规则&a…

Kingbase 常用运维命令总结

一、数据库连接与基础操作 连接指定服务器数据库 ksql -h 主机IP -p 端口号 -U 用户名 -d 数据库名 -W # 示例&#xff1a;连接 IP 为 192.168.1.100 的数据库 ksql -h 192.168.1.100 -p 54321 -U system -d test -W 断开数据库连接 \q 或 exit 查看数据库列表及详细信息…

【数据结构与算法】LRU Cache 算法实现

文章目录 Ⅰ. 什么是 LRU CacheⅡ. LRU Cache 的实现[146. LRU 缓存](https://leetcode.cn/problems/lru-cache/) Ⅰ. 什么是 LRU Cache ​ LRU&#xff08; Least Recently Used&#xff09; 是一种淘汰策略的缩写&#xff0c;意思是 最近最少使用&#xff0c;它是一种 Cache…

网页布局汇总

1. 盒模型 容器大小 内容大小 内边距(padding) 边框大小 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0">&l…

打造海外流量矩阵,TikTok云控工具让获客更简单!

跨境获客&#xff0c;始终是无数企业主心中的一道难题。今天&#xff0c;给大家带来一款强大实用的工具——TikTok矩阵云控系统&#xff0c;帮你轻松突破流量瓶颈&#xff0c;实现高效跨境获客&#xff01; 跨国远程操控——苹果手机矩阵云控系统 在正式开始之前&#xff0c;…

MyBatis-plus 快速入门

提示&#xff1a;MyBatis-Plus&#xff08;MP&#xff09;是一个 MyBatis的增强版 文章目录 前言使用MybatisPlus的基本步骤1、引入MybatisPlus依赖代替Mybatis依赖2、定义Mapper接口并继承BaseMapper他是怎么知道哪张表&#xff0c;哪些字段呢 3、实体类注解4、根据需要添加配…

找搭子系统 搭子经济新风口 基于精准匹配的社交新生态探索

一、市场前景&#xff1a;为什么现在需要"找搭子"&#xff1f; 孤独经济爆发 超60%年轻人存在"精准陪伴"需求&#xff08;2024社交报告&#xff09; 传统社交App无法满足"非婚恋、非熟人"的中间态需求 线下活动复苏 剧本杀/飞盘等兴趣活动年增…

深入探析C#设计模式:访问者模式(Visitor Pattern)的原理与应用

引言 在软件开发中&#xff0c;设计模式为我们提供了高效、可维护的解决方案。而在众多设计模式中&#xff0c;访问者模式&#xff08;Visitor Pattern&#xff09;以其独特的结构和应用场景&#xff0c;在复杂系统中发挥着重要作用。本文将深入讲解访问者模式的定义、原理、优…

Redis核心功能实现

前言 学习是个输入的过程&#xff0c;在进行输入之后再进行一些输出&#xff0c;比如写写文章&#xff0c;笔记&#xff0c;或者做一些技术串讲&#xff0c;虽然需要花费不少时间&#xff0c;但是好处很多&#xff0c;首先是能通过输出给自己的输入带来一些动力&#xff0c;然…

RPA VS AI Agent

图片来源网络 RPA&#xff08;机器人流程自动化&#xff09;和AI Agent&#xff08;人工智能代理&#xff09;在自动化和智能化领域各自扮演着重要角色&#xff0c;但它们之间存在显著的区别。以下是对两者区别的详细分析&#xff1a; 一、定义与核心功能 RPA&#xff08;机…

多模态大语言模型arxiv论文略读(十五)

Jailbreaking GPT-4V via Self-Adversarial Attacks with System Prompts ➡️ 论文标题&#xff1a;Jailbreaking GPT-4V via Self-Adversarial Attacks with System Prompts ➡️ 论文作者&#xff1a;Yuanwei Wu, Xiang Li, Yixin Liu, Pan Zhou, Lichao Sun ➡️ 研究机构…

第1节:计算机视觉发展简史

计算机视觉与图像分类概述&#xff1a;计算机视觉发展简史 计算机视觉&#xff08;Computer Vision&#xff09;作为人工智能领域的重要分支&#xff0c;是一门研究如何使机器"看"的科学&#xff0c;更具体地说&#xff0c;是指用摄影机和计算机代替人眼对目标进行识…

【工具】Fiddler抓包

本文主要讲解如何使用Fiddler抓HTTP包&#xff0c;可通过所抓包内容分析HTTP请求/响应的细节 安装与配置 1.下载与安装 下载地址: https://www.telerik.com/fiddler/ 点击了链接后&#xff0c;跳转到以下页面&#xff1a; 点击Fiddler Classic(免费版)后&#xff0c;跳转到以…

STM32F103复用JTAG/SWD引脚为GPIO

普中-精灵1开发板&#xff0c;主芯片为STM32F103C8T6&#xff0c;4个独立按键K1~K4依次接PA15~PA12&#xff0c;按下为低电平&#xff0c;8个LED灯D1~D8&#xff0c;依次接PA0~PA7。查询手册得知&#xff1a;PA15主功能为JTDI&#xff0c;PA14为JTCK/SWCLK&#xff0c;PA13为JT…

难度偏低,25西电人工智能学院821、833、834考研录取情况

1、人工智能学院各个方向 2、人工智能学院近三年复试分数线对比 学长、学姐分析 由表可看出&#xff1a; 1、智能院25年院线相对于24年院线 全部专业下降比较多&#xff0c;其中控制科学与工程下降20分&#xff0c;计算机科学与技术下降20分&#xff0c;计算机技术[专硕]下降…