2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/CRC/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-10-27 13:42:30 +02:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/CRC/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/CRC/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/CRC/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/CRC/actions/workflows/jsoncheck.yml)
|
2021-01-29 12:31:58 +01:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/CRC/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/CRC.svg?maxAge=3600)](https://github.com/RobTillaart/CRC/releases)
|
|
|
|
|
|
|
|
|
|
|
|
# CRC
|
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
Arduino library with CRC8, CRC16, CRC32 and CRC64 functions.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
## Description
|
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
Goal of this library is to have a flexible and portable set of generic
|
|
|
|
CRC functions and classes.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
The CRCx classes have a number of added values. Most important is that
|
|
|
|
they allow one to verify intermediate CRC values. This is useful if one
|
|
|
|
sends a "train of packets" which include a CRC so far. This detects both
|
|
|
|
errors in one packet but also missing packets, or injected packages.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
Another trick one can do is change the polynome or the reverse flag during
|
|
|
|
the process. This makes it harder to imitate.
|
2021-04-07 13:31:22 +02:00
|
|
|
|
|
|
|
Furthermore the class allows to add values in single steps and continue too.
|
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
Finally the class version gives more readable code (imho) as the parameters
|
|
|
|
are explicitly set.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
**Note** the classes have same names as the static functions, except the class
|
|
|
|
is UPPER case. So CRC8 is a class and **crc8()** is the function.
|
|
|
|
|
|
|
|
Deeper tech info -https://en.wikipedia.org/wiki/Cyclic_redundancy_check
|
|
|
|
and many other websites.
|
|
|
|
|
|
|
|
|
|
|
|
## Interface CRC classes
|
|
|
|
|
|
|
|
These interfaces are very similar for CRC8, CRC16, CRC32 and CRC64 class.
|
2021-12-14 20:22:40 +01:00
|
|
|
The only difference is the data type for polynome, start- and end-mask,
|
|
|
|
and the returned CRC.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
Use **\#include "CRC8.h"**
|
|
|
|
|
|
|
|
- **CRC8()** Constructor
|
|
|
|
- **void reset()** set all internals to constructor defaults.
|
2021-12-14 20:22:40 +01:00
|
|
|
- **void restart()** reset internal CRC and count only; reuse values for other
|
|
|
|
e.g polynome, XOR masks and reverse flags.
|
2021-04-07 13:31:22 +02:00
|
|
|
- **void setPolynome(polynome)** set polynome, note reset sets a default polynome.
|
2021-10-27 13:42:30 +02:00
|
|
|
- **void setStartXOR(start)** set start-mask, default 0.
|
|
|
|
- **void setEndXOR(end)** set end-mask, default 0.
|
|
|
|
- **void setReverseIn(bool reverseIn)** reverse the bit pattern of input data (MSB vs LSB).
|
|
|
|
- **void setReverseOut(bool reverseOut)** reverse the bit pattern of CRC (MSB vs LSB).
|
2021-01-29 12:31:58 +01:00
|
|
|
- **void add(value)** add a single value to CRC calculation.
|
2021-12-14 20:22:40 +01:00
|
|
|
- **void add(array, uint32_t length)** add an array of values to the CRC.
|
|
|
|
In case of a warning/error use casting to (uint8_t \*).
|
|
|
|
- **uint8_t getCRC()** returns CRC calculated so far. This allows to check the CRC of
|
|
|
|
a really large stream at intermediate moments, e.g. to link multiple packets.
|
|
|
|
- **uint32_t count()** returns number of values added so far. Default 0.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
### Example snippet
|
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
A minimal usage only needs:
|
2021-01-29 12:31:58 +01:00
|
|
|
- the constructor, the add() function and the getCRC() function.
|
|
|
|
|
|
|
|
```cpp
|
2021-04-07 13:31:22 +02:00
|
|
|
#include "CRC32.h"
|
|
|
|
...
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
CRC32 crc;
|
|
|
|
...
|
|
|
|
while (Serial.available())
|
|
|
|
{
|
|
|
|
int c = Serial.read();
|
|
|
|
crc.add(c);
|
|
|
|
}
|
|
|
|
Serial.println(crc.getCRC());
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
## Interface static functions
|
|
|
|
|
|
|
|
Use **\#include "CRC.h"**
|
|
|
|
|
|
|
|
Most functions have a default polynome, same start and end masks, and default there is no reversing.
|
|
|
|
However these parameters allow one to tweak the CRC in all aspects known.
|
2021-10-27 13:42:30 +02:00
|
|
|
In all the examples encountered the reverse flags were set both to false or both to true.
|
2021-01-29 12:31:58 +01:00
|
|
|
For flexibility both parameters are kept available.
|
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
- **uint8_t crc8(array, length, polynome = 0xD5, start = 0, end = 0, reverseIn = false, reverseOut = false)** idem with default polynome.
|
|
|
|
- **uint16_t crc16(array, length, polynome = 0xA001, start = 0, end = 0, reverseIn = false, reverseOut = false)** idem with default polynome.
|
2021-01-29 12:31:58 +01:00
|
|
|
- **uint16_t crc16-CCITT(array, length)** fixed polynome **0x1021**, non zero start / end masks.
|
2021-12-14 20:22:40 +01:00
|
|
|
- **uint32_t crc32(array, length, polynome = 0x04C11DB7, start = 0, end = 0, reverseIn = false, reverseOut = false)** idem with default polynome.
|
|
|
|
- **uint64_t crc64(array, length, polynome, start, end, reverseIn, reverseOut)** - experimental version, no reference found except on Wikipedia.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
Note these functions are limited to one call per block of data. For more flexibility use the classes.
|
|
|
|
|
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
## Operational
|
|
|
|
|
|
|
|
See examples.
|
|
|
|
|
|
|
|
|
|
|
|
## Links
|
|
|
|
|
|
|
|
- https://en.wikipedia.org/wiki/Cyclic_redundancy_check - generic background.
|
|
|
|
- https://crccalc.com/ - online CRC calculator to verify.
|
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Future
|
|
|
|
|
|
|
|
- extend examples.
|
|
|
|
- table versions for performance? (performance - memory discussion)
|
|
|
|
- example showing multiple packages of data linked by their CRC.
|
|
|
|
- stream version - 4 classes class?
|
2021-04-07 13:31:22 +02:00
|
|
|
- setCRC(value) to be able to pick up where one left ?
|
|
|
|
- getters, getPolynome() etc?
|
|
|
|
-
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
#### Exotic CRC's ?
|
|
|
|
|
|
|
|
- **CRC1()** // parity :)
|
2021-12-14 20:22:40 +01:00
|
|
|
- **CRC4(array, length, polynome, start, end, reverseIn, reverseOut)** nibbles?
|
2021-01-29 12:31:58 +01:00
|
|
|
- default polynome 0x03
|
|
|
|
|
|
|
|
|
2021-12-14 20:22:40 +01:00
|
|
|
#### Magic \#defines for "common" polynomes? verify ?
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
- \#define CRC_ISO64 0x000000000000001B
|
|
|
|
- \#define CRC_ECMA64 0x42F0E1EBA9EA3693
|
|
|
|
|