极海APM32F103系列CRC32外设实验 在传输数据存储数据时,均需对数据的完整性进行校验。试想一下,保存着你的工资数值的flash存储块恰巧坏了一下——归零了!那你这一个月岂不是白忙活了!又比如传输一帧数据的长度,在出现干扰后,长度变成了0xFFFFFFFF, 那咱们这一帧数据要接收到猴年马月去呀! 在学习CRC32外设时,极海的datasheet里面介绍相对较少,其实也是因为CRC32是一个公共基础知识,理应自己学习,但在B站上面,极海的技术微课介绍就非常全面了。 CRC32是32位循环冗余校验算法,它能基于数学原理验证数据是否完整,为我们数据可靠传输、安全传输提供保证。CRC32有许多算法,主要针对不同的应用场景。今天讨论CRC32的算法,是极海工业级MCU内置的CRC32硬件模块所采用的CRC32-MPEG2算法。 根据视频讲解可知,CRC32-MPEG2的参数如下: 多项式:0x04C11DB7 初始值:0xFFFFFFFF 输入反转:false 输出反转:false 结果异或:0x00000000
接下来,我们根据课堂的讲解做一个小实验,看看硬件CRC32计算模块如何计算的?我是基于极海APM32F103系列MCU,使用Keil编译环境,源代码如下: - const uint32_t calc_data[16] = {
- 0x01020304, 0x05060708, 0x090a0b0c, 0x0d0e0f00,
- 0x01020304, 0x05060708, 0x090a0b0c, 0x0d0e0f00,
- 0x01020304, 0x05060708, 0x090a0b0c, 0x0d0e0f00,
- 0x01020304, 0x05060708, 0x090a0b0c, 0x0d0e0f00};
- int main(void)
- {
- uint32_t i;
- uint32_t ret = 0;
- uint8_t *ptr;
- hal_sysclock_set();
- SysTick_Config(SystemCoreClock / 1000);
- hal_board_init();
- time_base_tick = 1000;
- ptr = (uint8_t *)calc_data;
- CRC_ResetDATA();
- for (i = 0; i < 16; i++)
- {
- ptr = (uint8_t *)&calc_data[i];
- ret = sprintf(log_buf, "%02X %02X %02X %02X ", ptr[0], ptr[1], ptr[2], ptr[3]);
- log_buf[ret] = 0;
- log_printf(log_buf);
- ret = CRC_CalculateCRC(calc_data[i]);
- }
- ret = sprintf(log_buf, "\r\nCRC32 result = 0x%08X\r\n", ret);
- log_buf[ret] = 0;
- log_printf(log_buf);
- while (1)
- {
- if (time_base_tick == 0)
- {
- time_base_tick = 1000;
- log_printf(hello_str);
- led_toggle();
- }
- }
- }
通过串口输出结果如下:
通过上面的代码可以得出,利用极海APM32F103的CRC32外设计算校验值,代码长度超级短,而且硬件运行效益也高——仅需要4个AHB的时钟周期。 极海B站的APM32技术微课内容满满,干货满满。附上本次学习的B站链接: 【【APM32技术微课 | 第23讲】APM32的CRC应用分享】 https://www.bilibili.com/video/BV1hvxFegE7h/?share_source=copy_web&vd_source=65d181aad673c4302ac1a268837e19e2 @Gfan 参加活动
|