打印

硬件CRC寄存器例程

[复制链接]
862|2
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
qbwww|  楼主 | 2022-1-1 22:02 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
1、硬件CRC简介

ME32F030系列集成有一个微型CRC协处理器,它可以用来处理控制器的复杂计算,从而降低MCU的运算压力,软件可以通过调用CRC寄存器去完成预设的计算功能。
CRC系统时钟 CRC_PCLK 由控制器系统时钟提供并由 SYSAHBCLKCTRL 控制。类似控制器其它模块,CRC可以通过关闭时钟从而节能。CRC 可以完成下列任务:CRC-CCITT、 CRC-16 、 CRC-32。

2、硬件CRC寄存器

ME32F030的CRC寄存器使用起来十分简便,相对应的寄存器也较少。
图1 CRC寄存器列表

2-1 CRC模式寄存器

该寄存器用来选择CRC的多项式选择、数据顺位、多项式等算法参数。
图2 CRC模式寄存器
图3 CRC模式寄存器(续)

2-2 CRC种子寄存器

该寄存器用于保存参与计算的CRC种子,默认值为0x0000FFFF。
图4 CRC种子寄存器

2-3 CRC校验和寄存器

注意这是一个只读寄存器。它保存着最近一次的校验和。
图5 CRC校验和寄存器

2-4 CRC数据寄存器

该寄存器是只写寄存器,用于输入将计算CRC和的数据块。
图6 CRC数据寄存器

3、CRC操作函数


在例程LIB->common->Drivers->Source文件夹内有crc.c文件,这个就是提供的CRC库函数文件,里面包含了支持的CRC函数,使用起来十分方便。它给出了支持的CRC 标准的寄存器设置函数。支持的CRC类型如下所示:
uint16_t CRC_CCITT(uint8_t * str, uint16_t strlen,uint32_t crcseed);uint16_t CRC_16(uint8_t * str, uint16_t strlen,uint32_t crcseed);uint32_t CRC_32(uint8_t * str, uint16_t strlen);本章节的主要目的是使用硬件CRC单元来提高MCU的效率。因此对CRC函数的详细算法不再赘述。

学习记录

4、CRC例程

接下来写个小例程来测试下硬件CRC的正确性,程序源码如下。
  • uint16_t crc_16_std, crc_16_modbus;
  • uint16_t crc_ccitt_std, crc_ccitt_xmodem, crc_ccitt_0x1d0f;
  • uint32_t crc_32;
  • int main(void)
  • {
  • uint8_t datastr[16]={0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,
  •                      0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F,0x10};
  • crc_16_std=CRC_16(datastr,16,0x0);
  • crc_16_modbus=CRC_16(datastr,16,0xFFFF);
  • crc_ccitt_xmodem=CRC_CCITT(datastr,16,0x0);
  • crc_ccitt_std=CRC_CCITT(datastr,16,0xFFFF);
  • crc_ccitt_0x1d0f=CRC_CCITT(datastr,16,0x1d0f);
  • crc_32=CRC_32(datastr,16);
  • while (1);
  • }


例程列举了几种常用的几种CRC算法。程序编译无误后,便可以下载仿真测试。首先在while(1)的位置打上断点,然后全速运行。等到停止后,所有的CRC都已运算完成。接下来就把算出的CRC检验结果添加到Watch1中,对CRC检验结果的正确性进行验证。
通过Watch1窗口,我们观察到的硬件CRC的计算结果如下图所示:

图7 CRC计算

然后通过网上的在线CRC计算工具,对我们的数据进行计算,不同的CRC标准算出的结果都给列举出来了。经过对比发现与硬件CRC计算结果一致。

图8 CRC运算结果


使用特权

评论回复

相关帖子

沙发
qbwww|  楼主 | 2022-1-1 22:02 | 只看该作者
CRC系统时钟 CRC_PCLK 由控制器系统时钟提供并由 SYSAHBCLKCTRL 控制。类似控制器其它模块,CRC可以通过关闭时钟从而节能。CRC 可以完成下列任务:CRC-CCITT、 CRC-16 、 CRC-32。

使用特权

评论回复
板凳
甘木| | 2022-1-1 22:04 | 只看该作者
程序编译无误后,便可以下载仿真测试。首先在while(1)的位置打上断点,然后全速运行。等到停止后,所有的CRC都已运算完成。接下来就把算出的CRC检验结果添加到Watch1中,对CRC检验结果的正确性进行验证。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

733

主题

4516

帖子

12

粉丝