CRC计算单元

news2025/1/14 18:33:06

CRC计算单元

CRC是Cyclic Redundancy Check,循环冗余校验的缩写. 是一种检测数据错误的技术,主要用在数据通信和数据存储的方面. 但是这种技术只能检测到传输或存储的数据是否有误,没有将错误纠正的功能.

而CRC计算单元是一个独立的具备CRC计算功能的外设. AT32 MCU片上CRC计算单元采用CRC32/MPEG-2标准. 其多项式为 X 32 + X 26 + X 23 + X 22 + X 16 + X 12 + X 11 + X 10 + X 8 + X 7 + X 5 + X 4 + X 2 + X + 1 X^{32}+X^{26}+X^{23}+X^{22}+X^{16}+X^{12}+X^{11}+X^{10}+X^{8}+X^{7}+X^{5}+X^{4}+X^{2}+X+1 X32+X26+X23+X22+X16+X12+X11+X10+X8+X7+X5+X4+X2+X+1 .

这个多项式的简记式为: 0x4C11DB7.

由于所有的CRC多项式的最高位都是1,因此我们在记录简记式的时候习惯忽略最高位.

我们将0-31位bit先置0,对应上述的多项式,如果有,则置1.

01 (多项式中1=X0)
11 (多项式中有X1)
21 (多项式中有X2)
30 (多项式中不包含X3)
41
51
60
71
81
90
101
111
121
130
140
150
161
170
180
190
200
210
221
231
240
250
261
270
280
290
300
310

将这32个bit从下往上组合起来,就是简记式:0x04C11DB7.省略第一个0.则为:0x4C11DB7.

CRC标准

虽然AT32 MCU的CRC计算单元采用的是CRC32标准,但是还有许多种CRC标准可以使用. 下面是一些常见的CRC标准:

在这里插入图片描述

其中,CRC-12码通常用来传送6-bit字符串,CRC-16码及CRC-CCITT码通常用来传送8-bit字符串, CRC-32码通常用来进行点对点的同步传输。多项式并非固定某个值或者某个标准,只要计算方及校验方合理采用一致的多项式即可.

CRC算法

CRC的计算方法采用异或运算方式.

其计算原理是将输入数据作为被除数,与作为除数的生成多项式进行模二除法,得到的余数即为CRC值.

在进行CRC计算时可能存在目标数据串位宽比多项式更短,并且计算过程希望保证到目标数据串中的每一位都有被处理到,因此通常的做法是在目标位数据串的后面加上简记式位宽W个"0",再进行异或求余.示例如下:

多项式 = 1011(宽度W=3)

目标数据串 = 11100110

Bit 流 = 目标数据串 + W个“0” = 11100110000

CRC result = 100

计算过程图示如下:

下面对AT32 CRC外设进行介绍:

AT32 CRC外设

特性:

  1. 采用CRC32标准
  2. 一次CRC计算需要4个HCLK
  3. 输入输出数据格式可逆转
  4. 数据写入及结果读出都通过同一个数据寄存器(32位CRC_DT)
  5. 配置CRC_IDT写入初始化值,在每次CRC复位后该值都会加载到CRC_DT

数据格式逆转

指对指定数据按一定的数据格式进行高低位逆转的处理方式

AT32 CRC外设支持输入数据按 字节byte,半字halfword,字word格式逆转.

输出数据按字word格式逆转的特性可配,默认情况下都不逆转.

16位数据按字节和半字的逆转图示如下,其余格式与此类似:

在这里插入图片描述

CRC功能说明

CRC运算流程:
  • 输入翻转,即数据输入后,先依据CRC_CTRL的REVID值进行输入数据翻转
  • 初始化,首次计算会与CRC_IDT设定的初始值做XOR. 若非首次计算,则初始值为上次计算的结果.
  • CRC计算,与生成多项式进行模二除法,所得余数为CRC值
  • 输出翻转,依据CRC_CTRL的REVOD决定是否将CRC值执行全字翻转后再输出
CRC-32/MPEG-2参数说明
  • 初始值:0xFFFFFFFF,目的是为避免待测数据为1字节的0x00和多字节的0x00结果相同
  • 结果异或值: 0x0000 0000,此值表示不对CRC结果再进行一次XOR计算.

CRC寄存器

CRC_DT

简称复位值类型功能
位31:0DT0xFFFF FFFFrw数据寄存器位(Data value)
写入CRC计算器的新数据时,作为输入寄存器读取时返回CRC计算结果

CRC_CDT

简称复位值类型功能
位31:8保留0x0000 0000resd保持默认值
位7:0CDT0x00rw通用8位数据寄存器位
可用于临时存放1字节的数据.控制寄存器的RST产生的CRC复位对本寄存器没有影响

CRC_CTRL

简称复位值类型功能
位31:8保留0x0000 0000resd保持默认值
位7REVOD0x0resd输出数据翻转
由软件置起或清零.该位控制是否翻转输出数据
0: 不翻转
1: 全字翻转
位6:5REVID0x0rw输入数据翻转
由软件置起或清零.该位控制是否翻转输入数据
00: 不翻转
01: 字节翻转
10: 半字翻转
11: 全字翻转
位4:1保留0x0resd保持默认值
位0RST0x0rwRESET位
由软件置起,由硬件自动清零.复位CRC计算单元,设置数据寄存器为0xFFFF FFFF
0: 无作用
1: 复位

CRC_IDT

简称复位值类型功能
位31:0IDT0xFFFF FFFFrw初始化数据寄存器
当控制寄存器的RST位产生的复位时,初始化寄存器中的数值将作为数据寄存器的初始值写入.

CRC配置流程

了解了CRC有关的寄存器,我们现在来介绍如何配置有关寄存器,从而使用CRC计算单元.

  1. 在CRC操作之前,开启CRC的外设时钟
  2. 设置初始化寄存器(CRC_IDT)值,在对数据寄存器(CRC_DT)进行软复位的时候,会将初始化寄存器里的值直接写入到CRC_DT寄存器作为初始值,如不设置,此寄存器默认值为0xFFFF FFFF
  3. 设置多项式宽度
  4. 设置多项式值
  5. 设置输入输出数据的逆转模式
  6. Reset CRC_DT 后将数据按32-bit 格式逐个写入到CRC_DT进行计算
  7. 读CRC_DT寄存器,检查计算结果

如果想要例程的,可以去雅特力官网上查找

雅特力科技 : 32位微控制器的创新领导者! (arterytek.com)

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

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

相关文章

Web应用安全测试-认证功能缺陷

Web应用安全测试-认证功能缺陷 存在空口令 漏洞描述:认证登录环节允许空口令 测试方法: 找到网站登录页面,尝试输入用用户名,密码为空进行登录。 风险分析:攻击者可利用该漏洞登录网站后台,操作敏感数…

Warning: `ReactDOMTestUtils.act` is deprecated in favor of `React.act`.

问题:在代码中使用jest进行单元测试时,报错如下: 解决思路: 根据报错提示出来的 react-dom/test-utils 进行全局搜索,发现没有该引用,故进入该代码块中分析。发现代码中引入testing-library/react &#…

C++ 28 之 类对象作为类成员

#define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> using namespace std;class Phone { public:string s_p_name;Phone(string p_name) {s_p_name p_name;cout << "phone的构造函数调用" << endl;}~Phone(){cout &…

BitMEX 联合创始人 Arthur Hayes 加入 Covalent 担任战略顾问

Arthur Hayes 加入 Covalent Network&#xff08;CQT&#xff09;&#xff0c;成为其战略顾问。 Hayes 认为 Covalent 与其竞争对手如 The Graph 相比&#xff0c;Covalent Network 的 CQT 代币一直被相对低估&#xff0c;他希望帮助 Covalent Network&#xff08;CQT&#x…

【Three.js】知识梳理二十一:Three.js性能优化和实践建议

Three.js 是一个功能强大的 3D 引擎&#xff0c;用于创建 WebGL 应用。尽管它功能强大&#xff0c;但在复杂的 3D 场景中保持高性能是一个挑战。本文将分享一些在使用 Three.js 时的性能优化提示&#xff0c;帮助你提高应用的运行效率。 1. 使用 stats.js 监视性能 在进行任何…

苦日子开始了,普通人应该怎么做?

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 以为疫情后&#xff0c;我们的收入会好起来&#xff0c;谁曾想连工作都快保不住了&#xff0c;这几年大家日子过的比较苦&#xff0c;很多人想多一份收入。 面对这种情况&#xff0c;我们普通人应该怎么办?如何多…

【秋招突围】2024届秋招笔试-阿里系列笔试题-第一套-三语言题解(Java/Cpp/Python)

&#x1f36d; 大家好这里是清隆学长 &#xff0c;一枚热爱算法的程序员 ✨ 本系计划跟新各公司春秋招的笔试题 &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&#x1f497; &#x1f4e7; 清隆这边…

C++ 27 之 初始化列表

c27初始化列表.cpp #include <iostream> #include <string.h> using namespace std;class Students06{ public:int s_a;int s_b;int s_c;Students06(int a, int b, int c){s_a a;s_b b;s_c c;}// 初始化列表写法1&#xff1a;// Students06():s_a(4),s_b(5),s_…

使用QT绘制简单的动态数据折线图

两个核心类时QChart和QLineSeries 下面这个示例代码中&#xff0c;定时器每隔一段时间将曲线图中的数据点向右移动 一个单位&#xff0c;同时调整横坐标轴的范围&#xff0c;实现了一次滚动对应移动一个数据点的效果。 QLineSeries最多容纳40961024个点 #include <QtWidg…

【RabbitMQ】初识 RabbitMQ

初识 RabbitMQ 1.认识 RabbitMQ1.1 介绍1. 2.使用场景1.2.1 推送通知1.2.2 异步任务1.2.3 多平台应用的通信1.2.4 消息延迟1.2.5 远程过程调用 1.3 特性 2.基本概念2.1 生产者、消费者和代理2.2 消息队列2.3 交换机2.3.1 direct2.3.2 topic2.3.3 headers2.3.4 fanout 2.4 绑定2…

Downie for Mac v4.7.17 在线视频下载软件 安装(简单易学,小白轻松搞定)

Mac分享吧 文章目录 效果一、准备工作二、开始安装1、双击运行软件&#xff0c;将其从左侧拖入右侧文件夹中&#xff0c;等待安装完毕2、应用程序显示软件图标&#xff0c;表示安装成功 三、运行测试1、打开软件&#xff0c;进行设置2、下载视频&#xff0c;测试3、根据需要选…

关于unbuntu的终端自动退出的解决方案

输入sudo vim /etc/profile 将下面的TMOUT的时间注释掉 source /etc/profile使得更改生效

打破数据分析壁垒:SPSS复习必备(一)

一、数据录入与数据获取 1.变量的测量尺度 &#xff08;1&#xff09;定类尺度 顾名思义&#xff0c;是对事物的类别或属性的一种测度&#xff0c;按照事物的某种属性对其进行分类或分组。 该类变量只能计算频数和频率&#xff0c;用表示 &#xff08;2&#xff09;定序尺…

人生感悟 | 我们为什么贫穷?

哈喽&#xff0c;你好啊&#xff0c;我是雷工&#xff01; 我们为什么贫穷&#xff1f; 因为我们都在局中并坦然的按着规则制定者循规蹈矩的生活。 01 负债导致贫穷 最近同事买房&#xff0c;总价一百多万&#xff0c;月供四千多&#xff0c;讲话&#xff1a;已入坑&#xff0…

python反序列化知识点学习

最近遇到了python反序列化的题目&#xff0c;简单学习一下相关的知识点 基础知识 Python 的序列化指的是将 Python 对象转换为一种格式&#xff0c;以便可以将其存储在文件或通过网络传输。Python 中最常用的序列化模块是 pickle 模块。 序列化使用的是pickle.dumps方法&…

qt仿制qq登录界面

#include "mainwindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent) {// 设置窗口大小this->resize(window_width, window_heigth);// 固定窗口大小this->setFixedSize(window_width, window_heigth);// 设置窗口图标this->se…

JavaScript-数组

学习目标&#xff1a; 掌握数组 学习内容&#xff1a; 数组是什么数组的基本使用练习操作数组 数组是什么&#xff1a; 数组Array 是一种可以按顺序保存数据的数据类型。场景&#xff1a;如果有多个数据可以用数组保存起来&#xff0c;然后放到一个变量中&#xff0c;管理非常…

SQL 表连接(表关联)

目录 一、INNER JOIN&#xff08;内连接,等值连接&#xff09; 二、LEFT JOIN&#xff08;左连接&#xff09; 三、RIGHT JOIN&#xff08;右连接&#xff09;&#xff1a; 一、INNER JOIN&#xff08;内连接,等值连接&#xff09; 用途&#xff1a;获取两个表中字段能匹配上…

返回值返回引用返回指针之间的区别

一、返回值 当函数返回一个值时&#xff0c;实际返回的是一个变量的拷贝。 优点&#xff1a; 简单易用&#xff1b;安全&#xff0c;不会导致悬挂指针或悬挂引用&#xff1b; 缺点&#xff1a; 当返回值是一个较大的对象时会产生拷贝开销&#xff0c;影响程序性能&#xf…

TcpClient 服务器、客户端连接

TcpClient 服务器 TcpListener 搭建tcp服务器的类&#xff0c;基于socket套接字通信的 1 创建服务器对象 TcpListener server new TcpListener(IPAddress.Parse("127.0.0.1"), 3000); 2 开启服务器 设置最大连接数 server.Start(1000); 3 接收客户端的链接,只能…