系统环境
软件平台
硬件需求
RV-STAR开发板
CRC(循环冗余校验)
GD32VF103的计算单元
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值。
本期内容到此结束,欢迎读者们在社区中进行交流。
实验源码
https://github.com/Nuclei-Software/nuclei-board-labs/tree/master/rvstar/crc/crc_single_data