CRC computation shows different results

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

CRC computation shows different results

跳至解决方案
3,723 次查看
nicolasguigo
Contributor II

Hello,

I have TWR-K64F120 and I use KDS (3.0.0) with KSDK (1.3.0). To compute the CRC, I use the fsl_crc module which provides the function "CRC_DRV_Get_CrcBlock" to compute the CRC. The module is configured to compute the CRC16 CCITT (polynomial is 0x1021). The result given the first time is correct and then... all the subsequent results are false, even if the same data is given!

My (simplified) test code is as below:

    uint8_t test_array[2] = { 0 };

    test_array[0] = 0x01;

    test_array[1] = ~test_array[0];
    uint32_t crc_computed = CRC_DRV_GetCrcBlock(crc16_CCITT_IDX, test_array, 2);

The first time the function is called, the result is 0x20EF which is expected. Calling the function after that always give a wrong (and different) result. Could you kindly help me to understand what I do (or don't do) which could cause the error?

标签 (1)
标记 (3)
0 项奖励
回复
1 解答
2,918 次查看
Hui_Ma
NXP TechSupport
NXP TechSupport

Hi,

Please download the latest MCUXpresso SDK software package (Rev.2.3.0) for TWR-K64F board.

There with the CRC example demo, which located at default path:

..\SDK_2.3.0_FRDM-K64F\boards\frdmk64f\driver_examples\crc

There need to re-config the CRC parameters.

Wish it helps.


Have a great day,
Mike

-----------------------------------------------------------------------------------------------------------------------
Note: If this post answers your question, please click the Correct Answer button. Thank you!
-----------------------------------------------------------------------------------------------------------------------

在原帖中查看解决方案

5 回复数
2,918 次查看
nicolasguigo
Contributor II

I noticed that the results are always the same and I managed to track down the cause of these results: the initial value (seed) takes the value of the computed CRC. Is it the expected behaviour? Do I have to call the CRC_DRV_Configure() function before each call to CRC_DRV_GetCrcBlock()?

0 项奖励
回复
2,919 次查看
Hui_Ma
NXP TechSupport
NXP TechSupport

Hi,

Please download the latest MCUXpresso SDK software package (Rev.2.3.0) for TWR-K64F board.

There with the CRC example demo, which located at default path:

..\SDK_2.3.0_FRDM-K64F\boards\frdmk64f\driver_examples\crc

There need to re-config the CRC parameters.

Wish it helps.


Have a great day,
Mike

-----------------------------------------------------------------------------------------------------------------------
Note: If this post answers your question, please click the Correct Answer button. Thank you!
-----------------------------------------------------------------------------------------------------------------------

2,918 次查看
nicolasguigo
Contributor II

Thanks for the pointers. The demo provided compute different types of CRCs so it makes sense that the CRC module is reconfigured at each call. It still seems a bit strange to have to reconfigure the CRC module before using it even though the CRC computed is exactly the same... writing so, I understand how the module is used in a re-entrant manner. It does make sense but having to call the "configure" function is not intuitive.

0 项奖励
回复
2,918 次查看
Ray_V
Contributor V

It does seem counter intuitive at first, but it is useful to do it this way.

Say you want to use the function to verify the contents of a serial flash and you don't have enough RAM to load it all.

You can load to RAM a portion at a time and call the function each time without re-initializing in between and this way you can get the CRC for the entire flash, if needed.

Besides, you don't need to re-initialize every time you want to calculate a CRC using the same algorithm, all you need is to "seed"(load initial value) before each calculation.

2,918 次查看
nicolasguigo
Contributor II

Thank you for the input, I didn't think of it as I only use the CRC to validate data in a communication protocol and some small parts of the flash (config data). Checking the CRC for the entire flash is indeed one good reason for designing it the way it is.

0 项奖励
回复