打印

STM32内置CRC模块的使用

[复制链接]
1685|2
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
zly0123yz|  楼主 | 2013-10-8 15:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
这是篇网上摘录的**。里面的算法,我实际验证过是对的。       
所有的STM32芯片都内置了一个硬件的CRC计算模块,可以很方便地应用到需要进行通信的程序中,这个CRC计算模块使用常见的、在以太网中使用的计算多项式:
  X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 +X8 + X7 + X5 + X4 + X2 + X + 1
写成16进制就是:0x04C11DB7

下面是用C语言描述的这个计算模块的算法,大家可以把它放在通信的另一端,对通信的正确性进行验证:

DWORD dwPolynomial = 0x04c11db7;
DWORD cal_crc(DWORD *ptr, int len)
{
DWORD xbit;
DWORD data;
DWORD CRC = 0xFFFFFFFF; // init
while (len--) {
  xbit = 1 << 31;

  data = *ptr++;
  for (int bits = 0; bits < 32; bits++) {
   if (CRC & 0x80000000) {
    CRC <<= 1;
    CRC ^= dwPolynomial;
   }
   else
    CRC <<= 1;
   if (data & xbit)
    CRC ^= dwPolynomial;

   xbit >>= 1;
  }
}
return CRC;
}

有几点需要说明:

1)上述算法中变量CRC,在每次循环结束包含了计算的余数,它始终是向左移位(既从最低位向最高位移动),溢出的数据位被丢弃。

2)输入的数据始终是以32位为单位,如果原始数据少于32位,需要在低位补0,当然也可以高位补0。

3)假定输入的DWORD数组中每个分量是按小端存储。

4)输入数据是按照最高位最先计算,最低位最后计算的顺序进行。

例如:
如果输入0x44434241,内存中按字节存放的顺序是:0x41, 0x42, 0x43, 0x44。计算的结果是:0xCF534AE1
如果输入0x41424344,内存中按字节存放的顺序是:0x44, 0x43, 0x42, 0x41。计算的结果是:0xABCF9A63
沙发
zly0123yz|  楼主 | 2013-10-8 18:22 | 只看该作者
没有人啊

使用特权

评论回复
板凳
yinhaix| | 2015-5-25 13:27 | 只看该作者

使用特权

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

本版积分规则

24

主题

420

帖子

0

粉丝