一、STM32F407CRC校验的补充
由于STM32F407的CRC校验,并没有什么配置的选项,就会导致他只能进行32位,且初始值是0XFFFFFFFF,输入和输出都没有反转的CRC校验。为了弥补这些不足点,于是自己编写函数来增加这些功能
//输入反转 函数如果需要输入反转就先调用这个将输入的数据先进行反转
//每个字节按位反转 注意一个字节是8位
void Byte_Reversal(uint32_t *buf, uint32_t length)
{uint32_t temp = 0;uint8_t i = 0, j = 0, k = 0;for (i=0; i<length; i++){for (j=0; j<=24; j+=8){temp = (buf[i] >> j) & 0xff;for (k=0; k<8; k++){temp |= ((temp & (0x01 << k)) << (15 - 2*k));}temp >>= 8;buf[i] &= ~(0x000000ff << j); buf[i] |= (temp << j);}}}//也就是CRC校验完成之后输出是否进行反转的函数 整个数据按位反转
//这个函数要在计算结果之后 异或之前进行调用
uint32_t Bits_Reversal(uint32_t buf)
{uint32_t temp = 0;uint8_t k = 0;for (k=0; k<32; k++){ temp |= (((buf >> k) & 0x01) << (31 - k));}return temp;
}//输出结果异或 这个是最后执行的,放在输出结果反转的后面就行
//yihuo 需要异或的值
uint32_t Result_Xor(uint32_t num, uint32_t yihuo)
{return (num ^ yihuo);}
Byte_Reversal(buf, 2); //输入结果反转
result = HAL_CRC_Calculate(&hcrc, buf, 2); //进行CRC校验
result = Result_Xor(Bits_Reversal(result), 0xffffffff); //输出结果反转 并进行异或
printf("result = %X\n", result);