| * Copyright (c) 2017 Intel Corporation. |
| * SPDX-License-Identifier: Apache-2.0 |
| uint16_t crc16(const uint8_t *src, size_t len, uint16_t polynomial, |
| uint16_t initial_value, bool pad) |
| uint16_t crc = initial_value; |
| size_t padding = pad ? sizeof(crc) : 0; |
| /* src length + padding (if required) */ |
| for (i = 0; i < len + padding; i++) { |
| for (b = 0; b < 8; b++) { |
| uint16_t divide = crc & 0x8000UL; |
| /* choose input bytes or implicit trailing zeros */ |
| crc |= !!(src[i] & (0x80U >> b)); |
| uint16_t crc16_ccitt(uint16_t seed, const uint8_t *src, size_t len) |
| seed = (seed >> 8) ^ ((uint16_t)f << 8) ^ ((uint16_t)f << 3) ^ ((uint16_t)f >> 4); |
| uint16_t crc16_itu_t(uint16_t seed, const uint8_t *src, size_t len) |
| seed = (seed >> 8U) | (seed << 8U); |
| seed ^= (seed & 0xffU) >> 4U; |
| seed ^= (seed & 0xffU) << 5U; |