当前位置:首页 > 公众号精选 > 硅农亚历山大
[导读]在之前的内容里,我们介绍了很多通信协议,不过仅讲解了数据的收发方法,而在实际的通信系统中,除了要实现收发外,还要尽量保证数据尽量不出差错。为尽量提高接收方收到数据的正确率,在接收数据时要对数据进行差错检测,检测的方式有很多种,常见的有奇偶校验、海明校验和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课堂”专栏已在社区开通如需获取实验源码或有实验相关问题扫码进入即可






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

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭