123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- /*
- * Copyright (c) 2018 Workaround GmbH.
- * Copyright (c) 2017 Intel Corporation.
- * Copyright (c) 2017 Nordic Semiconductor ASA
- * Copyright (c) 2015 Runtime Inc
- * Copyright (c) 2018 Google LLC.
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- /** @file
- * @brief CRC computation function
- */
- #ifndef ZEPHYR_INCLUDE_SYS_CRC_H_
- #define ZEPHYR_INCLUDE_SYS_CRC_H_
- #include <zephyr/types.h>
- #include <stdbool.h>
- #include <stddef.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /* Initial value expected to be used at the beginning of the crc8_ccitt
- * computation.
- */
- #define CRC8_CCITT_INITIAL_VALUE 0xFF
- /**
- * @defgroup checksum Checksum
- */
- /**
- * @defgroup crc CRC
- * @ingroup checksum
- * @{
- */
- /**
- * @brief Generic function for computing CRC 16
- *
- * Compute CRC 16 by passing in the address of the input, the input length
- * and polynomial used in addition to the initial value.
- *
- * @param src Input bytes for the computation
- * @param len Length of the input in bytes
- * @param polynomial The polynomial to use omitting the leading x^16
- * coefficient
- * @param initial_value Initial value for the CRC computation
- * @param pad Adds padding with zeros at the end of input bytes
- *
- * @return The computed CRC16 value
- */
- uint16_t crc16(const uint8_t *src, size_t len, uint16_t polynomial,
- uint16_t initial_value, bool pad);
- /**
- * @brief Generic function for computing CRC 8
- *
- * Compute CRC 8 by passing in the address of the input, the input length
- * and polynomial used in addition to the initial value.
- *
- * @param src Input bytes for the computation
- * @param len Length of the input in bytes
- * @param polynomial The polynomial to use omitting the leading x^8
- * coefficient
- * @param initial_value Initial value for the CRC computation
- * @param reversed Should we use reflected/reversed values or not
- *
- * @return The computed CRC8 value
- */
- uint8_t crc8(const uint8_t *src, size_t len, uint8_t polynomial, uint8_t initial_value,
- bool reversed);
- /**
- * @brief Compute the CRC-16/CCITT checksum of a buffer.
- *
- * See ITU-T Recommendation V.41 (November 1988). Uses 0x1021 as the
- * polynomial, reflects the input, and reflects the output.
- *
- * To calculate the CRC across non-contiguous blocks use the return
- * value from block N-1 as the seed for block N.
- *
- * For CRC-16/CCITT, use 0 as the initial seed. Other checksums in
- * the same family can be calculated by changing the seed and/or
- * XORing the final value. Examples include:
- *
- * - X-25 (used in PPP): seed=0xffff, xor=0xffff, residual=0xf0b8
- *
- * @note API changed in Zephyr 1.11.
- *
- * @param seed Value to seed the CRC with
- * @param src Input bytes for the computation
- * @param len Length of the input in bytes
- *
- * @return The computed CRC16 value
- */
- uint16_t crc16_ccitt(uint16_t seed, const uint8_t *src, size_t len);
- /**
- * @brief Compute the CRC-16/XMODEM checksum of a buffer.
- *
- * The MSB first version of ITU-T Recommendation V.41 (November 1988).
- * Uses 0x1021 as the polynomial with no reflection.
- *
- * To calculate the CRC across non-contiguous blocks use the return
- * value from block N-1 as the seed for block N.
- *
- * For CRC-16/XMODEM, use 0 as the initial seed. Other checksums in
- * the same family can be calculated by changing the seed and/or
- * XORing the final value. Examples include:
- *
- * - CCIITT-FALSE: seed=0xffff
- * - GSM: seed=0, xorout=0xffff, residue=0x1d0f
- *
- * @param seed Value to seed the CRC with
- * @param src Input bytes for the computation
- * @param len Length of the input in bytes
- *
- * @return The computed CRC16 value
- */
- uint16_t crc16_itu_t(uint16_t seed, const uint8_t *src, size_t len);
- /**
- * @brief Compute ANSI variant of CRC 16
- *
- * ANSI variant of CRC 16 is using 0x8005 as its polynomial with the initial
- * value set to 0xffff.
- *
- * @param src Input bytes for the computation
- * @param len Length of the input in bytes
- *
- * @return The computed CRC16 value
- */
- static inline uint16_t crc16_ansi(const uint8_t *src, size_t len)
- {
- return crc16(src, len, 0x8005, 0xffff, true);
- }
- /**
- * @brief Generate IEEE conform CRC32 checksum.
- *
- * @param *data Pointer to data on which the CRC should be calculated.
- * @param len Data length.
- *
- * @return CRC32 value.
- *
- */
- uint32_t crc32_ieee(const uint8_t *data, size_t len);
- /**
- * @brief Update an IEEE conforming CRC32 checksum.
- *
- * @param crc CRC32 checksum that needs to be updated.
- * @param *data Pointer to data on which the CRC should be calculated.
- * @param len Data length.
- *
- * @return CRC32 value.
- *
- */
- uint32_t crc32_ieee_update(uint32_t crc, const uint8_t *data, size_t len);
- /**
- * @brief Calculate CRC32C (Castagnoli) checksum.
- *
- * @param crc CRC32C checksum that needs to be updated.
- * @param *data Pointer to data on which the CRC should be calculated.
- * @param len Data length.
- * @param first_pkt Whether this is the first packet in the stream.
- * @param last_pkt Whether this is the last packet in the stream.
- *
- * @return CRC32 value.
- *
- */
- uint32_t crc32_c(uint32_t crc, const uint8_t *data,
- size_t len, bool first_pkt, bool last_pkt);
- /**
- * @brief Compute CCITT variant of CRC 8
- *
- * Normal CCITT variant of CRC 8 is using 0x07.
- *
- * @param initial_value Initial value for the CRC computation
- * @param buf Input bytes for the computation
- * @param len Length of the input in bytes
- *
- * @return The computed CRC8 value
- */
- uint8_t crc8_ccitt(uint8_t initial_value, const void *buf, size_t len);
- /**
- * @brief Compute the CRC-7 checksum of a buffer.
- *
- * See JESD84-A441. Used by the MMC protocol. Uses 0x09 as the
- * polynomial with no reflection. The CRC is left
- * justified, so bit 7 of the result is bit 6 of the CRC.
- *
- * @param seed Value to seed the CRC with
- * @param src Input bytes for the computation
- * @param len Length of the input in bytes
- *
- * @return The computed CRC7 value
- */
- uint8_t crc7_be(uint8_t seed, const uint8_t *src, size_t len);
- /**
- * @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif
|