2022-01-27 10:11:25 +01:00
|
|
|
//
|
|
|
|
// FILE: Fletcher16.cpp
|
2022-09-13 16:31:43 +02:00
|
|
|
// AUTHOR: Rob Tillaart, Daniel Mohr
|
2022-01-27 10:11:25 +01:00
|
|
|
// PURPOSE: Arduino class for Fletcher16
|
|
|
|
// URL: https://github.com/RobTillaart/Fletcher
|
|
|
|
|
|
|
|
|
|
|
|
#include "Fletcher16.h"
|
|
|
|
|
2023-01-17 19:28:45 +01:00
|
|
|
// UINT8_MAX = 255 = ((((uint16_t) 1) << 8) - 1)
|
|
|
|
#define FLETCHER_16 UINT8_MAX
|
2022-01-27 10:11:25 +01:00
|
|
|
|
|
|
|
|
|
|
|
Fletcher16::Fletcher16()
|
|
|
|
{
|
|
|
|
begin();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Fletcher16::begin(uint8_t s1, uint8_t s2)
|
|
|
|
{
|
2022-09-13 16:31:43 +02:00
|
|
|
_s1 = (s1 == FLETCHER_16) ? 0 : s1;
|
|
|
|
_s2 = (s2 == FLETCHER_16) ? 0 : s2;
|
2022-01-27 10:11:25 +01:00
|
|
|
_count = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Fletcher16::add(uint8_t value)
|
|
|
|
{
|
|
|
|
_count++;
|
2022-09-13 16:31:43 +02:00
|
|
|
#if defined(ARDUINO_ARCH_AVR)
|
|
|
|
uint8_t t = 0xFF - value;
|
|
|
|
if (t >= _s1) _s1 += value;
|
|
|
|
else _s1 = _s1 + value + 1;
|
|
|
|
|
|
|
|
t = 0xFF - _s1;
|
|
|
|
if (t >= _s2) _s2 += _s1;
|
|
|
|
else _s2 = _s2 + _s1 + 1;
|
|
|
|
|
|
|
|
#elif defined(ARDUINO_ARCH_SAMD) || defined(ESP32) || defined(ESP8266)
|
|
|
|
_s1 += value;
|
|
|
|
_s1 = (_s1 & FLETCHER_16) + (_s1 >> 8);
|
|
|
|
_s2 += _s1;
|
|
|
|
_s2 = (_s2 & FLETCHER_16) + (_s2 >> 8);
|
|
|
|
|
|
|
|
#else
|
|
|
|
// REFERENCE
|
2022-01-27 10:11:25 +01:00
|
|
|
_s1 += value;
|
2022-09-13 16:31:43 +02:00
|
|
|
if (_s1 >= FLETCHER_16) _s1 -= FLETCHER_16;
|
2022-01-27 10:11:25 +01:00
|
|
|
_s2 += _s1;
|
2022-09-13 16:31:43 +02:00
|
|
|
if (_s2 >= FLETCHER_16) _s2 -= FLETCHER_16;
|
|
|
|
#endif
|
2022-01-27 10:11:25 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Fletcher16::add(const uint8_t * array, uint16_t length)
|
|
|
|
{
|
|
|
|
while (length--)
|
|
|
|
{
|
|
|
|
add(*array++);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-09-13 16:31:43 +02:00
|
|
|
uint16_t Fletcher16::getFletcher()
|
|
|
|
{
|
|
|
|
if (_s1 >= FLETCHER_16) _s1 -= FLETCHER_16;
|
|
|
|
if (_s2 >= FLETCHER_16) _s2 -= FLETCHER_16;
|
|
|
|
return (((uint16_t)_s2) << 8) | _s1;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
uint32_t Fletcher16::count()
|
|
|
|
{
|
|
|
|
return _count;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2023-01-17 19:28:45 +01:00
|
|
|
// -- END OF FILE --
|
2022-01-27 10:11:25 +01:00
|
|
|
|