·上一文章:基于FPGA的VGA时序彩条信号实现
·下一文章:基于CPLD的空调控制系统
做一点演算有助于更清楚地说明这一概念。
假定%符号在下列表达式中表示模运算。
对于未经反演附加校验和的情况:
(Mxr–R)xr%G=0
在这种情况下,接收器会执行与发射器一样的移位运算。
现在,考虑校验和在发射器上经反演后附加到消息流的情况: (Mxr–Rc)xr% G
其中,Rc表示经过反演的校验和。
还可以将其写成:(Mxr– R +(xr-1+...+x+ 1)) xr% G
一个位的反码与其对1异或运算的结果相同。这里的+号表示模2算法中的加法(另请注意,在模2算法中,加法和减法运算相同)。
在这种情况下,余数与以下表达式相同:(xr-1+...+x+1) xr% G
对于给定的生成器多项式来说,此表达式的计算结果将是一个常数。
最常用的CRC 32生成器多项式是G(x) = x32+x26+x23+x22+x16+x12+x11+x10+x8+x7+x5+x4+x2+x+1
该式在十六进制中是04C11DB7。
与CRC-32对应的常数剩余值在十六进制中是C704DD7B。对于给定的生成器多项式G来说,无论在输入端提供何种数据样式,剩余值仍为常数。
硬件实现
CRC校验和的计算是多项式除法过程。在硬件中实现该过程需要使用一个移位寄存器(亦称CRC寄存器)。该移位寄存器的长度与生成器多项式的阶数相同。
CRC 计算过程如下:
1.初始化CRC寄存器。
2.持续获取消息位,直到获得所有消息位。如果CRC寄存器中的高阶位是1,则向左移一位,并且将其结果与G进行异或运算。否则,仅向左移一位。