当前位置:首页 > 公众号精选 > 硅农亚历山大
[导读]在之前的内容里,我们介绍了很多通信协议,不过仅讲解了数据的收发方法,而在实际的通信系统中,除了要实现收发外,还要尽量保证数据尽量不出差错。为尽量提高接收方收到数据的正确率,在接收数据时要对数据进行差错检测,检测的方式有很多种,常见的有奇偶校验、海明校验和CRC(循环冗余校验)。其...

在之前的内容里,我们介绍了很多通信协议,不过仅讲解了数据的收发方法,而在实际的通信系统中,除了要实现收发外,还要尽量保证数据尽量不出差错。为尽量提高接收方收到数据的正确率,在接收数据时要对数据进行差错检测,检测的方式有很多种,常见的有奇偶校验、海明校验和CRC(循环冗余校验)。其中CRC的检错正确率、速度和成本等方面都具有优势,也被广泛应用于计算机网络通信中,本期内容我们就通过一个小实验,带领大家了解GD32VF103片内CRC单元的应用方法。
系统环境


Windows 10-64bit
软件平台


NucleiStudio IDE 202102版或 PlatformIO IDE
硬件需求


RV-STAR开发板




CRC(循环冗余校验)



循环冗余校验(Cyclic redundancy check,CRC)是一种根据网上数据包或计算机文件等数据产生简短固定位数校验码的一种散列函数,主要用来检测或校验数据传输或者保存后可能出现的错误。生成的数字在传输或者存储之前计算出来并且附加到数据后面,然后接收方进行检验确定数据是否发生变化。一般来说,循环冗余校验的值都是32位的整数。由于本函数易于用二进制的计算机硬件使用、容易进行数学分析并且尤其善于检测传输通道干扰引起的错误,因此获得广泛应用。此方法是由W. Wesley Peterson于1961年发表,具体的计算流程在本期内容中不作详述,请读者查阅相关资料或文献进行学习。


GD32VF103的计算单元




GD32VF103的CRC计算单元使用固定多项式计算32位CRC校验码,其主要特征如下:
  • 32位数据输入/输出寄存器CRC_DATA


  • 固定的CRC计算多项式:0x4C11DB7,与以太网CRC计算多项式相同,即CRC-32/MPEG-2


  • 对于32位的输入数据,从数据输入到得出计算结果,需4个AHB时钟周期,在此期间因32位的输入缓存存在,AHB总线不会挂起


  • 如果不通过软件设置CRC_CTL寄存器的方式清除CRC_DATA寄存器,CRC计算单元将基于新输入的原始数据和前一次CRC_DATA寄存器中的结果进行计算


  • 提供一个与计算无关的独立8位寄存器CRC_FDATA,可以供其他任何外设随时使用





实验部分



本期实验主要让大家了解CRC计算单元的应用方法,而不涉及具体的通信过程,实验思路如下:



  • 选取一个特定的32位输入数据 0x1234ABCD


  • 使用在线的CRC计算工具,计算出上述输入值的CRC值为 0x9B3CD6F8


  • 编写代码,使用片上CRC计算单元计算输入数据的CRC值,与在线工具计算的CRC值进行比对,使用板载的LED来表示比较结果,LED亮表示CRC值计算正确


例程如下:#include "nuclei_sdk_hal.h"

/* CRC input value */
uint32_t val = (uint32_t)0x1234ABCD;
/* pre-calculated CRC value for input value */
uint32_t val_crc = (uint32_t)0x9B3CD6F8;

int main(void)
{
/* init the built-in green led */
gd_rvstar_led_init(LED1);
/* enable the CRC clock */
rcu_periph_clock_enable(RCU_CRC);

/* reset the CRC to clear the register */
crc_data_register_reset();

/* compare the pre-calculated CRC value with the value calculated by hardware */
if (val_crc == crc_single_data_calculate(val)) {
gd_rvstar_led_on(LED1);
} else {
gd_rvstar_led_off(LED1);
}
}



创建工程,添加以上例程到main.c文件中,然后编译上传到开发板中,观察到RV-STAR的板载绿色LED点亮,说明硬件的CRC单元计算出了正确的CRC值。


本期内容到此结束,欢迎读者们在社区中进行交流。




“RVMCU课堂”专栏已在社区开通如需获取实验源码或有实验相关问题扫码进入即可






本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

以前微处理器(MPU)与微控制器(MCU)是截然不同的两种设备,MPU支持丰富的软件系统,如Linux和相关的软件堆栈,而MCU通常将专注于裸机和RTOS。近年来,随着MCU的性能越来越高,MCU和MPU之间的区别变得越...

关键字: MCU MPU 开发板

该产品线提供了并行SRAM的低成本替代方案,容量高达 4 Mb,具有143 MHz SPI/SQI™通信功能

关键字: SRAM 存储器 MCU

瑞典乌普萨拉,2024年3月27日 – 全球领先的嵌入式系统开发软件解决方案供应商IAR自豪地宣布:公司备受全球数百万开发者青睐的开发环境再次升级,已率先支持瑞萨首款通用32位RISC-V MCU,该 MCU 搭载了瑞萨...

关键字: MCU RISC-V CPU

3月26日,四维图新旗下杰发科技与国际第三方独立检测、检验和认证机构德国莱茵TÜV集团(以下简称TÜV莱茵)在上海举办颁证仪式,杰发科技宣布AC7840x系列车规级MCU芯片已成功通过ISO 26262 ASIL B功能...

关键字: 芯片 MCU 智能座舱

吹风机是居家生活必备物品,然而传统型吹风机所带来的体验并不佳,高频使用的女性群体对此更是深有感触。究其原因主要有:转速低,通常在每分钟2万转左右,导致干发速度慢;高温干发,容易损伤头发;噪声大且体积笨重等等。因此,能改善...

关键字: 吹风机 MCU 电源

Holtek新推出Sub-1GHz RF OOK/FSK Transmitter OTP MCU BC68R2123,扩大Holtek Sub-1GHz Tx系列产品涵盖面,并提供客户无线控制产品优势竞争力,适合各类无线...

关键字: RF发射器 MCU 无线控制

Holtek隆重推出全新一代32-bit Arm® Cortex®-M0+ 5V CAN MCU - HT32F53231/HT32F53241/HT32F53242/HT32F53252。这一系列单片机带有来自Bosc...

关键字: MCU 工业自动化 单片机

Holtek新推出BS67F2432具备触控按键、高精准度HIRC与LCD驱动器Flash MCU。主要特色为内建高精准度4MHz HIRC振荡电路、8路触控按键及最大支持4COM×15SEG LCD驱动器。适用于触控接...

关键字: MCU LCD驱动器 定时器

Holtek 新推出 BS45F2345 Touch A/D Flash MCU,特点内建高精准度振荡器、精准的 ADC 参考电压、8 路触控按键及支持SLCD 功能。其中触控可通过 CS (Conductive Sus...

关键字: MCU 电磁炉 振荡器

Holtek针对电池充电器应用领域,推出HT45F5QC-5/HT45F5QC-6专用 MCU,内建CAN Bus控制器,符合ISO11898-1:2003规范的CAN 2.0A/B协议,应用于二轮/三轮电动车、电动辅助...

关键字: 充电器 MCU
关闭