|
- /* FastCRC library code is placed under the MIT license
- * Copyright (c) 2014-2019 Frank Bösing
- *
- * Permission is hereby granted, free of charge, to any person obtaining
- * a copy of this software and associated documentation files (the
- * "Software"), to deal in the Software without restriction, including
- * without limitation the rights to use, copy, modify, merge, publish,
- * distribute, sublicense, and/or sell copies of the Software, and to
- * permit persons to whom the Software is furnished to do so, subject to
- * the following conditions:
- *
- * The above copyright notice and this permission notice shall be
- * included in all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
- * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
- * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
- * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
-
-
- // Teensy 3.0, Teensy 3.1:
- // See K20P64M72SF1RM.pdf (Kinetis), Pages 638 - 641 for documentation of CRC Device
- // See KINETIS_4N30D.pdf for Errata (Errata ID 2776)
- //
- // So, ALL HW-calculations are done as 32 bit.
- //
- //
- //
- // Thanks to:
- // - Catalogue of parametrised CRC algorithms, CRC RevEng
- // http://reveng.sourceforge.net/crc-catalogue/
- //
- // - Danjel McGougan (CRC-Table-Generator)
- //
-
-
- // Set this to 0 for smaller 32BIT-CRC-Tables:
- #define CRC_BIGTABLES 1
-
-
- #if !defined(FastCRC_h)
- #define FastCRC_h
- #include "inttypes.h"
-
-
- // ================= DEFINES ===================
- #if defined(KINETISK)
- #define CRC_SW 0
- #define CRC_FLAG_NOREFLECT (((1<<31) | (1<<30)) | ((0<<29) | (0<<28))) //refin=false refout=false
- #define CRC_FLAG_REFLECT (((1<<31) | (0<<30)) | ((1<<29) | (0<<28))) //Reflect in- and outgoing bytes (refin=true refout=true)
- #define CRC_FLAG_XOR (1<<26) //Perform XOR on result
- #define CRC_FLAG_NOREFLECT_8 (0) //For 8-Bit CRC
- #define CRC_FLAG_REFLECT_SWAP (((1<<31) | (0<<30)) | ((0<<29) | (1<<28))) //For 16-Bit CRC (byteswap)
- #else
- #define CRC_SW 1
- #endif
-
- // ================= 7-BIT CRC ===================
- class FastCRC7
- {
- public:
- FastCRC7();
- uint8_t crc7(const uint8_t *data, const uint16_t datalen); // (MultiMediaCard interface)
- uint8_t crc7_upd(const uint8_t *data, const uint16_t datalen); // Call for subsequent calculations with previous seed.
- #if !CRC_SW
- uint8_t generic(const uint8_t polyom, const uint8_t seed, const uint32_t flags, const uint8_t *data, const uint16_t datalen); //Not available in non-hw-variant (not T3.x)
- #endif
- private:
- #if CRC_SW
- uint8_t seed;
- #else
- uint8_t update(const uint8_t *data, const uint16_t datalen);
- #endif
- };
-
- // ================= 8-BIT CRC ===================
-
- class FastCRC8
- {
- public:
- FastCRC8();
- uint8_t smbus(const uint8_t *data, const uint16_t datalen); // Alias CRC-8
- uint8_t maxim(const uint8_t *data, const uint16_t datalen); // Equivalent to _crc_ibutton_update() in crc16.h from avr_libc
-
- uint8_t smbus_upd(const uint8_t *data, uint16_t datalen); // Call for subsequent calculations with previous seed.
- uint8_t maxim_upd(const uint8_t *data, uint16_t datalen); // Call for subsequent calculations with previous seed.
- #if !CRC_SW
- uint8_t generic(const uint8_t polyom, const uint8_t seed, const uint32_t flags, const uint8_t *data, const uint16_t datalen); //Not available in non-hw-variant (not T3.x)
- #endif
- private:
- #if CRC_SW
- uint8_t seed;
- #else
- uint8_t update(const uint8_t *data, const uint16_t datalen);
- #endif
- };
-
- // ================= 14-BIT CRC ===================
-
- class FastCRC14
- {
- public:
- #if !CRC_SW //NO Software-implemenation so far
- FastCRC14();
- uint16_t darc(const uint8_t *data, const uint16_t datalen);
- uint16_t gsm(const uint8_t *data, const uint16_t datalen);
- uint16_t eloran(const uint8_t *data, const uint16_t datalen);
- uint16_t ft4(const uint8_t *data, const uint16_t datalen);
-
- uint16_t darc_upd(const uint8_t *data, uint16_t len);
- uint16_t gsm_upd(const uint8_t *data, uint16_t len);
- uint16_t eloran_upd(const uint8_t *data, uint16_t len);
- uint16_t ft4_upd(const uint8_t *data, uint16_t len);
- #endif
- #if !CRC_SW
- uint16_t generic(const uint16_t polyom, const uint16_t seed, const uint32_t flags, const uint8_t *data, const uint16_t datalen); //Not available in non-hw-variant (not T3.x)
- #endif
- private:
- #if CRC_SW
- uint16_t seed;
- #else
- uint16_t update(const uint8_t *data, const uint16_t datalen);
- #endif
- };
-
- // ================= 16-BIT CRC ===================
-
- class FastCRC16
- {
- public:
- FastCRC16();
- uint16_t ccitt(const uint8_t *data, const uint16_t datalen); // Alias "false CCITT"
- uint16_t mcrf4xx(const uint8_t *data,const uint16_t datalen); // Equivalent to _crc_ccitt_update() in crc16.h from avr_libc
- uint16_t kermit(const uint8_t *data, const uint16_t datalen); // Alias CRC-16/CCITT, CRC-16/CCITT-TRUE, CRC-CCITT
- uint16_t modbus(const uint8_t *data, const uint16_t datalen); // Equivalent to _crc_16_update() in crc16.h from avr_libc
- uint16_t xmodem(const uint8_t *data, const uint16_t datalen); // Alias ZMODEM, CRC-16/ACORN
- uint16_t x25(const uint8_t *data, const uint16_t datalen); // Alias CRC-16/IBM-SDLC, CRC-16/ISO-HDLC, CRC-B
-
- uint16_t ccitt_upd(const uint8_t *data, uint16_t len); // Call for subsequent calculations with previous seed
- uint16_t mcrf4xx_upd(const uint8_t *data, uint16_t len); // Call for subsequent calculations with previous seed
- uint16_t kermit_upd(const uint8_t *data, uint16_t len); // Call for subsequent calculations with previous seed
- uint16_t modbus_upd(const uint8_t *data, uint16_t len); // Call for subsequent calculations with previous seed
- uint16_t xmodem_upd(const uint8_t *data, uint16_t len); // Call for subsequent calculations with previous seed
- uint16_t x25_upd(const uint8_t *data, uint16_t len); // Call for subsequent calculations with previous seed
- #if !CRC_SW
- uint16_t generic(const uint16_t polyom, const uint16_t seed, const uint32_t flags, const uint8_t *data, const uint16_t datalen); //Not available in non-hw-variant (not T3.x)
- #endif
- private:
- #if CRC_SW
- uint16_t seed;
- #else
- uint16_t update(const uint8_t *data, const uint16_t datalen);
- #endif
- };
-
- // ================= 32-BIT CRC ===================
-
- class FastCRC32
- {
- public:
- FastCRC32();
- uint32_t crc32(const uint8_t *data, const uint16_t datalen); // Alias CRC-32/ADCCP, PKZIP, Ethernet, 802.3
- uint32_t cksum(const uint8_t *data, const uint16_t datalen); // Alias CRC-32/POSIX
-
- uint32_t crc32_upd(const uint8_t *data, uint16_t len); // Call for subsequent calculations with previous seed
- uint32_t cksum_upd(const uint8_t *data, uint16_t len); // Call for subsequent calculations with previous seed
- #if !CRC_SW
- uint32_t generic(const uint32_t polyom, const uint32_t seed, const uint32_t flags, const uint8_t *data, const uint16_t datalen); //Not available in non-hw-variant (not T3.x)
- #endif
- private:
- #if CRC_SW
- uint32_t seed;
- #else
- uint32_t update(const uint8_t *data, const uint16_t datalen);
- #endif
- };
-
- #endif
|