123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292 |
- #include "fsl_crc.h"
- #ifndef FSL_COMPONENT_ID
- #define FSL_COMPONENT_ID "platform.drivers.crc"
- #endif
- #if defined(FSL_FEATURE_CRC_HAS_CRC_REG) && FSL_FEATURE_CRC_HAS_CRC_REG
- #define DATA CRC
- #define DATALL CRCLL
- #endif
- #if defined(CRC_DRIVER_USE_CRC16_CCIT_FALSE_AS_DEFAULT) && CRC_DRIVER_USE_CRC16_CCIT_FALSE_AS_DEFAULT
- #define CRC_DRIVER_DEFAULT_POLYNOMIAL 0x1021U
- #define CRC_DRIVER_DEFAULT_SEED 0xFFFFU
- #define CRC_DRIVER_DEFAULT_REFLECT_IN false
- #define CRC_DRIVER_DEFAULT_REFLECT_OUT false
- #define CRC_DRIVER_DEFAULT_COMPLEMENT_CHECKSUM false
- #define CRC_DRIVER_DEFAULT_CRC_BITS kCrcBits16
- #define CRC_DRIVER_DEFAULT_CRC_RESULT kCrcFinalChecksum
- #endif
- typedef enum _crc_transpose_type
- {
- kCrcTransposeNone = 0U,
- kCrcTransposeBits = 1U,
- kCrcTransposeBitsAndBytes = 2U,
- kCrcTransposeBytes = 3U,
- } crc_transpose_type_t;
- typedef struct _crc_module_config
- {
- uint32_t polynomial;
- uint32_t seed;
- crc_transpose_type_t readTranspose;
- crc_transpose_type_t writeTranspose;
- bool complementChecksum;
- crc_bits_t crcBits;
- } crc_module_config_t;
- static inline crc_transpose_type_t CRC_GetTransposeTypeFromReflectIn(bool enable)
- {
- return ((enable) ? kCrcTransposeBitsAndBytes : kCrcTransposeBytes);
- }
- static inline crc_transpose_type_t CRC_GetTransposeTypeFromReflectOut(bool enable)
- {
- return ((enable) ? kCrcTransposeBitsAndBytes : kCrcTransposeNone);
- }
- static void CRC_ConfigureAndStart(CRC_Type *base, const crc_module_config_t *config)
- {
- uint32_t crcControl;
-
- crcControl = 0 | CRC_CTRL_TOT(config->writeTranspose) | CRC_CTRL_TOTR(config->readTranspose) |
- CRC_CTRL_FXOR(config->complementChecksum) | CRC_CTRL_TCRC(config->crcBits);
-
- base->CTRL = crcControl;
-
- base->GPOLY = config->polynomial;
-
- base->CTRL = crcControl | CRC_CTRL_WAS(true);
-
- base->DATA = config->seed;
-
- base->CTRL = crcControl;
- }
- static void CRC_SetProtocolConfig(CRC_Type *base, const crc_config_t *protocolConfig)
- {
- crc_module_config_t moduleConfig;
-
- moduleConfig.polynomial = protocolConfig->polynomial;
- moduleConfig.seed = protocolConfig->seed;
- moduleConfig.readTranspose = CRC_GetTransposeTypeFromReflectOut(protocolConfig->reflectOut);
- moduleConfig.writeTranspose = CRC_GetTransposeTypeFromReflectIn(protocolConfig->reflectIn);
- moduleConfig.complementChecksum = protocolConfig->complementChecksum;
- moduleConfig.crcBits = protocolConfig->crcBits;
- CRC_ConfigureAndStart(base, &moduleConfig);
- }
- static void CRC_SetRawProtocolConfig(CRC_Type *base, const crc_config_t *protocolConfig)
- {
- crc_module_config_t moduleConfig;
-
- moduleConfig.polynomial = protocolConfig->polynomial;
- moduleConfig.seed = protocolConfig->seed;
- moduleConfig.readTranspose =
- kCrcTransposeNone;
- moduleConfig.writeTranspose = CRC_GetTransposeTypeFromReflectIn(protocolConfig->reflectIn);
- moduleConfig.complementChecksum = false;
- moduleConfig.crcBits = protocolConfig->crcBits;
- CRC_ConfigureAndStart(base, &moduleConfig);
- }
- void CRC_Init(CRC_Type *base, const crc_config_t *config)
- {
- #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
-
- CLOCK_EnableClock(kCLOCK_Crc0);
- #endif
-
- if (config->crcResult == kCrcFinalChecksum)
- {
- CRC_SetProtocolConfig(base, config);
- }
- else
- {
- CRC_SetRawProtocolConfig(base, config);
- }
- }
- void CRC_GetDefaultConfig(crc_config_t *config)
- {
- static const crc_config_t crc16ccit = {
- CRC_DRIVER_DEFAULT_POLYNOMIAL, CRC_DRIVER_DEFAULT_SEED,
- CRC_DRIVER_DEFAULT_REFLECT_IN, CRC_DRIVER_DEFAULT_REFLECT_OUT,
- CRC_DRIVER_DEFAULT_COMPLEMENT_CHECKSUM, CRC_DRIVER_DEFAULT_CRC_BITS,
- CRC_DRIVER_DEFAULT_CRC_RESULT,
- };
- *config = crc16ccit;
- }
- void CRC_WriteData(CRC_Type *base, const uint8_t *data, size_t dataSize)
- {
- const uint32_t *data32;
-
- while ((dataSize) && ((uint32_t)data & 3U))
- {
- base->ACCESS8BIT.DATALL = *data;
- data++;
- dataSize--;
- }
-
- data32 = (const uint32_t *)data;
- while (dataSize >= sizeof(uint32_t))
- {
- base->DATA = *data32;
- data32++;
- dataSize -= sizeof(uint32_t);
- }
- data = (const uint8_t *)data32;
-
- while (dataSize)
- {
- base->ACCESS8BIT.DATALL = *data;
- data++;
- dataSize--;
- }
- }
- uint32_t CRC_Get32bitResult(CRC_Type *base)
- {
- return base->DATA;
- }
- uint16_t CRC_Get16bitResult(CRC_Type *base)
- {
- uint32_t retval;
- uint32_t totr;
- retval = base->DATA;
- totr = (base->CTRL & CRC_CTRL_TOTR_MASK) >> CRC_CTRL_TOTR_SHIFT;
-
- if (totr >= 2U)
- {
-
- retval &= 0xFFFF0000U;
- retval = retval >> 16U;
- }
- else
- {
-
- retval &= 0x0000FFFFU;
- }
- return (uint16_t)retval;
- }
|