2018-05-10 14:49:39 +00:00
|
|
|
#include "crc_api.h"
|
2018-05-11 16:07:20 +00:00
|
|
|
#include "device.h"
|
2018-05-10 14:49:39 +00:00
|
|
|
|
|
|
|
#include "platform/mbed_assert.h"
|
|
|
|
|
|
|
|
#ifdef DEVICE_CRC
|
|
|
|
|
|
|
|
static CRC_HandleTypeDef current_state;
|
|
|
|
static uint32_t final_xor;
|
|
|
|
|
2018-06-27 12:21:07 +00:00
|
|
|
bool hal_crc_is_supported(const crc_mbed_config_t *config)
|
2018-05-10 14:49:39 +00:00
|
|
|
{
|
2018-06-27 12:21:07 +00:00
|
|
|
if (config == NULL) {
|
|
|
|
return false;
|
|
|
|
}
|
2018-05-10 14:49:39 +00:00
|
|
|
|
2018-06-27 12:21:07 +00:00
|
|
|
if (config->polynomial != POLY_32BIT_ANSI) {
|
|
|
|
return false;
|
|
|
|
}
|
2018-05-10 14:49:39 +00:00
|
|
|
|
2018-06-27 12:21:07 +00:00
|
|
|
if (config->width != 32) {
|
|
|
|
return false;
|
|
|
|
}
|
2018-05-10 14:49:39 +00:00
|
|
|
|
2018-06-27 12:21:07 +00:00
|
|
|
if ((config->final_xor != 0xFFFFFFFFU) && (config->final_xor != 0)) {
|
|
|
|
return false;
|
|
|
|
}
|
2018-05-10 14:49:39 +00:00
|
|
|
|
2018-06-27 12:21:07 +00:00
|
|
|
return true;
|
2018-05-10 14:49:39 +00:00
|
|
|
}
|
|
|
|
|
2018-06-27 12:21:07 +00:00
|
|
|
void hal_crc_compute_partial_start(const crc_mbed_config_t *config)
|
2018-05-10 14:49:39 +00:00
|
|
|
{
|
2018-06-27 12:21:07 +00:00
|
|
|
MBED_ASSERT(hal_crc_is_supported(config));
|
|
|
|
|
|
|
|
__HAL_RCC_CRC_CLK_ENABLE();
|
|
|
|
|
|
|
|
final_xor = config->final_xor;
|
|
|
|
|
|
|
|
current_state.Instance = CRC;
|
|
|
|
current_state.InputDataFormat = CRC_INPUTDATA_FORMAT_BYTES;
|
|
|
|
current_state.Init.DefaultPolynomialUse = DEFAULT_POLYNOMIAL_ENABLE;
|
|
|
|
current_state.Init.DefaultInitValueUse = DEFAULT_INIT_VALUE_DISABLE;
|
|
|
|
current_state.Init.InitValue = config->initial_xor;
|
|
|
|
current_state.Init.CRCLength = CRC_POLYLENGTH_32B;
|
|
|
|
current_state.Init.InputDataInversionMode =
|
|
|
|
config->reflect_in ? CRC_INPUTDATA_INVERSION_BYTE
|
|
|
|
: CRC_INPUTDATA_INVERSION_NONE;
|
|
|
|
current_state.Init.OutputDataInversionMode =
|
|
|
|
config->reflect_out ? CRC_OUTPUTDATA_INVERSION_ENABLE
|
|
|
|
: CRC_OUTPUTDATA_INVERSION_DISABLE;
|
|
|
|
|
|
|
|
HAL_CRC_Init(¤t_state);
|
2018-05-10 14:49:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void hal_crc_compute_partial(const uint8_t *data, const size_t size)
|
|
|
|
{
|
2018-06-27 12:21:07 +00:00
|
|
|
if (data && size) {
|
|
|
|
HAL_CRC_Accumulate(¤t_state, (uint32_t *)data, size);
|
|
|
|
}
|
2018-05-10 14:49:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t hal_crc_get_result(void)
|
|
|
|
{
|
2018-06-27 12:21:07 +00:00
|
|
|
const uint32_t result = current_state.Instance->DR;
|
2018-05-10 14:49:39 +00:00
|
|
|
|
2018-06-27 12:21:07 +00:00
|
|
|
return (final_xor == 0xFFFFFFFFU) ? ~result : result;
|
2018-05-10 14:49:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif // DEVICE_CRC
|