1、硬件CRC简介

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

2、硬件CRC寄存器

ME32F030的CRC寄存器使用起来十分简便,相对应的寄存器也较少。
391fc79b5ff54fc782529c48c17b6a56?from=pc.jpg
图1 CRC寄存器列表

2-1 CRC模式寄存器

该寄存器用来选择CRC的多项式选择、数据顺位、多项式等算法参数。
43fd019a00dd44968ba82264265d78a2?from=pc.jpg
图2 CRC模式寄存器
aca7a73c9bf7422198cbbe0f58a960a9?from=pc.jpg
图3 CRC模式寄存器(续)

2-2 CRC种子寄存器

该寄存器用于保存参与计算的CRC种子,默认值为0x0000FFFF。
9f935345cb38432bb80e85051caa34c3?from=pc.jpg
图4 CRC种子寄存器

2-3 CRC校验和寄存器

注意这是一个只读寄存器。它保存着最近一次的校验和。
2d6e81252f88404593a809c871d39a73?from=pc.jpg
图5 CRC校验和寄存器

2-4 CRC数据寄存器

该寄存器是只写寄存器,用于输入将计算CRC和的数据块。
b66b9396b0e345b7834e019ab189e892?from=pc.jpg
图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的计算结果如下图所示:

    5cc17319c6a646749d4394a2daea8d9d?from=pc.jpg
    图7 CRC计算

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

    269b7dd8189e40f3be648bee06c8742b?from=pc.jpg
    图8 CRC运算结果

    来源:老马识途单片机