Cyclic Redundancy Check

Description

Functions that provide access to cyclic redundancy code (CRC) calculation. See crc.h for source code.

Functions

uint16_t halCommonCrc16 (uint8_t newByte, uint16_t prevResult)
 Calculates 16-bit cyclic redundancy code (CITT CRC 16).
 
uint32_t halCommonCrc32 (uint8_t newByte, uint32_t prevResult)
 Calculates 32-bit cyclic redundancy code.
 

Macros

#define INITIAL_CRC   0xFFFFFFFFL
 
#define CRC32_START   INITIAL_CRC
 
#define CRC32_END   0xDEBB20E3L
 

Function Documentation

◆ halCommonCrc16()

uint16_t halCommonCrc16 ( uint8_t  newByte,
uint16_t  prevResult 
)

Calculates 16-bit cyclic redundancy code (CITT CRC 16).

Applies the standard CITT CRC 16 polynomial to a single byte. It should support being called first with an initial value, then repeatedly until all data is processed.

Parameters
newByteThe new byte to be run through CRC.
prevResultThe previous CRC result.
Returns
The new CRC result.

◆ halCommonCrc32()

uint32_t halCommonCrc32 ( uint8_t  newByte,
uint32_t  prevResult 
)

Calculates 32-bit cyclic redundancy code.

Note
On some radios or micros, the CRC for error detection on packet data is calculated in hardware.

Applies a CRC32 polynomial to a single byte. It should support being called first with an initial value, then repeatedly until all data is processed.

Parameters
newByteThe new byte to be run through CRC.
prevResultThe previous CRC result.
Returns
The new CRC result.