GPCRC
Detailed Description
General Purpose Cyclic Redundancy Check (GPCRC) API.
The GPCRC API functions provide full support for the GPCRC peripheral.
The GPCRC module is a peripheral that implements a Cyclic Redundancy Check (CRC) function. It supports a fixed 32-bit polynomial and a user configurable 16-bit polynomial. The fixed 32-bit polynomial is the commonly used IEEE 802.3 polynomial 0x04C11DB7.
When using a 16-bit polynomial it is up to the user to choose a polynomial that fits the application. Commonly used 16-bit polynomials are 0x1021 (CCITT-16), 0x3D65 (IEC16-MBus), and 0x8005 (ZigBee, 802.15.4, and USB). See this link for other polynomials: https://en.wikipedia.org/wiki/Cyclic_redundancy_check
Before a CRC calculation can begin it is important to call the GPCRC_Start function. This function will reset CRC calculation by copying the configured initialization value over to the CRC data register.
There are two ways of sending input data to the GPCRC. Either write the input data into the input data register using input functions GPCRC_InputU32 , GPCRC_InputU16 and GPCRC_InputU8 , or the user can configure LDMA to transfer data directly to one of the GPCRC input data registers.
Examples of GPCRC usage:
A CRC-32 Calculation:
A CRC-16 Calculation:
A CRC-CCITT calculation:
| Data Structures | |
| struct | GPCRC_Init_TypeDef | 
| Macros | |
| #define | GPCRC_INIT_DEFAULT | 
| Functions | |
| __STATIC_INLINE uint32_t | GPCRC_DataRead (GPCRC_TypeDef *gpcrc) | 
| Reads the data register of the CRC. | |
| __STATIC_INLINE uint32_t | GPCRC_DataReadBitReversed (GPCRC_TypeDef *gpcrc) | 
| Reads the data register of the CRC bit reversed. | |
| __STATIC_INLINE uint32_t | GPCRC_DataReadByteReversed (GPCRC_TypeDef *gpcrc) | 
| Reads the data register of the CRC byte reversed. | |
| __STATIC_INLINE void | GPCRC_Enable (GPCRC_TypeDef *gpcrc, bool enable) | 
| Enable/disable GPCRC. | |
| void | GPCRC_Init (GPCRC_TypeDef *gpcrc, const GPCRC_Init_TypeDef *init) | 
| Initialize the General Purpose Cyclic Redundancy Check (GPCRC) module. | |
| __STATIC_INLINE void | GPCRC_InitValueSet (GPCRC_TypeDef *gpcrc, uint32_t initValue) | 
| Set the initialization value of the CRC. | |
| __STATIC_INLINE void | GPCRC_InputU16 (GPCRC_TypeDef *gpcrc, uint16_t data) | 
| Writes a 16-bit value to the input data register of the CRC. | |
| __STATIC_INLINE void | GPCRC_InputU32 (GPCRC_TypeDef *gpcrc, uint32_t data) | 
| Writes a 32-bit value to the input data register of the CRC. | |
| __STATIC_INLINE void | GPCRC_InputU8 (GPCRC_TypeDef *gpcrc, uint8_t data) | 
| Writes an 8-bit value to the input data register of the CRC. | |
| void | GPCRC_Reset (GPCRC_TypeDef *gpcrc) | 
| Reset GPCRC registers to the hardware reset state. | |
| __STATIC_INLINE void | GPCRC_Start (GPCRC_TypeDef *gpcrc) | 
| Issues a command to initialize CRC calculation. | |
Macro Definition Documentation
| #define GPCRC_INIT_DEFAULT | 
Default configuration for GPCRC_Init_TypeDef structure.
        Definition at line
        
         159
        
        of file
        
         em_gpcrc.h
        
        .
       
Function Documentation
| __STATIC_INLINE uint32_t GPCRC_DataRead | ( | GPCRC_TypeDef * | 
            gpcrc
            | ) | 
Reads the data register of the CRC.
Use this function to read the calculated CRC value.
- Parameters
- 
         [in] gpcrcPointer to GPCRC peripheral register block. 
- Returns
- Content of the CRC data register.
        Definition at line
        
         301
        
        of file
        
         em_gpcrc.h
        
        .
       
| __STATIC_INLINE uint32_t GPCRC_DataReadBitReversed | ( | GPCRC_TypeDef * | 
            gpcrc
            | ) | 
Reads the data register of the CRC bit reversed.
Use this function to read the calculated CRC value bit reversed. When using a 32-bit polynomial, bits [31:0] are reversed, when using a 16-bit polynomial, bits [15:0] are reversed.
- Parameters
- 
         [in] gpcrcPointer to GPCRC peripheral register block. 
- Returns
- Content of the CRC data register bit reversed.
        Definition at line
        
         321
        
        of file
        
         em_gpcrc.h
        
        .
       
| __STATIC_INLINE uint32_t GPCRC_DataReadByteReversed | ( | GPCRC_TypeDef * | 
            gpcrc
            | ) | 
Reads the data register of the CRC byte reversed.
Use this function to read the calculated CRC value byte reversed.
- Parameters
- 
         [in] gpcrcPointer to GPCRC peripheral register block. 
- Returns
- Content of the CRC data register byte reversed.
        Definition at line
        
         339
        
        of file
        
         em_gpcrc.h
        
        .
       
| __STATIC_INLINE void GPCRC_Enable | ( | GPCRC_TypeDef * | 
            gpcrc,
            | 
| bool | 
            enable
            | ||
| ) | 
Enable/disable GPCRC.
- Parameters
- 
         [in] gpcrcPointer to GPCRC peripheral register block. [in] enableTrue to enable GPCRC, false to disable. 
        Definition at line
        
         187
        
        of file
        
         em_gpcrc.h
        
        .
       
References BUS_RegBitWrite() .
| void GPCRC_Init | ( | GPCRC_TypeDef * | 
            gpcrc,
            | 
| const GPCRC_Init_TypeDef * | 
            init
            | ||
| ) | 
Initialize the General Purpose Cyclic Redundancy Check (GPCRC) module.
Use this function to configure the operational parameters of the GPCRC, such as the polynomial to use and how the input should be preprocessed before entering the CRC calculation.
- Note
- This function will not copy the initialization value to the data register to prepare for a new CRC calculation. Either call GPCRC_Start before each calculation or by use the autoInit functionality.
- Parameters
- 
         [in] gpcrcA pointer to the GPCRC peripheral register block. [in] initA pointer to the initialization structure used to configure the GPCRC. 
        Definition at line
        
         72
        
        of file
        
         em_gpcrc.c
        
        .
       
References GPCRC_Init_TypeDef::autoInit , GPCRC_Init_TypeDef::crcPoly , GPCRC_Init_TypeDef::enable , GPCRC_Init_TypeDef::enableByteMode , GPCRC_Init_TypeDef::initValue , GPCRC_Init_TypeDef::reverseBits , GPCRC_Init_TypeDef::reverseByteOrder , and SL_RBIT16() .
| __STATIC_INLINE void GPCRC_InitValueSet | ( | GPCRC_TypeDef * | 
            gpcrc,
            | 
| uint32_t | 
            initValue
            | ||
| ) | 
Set the initialization value of the CRC.
- Parameters
- 
         [in] initValueValue to use to initialize a CRC calculation. This value is moved into the data register when calling GPCRC_Start [in] gpcrcPointer to GPCRC peripheral register block. 
        Definition at line
        
         223
        
        of file
        
         em_gpcrc.h
        
        .
       
| __STATIC_INLINE void GPCRC_InputU16 | ( | GPCRC_TypeDef * | 
            gpcrc,
            | 
| uint16_t | 
            data
            | ||
| ) | 
Writes a 16-bit value to the input data register of the CRC.
Use this function to write a 16 bit input data to the CRC. CRC calculation is based on the provided input data using the configured CRC polynomial.
- Parameters
- 
         [in] gpcrcPointer to GPCRC peripheral register block. [in] dataData to be written to the input data register. 
        Definition at line
        
         263
        
        of file
        
         em_gpcrc.h
        
        .
       
| __STATIC_INLINE void GPCRC_InputU32 | ( | GPCRC_TypeDef * | 
            gpcrc,
            | 
| uint32_t | 
            data
            | ||
| ) | 
Writes a 32-bit value to the input data register of the CRC.
Use this function to write a 32-bit input data to the CRC. CRC calculation is based on the provided input data using the configured CRC polynomial.
- Parameters
- 
         [in] gpcrcPointer to GPCRC peripheral register block. [in] dataData to be written to the input data register. 
        Definition at line
        
         243
        
        of file
        
         em_gpcrc.h
        
        .
       
| __STATIC_INLINE void GPCRC_InputU8 | ( | GPCRC_TypeDef * | 
            gpcrc,
            | 
| uint8_t | 
            data
            | ||
| ) | 
Writes an 8-bit value to the input data register of the CRC.
Use this function to write an 8-bit input data to the CRC. CRC calculation is based on the provided input data using the configured CRC polynomial.
- Parameters
- 
         [in] gpcrcPointer to GPCRC peripheral register block. [in] dataData to be written to the input data register. 
        Definition at line
        
         283
        
        of file
        
         em_gpcrc.h
        
        .
       
| void GPCRC_Reset | ( | GPCRC_TypeDef * | 
            gpcrc
            | ) | 
Reset GPCRC registers to the hardware reset state.
- Note
- The data registers are not reset by this function.
- Parameters
- 
         [in] gpcrcA pointer to the GPCRC peripheral register block. 
        Definition at line
        
         134
        
        of file
        
         em_gpcrc.c
        
        .
       
| __STATIC_INLINE void GPCRC_Start | ( | GPCRC_TypeDef * | 
            gpcrc
            | ) | 
Issues a command to initialize CRC calculation.
Issues the command INIT in GPCRC_CMD that initializes CRC calculation by writing the initial values to the DATA register.
- Parameters
- 
         [in] gpcrcPointer to GPCRC peripheral register block. 
        Definition at line
        
         207
        
        of file
        
         em_gpcrc.h
        
        .