stm32 CRC
http://www.emcu.it/CRC/CRCuk.html
Main Polynomials
- CRC-12 : X12 + X11
+ X3 + X2 + X + 1
1100000001111 - CRC-16 : X16 + X15
+ X2 + 1
11000000000000101 - CRC CCITT V41 : X16
+ X12 + X5 + 1
(This code is primarily used in the HDLC)
10001000000100001 - CRC-32 (Ethernet) : = X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 + X8 + X7 + X5 + X4 + X2 + X + 1
- CRC ARPA : X24 + X23+ X17 + X16 + X15 + X13 + X11 + X10 + X9 + X8 + X5 + X3 + 1
- SDLC: X16 + X12 + X5 + 1
--
SW : apple CRC 32 : http://opensource.apple.com//source/xnu/xnu-1456.1.26/bsd/libkern/crc32.c
--
STM CRC document
ref: http://www2.st.com/content/ccc/resource/technical/document/application_note/39/89/da/89/9e/d7/49/b1/DM00068118.pdf/files/DM00068118.pdf/jcr:content/translations/en.DM00068118.pdf
STM32F4 :
fix at 0x4C11DB7 = CRC-32 ethernet
initial value : 0xFFFFFFFF
STM32F429 library - https://github.com/MaJerle/stm32f429
STM32 hardware document :
http://www.cs.hs-rm.de/~kaiser/1313_canacademy/STM42F4xx_Reference_manual_DM00031020.pdf
source code : https://code.csdn.net/icecut/scorpionboard/blob/master/ScorpionBoardUsbSerial/Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_crc.c
CRC example :
https://github.com/fboris/STM32Cube_FW_F4/blob/master/Projects/STM324xG_EVAL/Examples/CRC/CRC_Example/Src/main.c
mbed 3.0 CRC example source :
#include "mbed-drivers/mbed.h"
#define BUFFER_SIZE 114
// CRC
CRC_HandleTypeDef CrcHandle;
static const uint32_t aDataBuffer[BUFFER_SIZE] =
{
0x00001021, 0x20423063, 0x408450a5, 0x60c670e7, 0x9129a14a, 0xb16bc18c,
0xd1ade1ce, 0xf1ef1231, 0x32732252, 0x52b54294, 0x72f762d6, 0x93398318,
0xa35ad3bd, 0xc39cf3ff, 0xe3de2462, 0x34430420, 0x64e674c7, 0x44a45485,
0xa56ab54b, 0x85289509, 0xf5cfc5ac, 0xd58d3653, 0x26721611, 0x063076d7,
0x569546b4, 0xb75ba77a, 0x97198738, 0xf7dfe7fe, 0xc7bc48c4, 0x58e56886,
0x78a70840, 0x18612802, 0xc9ccd9ed, 0xe98ef9af, 0x89489969, 0xa90ab92b,
0x4ad47ab7, 0x6a961a71, 0x0a503a33, 0x2a12dbfd, 0xfbbfeb9e, 0x9b798b58,
0xbb3bab1a, 0x6ca67c87, 0x5cc52c22, 0x3c030c60, 0x1c41edae, 0xfd8fcdec,
0xad2abd0b, 0x8d689d49, 0x7e976eb6, 0x5ed54ef4, 0x2e321e51, 0x0e70ff9f,
0xefbedfdd, 0xcffcbf1b, 0x9f598f78, 0x918881a9, 0xb1caa1eb, 0xd10cc12d,
0xe16f1080, 0x00a130c2, 0x20e35004, 0x40257046, 0x83b99398, 0xa3fbb3da,
0xc33dd31c, 0xe37ff35e, 0x129022f3, 0x32d24235, 0x52146277, 0x7256b5ea,
0x95a88589, 0xf56ee54f, 0xd52cc50d, 0x34e224c3, 0x04817466, 0x64475424,
0x4405a7db, 0xb7fa8799, 0xe75ff77e, 0xc71dd73c, 0x26d336f2, 0x069116b0,
0x76764615, 0x5634d94c, 0xc96df90e, 0xe92f99c8, 0xb98aa9ab, 0x58444865,
0x78066827, 0x18c008e1, 0x28a3cb7d, 0xdb5ceb3f, 0xfb1e8bf9, 0x9bd8abbb,
0x4a755a54, 0x6a377a16, 0x0af11ad0, 0x2ab33a92, 0xed0fdd6c, 0xcd4dbdaa,
0xad8b9de8, 0x8dc97c26, 0x5c644c45, 0x3ca22c83, 0x1ce00cc1, 0xef1fff3e,
0xdf7caf9b, 0xbfba8fd9, 0x9ff86e17, 0x7e364e55, 0x2e933eb2, 0x0ed11ef0
};
/* Expected CRC Value */
uint32_t uwExpectedCRCValue = 0x379E9F06;
// UART
Serial pc(PA_9, PA_10); //tx, rx
uint32_t uwCRCValue=0;
void app_start(int, char**) {
pc.baud(38400);
pc.printf("Wait 5 sec. \r\n");
wait(5);
pc.printf("Start CRC test\r\n");
__HAL_RCC_CRC_CLK_ENABLE();
CrcHandle.Instance = CRC;
if ( HAL_CRC_Init(&CrcHandle) != HAL_OK ) {
pc.printf("HAL_CRC_Init fail \r\n");
while(1);
}
uwCRCValue = HAL_CRC_Accumulate(&CrcHandle, (uint32_t *)aDataBuffer, BUFFER_SIZE);
pc.printf(" crc value = 0x%x \r\n", uwCRCValue);
if ( uwCRCValue != uwExpectedCRCValue ) {
pc.printf(" Not correct, right one is 0x%x \r\n", uwExpectedCRCValue);
} else {
pc.printf(" Correct ! \r\n");
}
}
Test Result :
Wait 5 sec.
Start CRC test
CRC clock enabled
crc value = 0x379e9f06
Correct !
留言
張貼留言