7f6524949a
As described in #42403, there was an issue with the existing crc16_ansi() implementation, since it was not calculating the CRC-16-ANSI (aka CRC-16-MODBUS). This is because the existing crc16() function only supported non-reflected input and output (and the CRC-16-ANSI requires reflection on both) and also it did not seem to support correctly inial seeds different from 0x0000 (and, again, the CRC-16-ANSI requires 0xffff as an initial seed). This commit replaces the existing crc16() with a functional pair, crc16() and crc16_reflect(), that also work with any poly, any initial seed and allow to select whether reflection is performed. It also adapts crc16_ansi() so that it actually returns the correct CRC. Fixes #42403. Signed-off-by: Carles Cufi <carles.cufi@nordicsemi.no> |
||
---|---|---|
.. | ||
base64 | ||
cbprintf | ||
crc | ||
intmath | ||
list | ||
math_extras | ||
net_timeout | ||
rbtree | ||
timeutil | ||
util | ||
winstream |