Zephyr API Documentation 4.1.99
A Scalable Open Source RTOS
 4.1.99
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
crc.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 Workaround GmbH.
3 * Copyright (c) 2017 Intel Corporation.
4 * Copyright (c) 2017 Nordic Semiconductor ASA
5 * Copyright (c) 2015 Runtime Inc
6 * Copyright (c) 2018 Google LLC.
7 * Copyright (c) 2022 Meta
8 * Copyright (c) 2024 Intercreate, Inc.
9 *
10 * SPDX-License-Identifier: Apache-2.0
11 */
16#ifndef ZEPHYR_INCLUDE_SYS_CRC_H_
17#define ZEPHYR_INCLUDE_SYS_CRC_H_
18
19#include <zephyr/types.h>
20#include <stdbool.h>
21#include <stddef.h>
22
23#include <zephyr/sys/__assert.h>
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
29/* Initial value expected to be used at the beginning of the crc8_ccitt
30 * computation.
31 */
32#define CRC8_CCITT_INITIAL_VALUE 0xFF
33#define CRC8_ROHC_INITIAL_VALUE 0xFF
34
35/* Initial value expected to be used at the beginning of the OpenPGP CRC-24 computation. */
36#define CRC24_PGP_INITIAL_VALUE 0x00B704CEU
37/*
38 * The CRC-24 value is stored on a 32-bit value, only the 3 least significant bytes
39 * are meaningful. Use the following mask to only keep the CRC-24 value.
40 */
41#define CRC24_FINAL_VALUE_MASK 0x00FFFFFFU
42
75
95uint16_t crc16(uint16_t poly, uint16_t seed, const uint8_t *src, size_t len);
96
125uint16_t crc16_reflect(uint16_t poly, uint16_t seed, const uint8_t *src, size_t len);
141uint8_t crc8(const uint8_t *src, size_t len, uint8_t polynomial, uint8_t initial_value,
142 bool reversed);
143
175uint16_t crc16_ccitt(uint16_t seed, const uint8_t *src, size_t len);
176
212uint16_t crc16_itu_t(uint16_t seed, const uint8_t *src, size_t len);
213
225static inline uint16_t crc16_ansi(const uint8_t *src, size_t len)
226{
227 return crc16_reflect(0xA001, 0xffff, src, len);
228}
229
239uint32_t crc32_ieee(const uint8_t *data, size_t len);
240
251uint32_t crc32_ieee_update(uint32_t crc, const uint8_t *data, size_t len);
252
266 size_t len, bool first_pkt, bool last_pkt);
267
292uint32_t crc32_k_4_2_update(uint32_t crc, const uint8_t *data, size_t len);
293
305uint8_t crc8_ccitt(uint8_t initial_value, const void *buf, size_t len);
306
319uint8_t crc8_rohc(uint8_t initial_value, const void *buf, size_t len);
320
334uint8_t crc7_be(uint8_t seed, const uint8_t *src, size_t len);
335
349uint8_t crc4_ti(uint8_t seed, const uint8_t *src, size_t len);
350
368uint8_t crc4(const uint8_t *src, size_t len, uint8_t polynomial, uint8_t initial_value,
369 bool reversed);
370
379uint32_t crc24_pgp(const uint8_t *data, size_t len);
380
392uint32_t crc24_pgp_update(uint32_t crc, const uint8_t *data, size_t len);
393
416static inline uint32_t crc_by_type(enum crc_type type, const uint8_t *src, size_t len,
417 uint32_t seed, uint32_t poly, bool reflect, bool first,
418 bool last)
419{
420 switch (type) {
421 case CRC4:
422 return crc4(src, len, poly, seed, reflect);
423 case CRC4_TI:
424 return crc4_ti(seed, src, len);
425 case CRC7_BE:
426 return crc7_be(seed, src, len);
427 case CRC8:
428 return crc8(src, len, poly, seed, reflect);
429 case CRC8_CCITT:
430 return crc8_ccitt(seed, src, len);
431 case CRC8_ROHC:
432 return crc8_rohc(seed, src, len);
433 case CRC16:
434 if (reflect) {
435 return crc16_reflect(poly, seed, src, len);
436 } else {
437 return crc16(poly, seed, src, len);
438 }
439 case CRC16_ANSI:
440 return crc16_ansi(src, len);
441 case CRC16_CCITT:
442 return crc16_ccitt(seed, src, len);
443 case CRC16_ITU_T:
444 return crc16_itu_t(seed, src, len);
445 case CRC24_PGP: {
446 uint32_t crc = crc24_pgp_update(seed, src, len);
447
448 if (last)
450 return crc;
451 }
452 case CRC32_C:
453 return crc32_c(seed, src, len, first, last);
454 case CRC32_IEEE:
455 return crc32_ieee_update(seed, src, len);
456 case CRC32_K_4_2:
457 return crc32_k_4_2_update(seed, src, len);
458 default:
459 break;
460 }
461
462 __ASSERT_NO_MSG(false);
463 return -1;
464}
465
470#ifdef __cplusplus
471}
472#endif
473
474#endif
#define CRC24_FINAL_VALUE_MASK
Definition crc.h:41
uint8_t crc7_be(uint8_t seed, const uint8_t *src, size_t len)
Compute the CRC-7 checksum of a buffer.
uint32_t crc32_ieee_update(uint32_t crc, const uint8_t *data, size_t len)
Update an IEEE conforming CRC32 checksum.
uint16_t crc16(uint16_t poly, uint16_t seed, const uint8_t *src, size_t len)
Generic function for computing a CRC-16 without input or output reflection.
uint8_t crc4_ti(uint8_t seed, const uint8_t *src, size_t len)
Compute the CRC-4 checksum of a buffer.
uint8_t crc4(const uint8_t *src, size_t len, uint8_t polynomial, uint8_t initial_value, bool reversed)
Generic function for computing CRC 4.
uint32_t crc24_pgp_update(uint32_t crc, const uint8_t *data, size_t len)
Update an OpenPGP CRC-24 checksum.
uint16_t crc16_itu_t(uint16_t seed, const uint8_t *src, size_t len)
Compute the checksum of a buffer with polynomial 0x1021, no reflection of input or output.
static uint32_t crc_by_type(enum crc_type type, const uint8_t *src, size_t len, uint32_t seed, uint32_t poly, bool reflect, bool first, bool last)
Compute a CRC checksum, in a generic way.
Definition crc.h:416
uint16_t crc16_ccitt(uint16_t seed, const uint8_t *src, size_t len)
Compute the checksum of a buffer with polynomial 0x1021, reflecting input and output.
uint8_t crc8_rohc(uint8_t initial_value, const void *buf, size_t len)
Compute ROHC variant of CRC 8.
uint32_t crc32_c(uint32_t crc, const uint8_t *data, size_t len, bool first_pkt, bool last_pkt)
Calculate CRC32C (Castagnoli) checksum.
uint8_t crc8_ccitt(uint8_t initial_value, const void *buf, size_t len)
Compute CCITT variant of CRC 8.
uint8_t crc8(const uint8_t *src, size_t len, uint8_t polynomial, uint8_t initial_value, bool reversed)
Generic function for computing CRC 8.
static uint16_t crc16_ansi(const uint8_t *src, size_t len)
Compute the ANSI (or Modbus) variant of CRC-16.
Definition crc.h:225
uint32_t crc32_k_4_2_update(uint32_t crc, const uint8_t *data, size_t len)
Update a CRC-32K/4.2 (*op) (Koopman) checksum.
crc_type
CRC algorithm enumeration.
Definition crc.h:59
uint16_t crc16_reflect(uint16_t poly, uint16_t seed, const uint8_t *src, size_t len)
Generic function for computing a CRC-16 with input and output reflection.
uint32_t crc24_pgp(const uint8_t *data, size_t len)
Generate an OpenPGP CRC-24 checksum as defined in RFC 4880 section 6.1.
uint32_t crc32_ieee(const uint8_t *data, size_t len)
Generate IEEE conform CRC32 checksum.
@ CRC7_BE
Use crc7_be.
Definition crc.h:62
@ CRC16
Use crc16.
Definition crc.h:66
@ CRC4_TI
Use crc4_ti.
Definition crc.h:61
@ CRC16_ITU_T
Use crc16_itu_t.
Definition crc.h:69
@ CRC32_C
Use crc32_c.
Definition crc.h:71
@ CRC16_ANSI
Use crc16_ansi.
Definition crc.h:67
@ CRC32_K_4_2
Use crc32_k_4_2_update.
Definition crc.h:73
@ CRC8
Use crc8.
Definition crc.h:63
@ CRC24_PGP
Use crc24_pgp.
Definition crc.h:70
@ CRC16_CCITT
Use crc16_ccitt.
Definition crc.h:68
@ CRC8_ROHC
Use crc8_rohc.
Definition crc.h:65
@ CRC8_CCITT
Use crc8_ccitt.
Definition crc.h:64
@ CRC32_IEEE
Use crc32_ieee.
Definition crc.h:72
@ CRC4
Use crc4.
Definition crc.h:60
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89