fp@1126: /***************************************************************************** fp@1126: * fp@1126: * $Id$ fp@1126: * fp@1126: ****************************************************************************/ fp@1126: fp@1126: #include "sii_crc.h" fp@1126: fp@1126: /*****************************************************************************/ fp@1126: fp@1126: /** Calculates the SII checksum field. fp@1126: * fp@1126: * The checksum is generated with the polynom x^8+x^2+x+1 (0x07) and an fp@1126: * initial value of 0xff (see IEC 61158-6-12 ch. 5.4). fp@1126: * fp@1126: * The below code was originally generated with PYCRC fp@1126: * http://www.tty1.net/pycrc fp@1126: * fp@1126: * ./pycrc.py --width=8 --poly=0x07 --reflect-in=0 --xor-in=0xff fp@1126: * --reflect-out=0 --xor-out=0 --generate c --algorithm=bit-by-bit fp@1126: * fp@1126: * \return CRC8 fp@1126: */ fp@1126: uint8_t calcSiiCrc( fp@1126: const uint8_t *data, /**< pointer to data */ fp@1126: size_t length /**< number of bytes in \a data */ fp@1126: ) fp@1126: { fp@1126: unsigned int i; fp@1126: uint8_t bit, byte, crc = 0x48; fp@1126: fp@1126: while (length--) { fp@1126: byte = *data++; fp@1126: for (i = 0; i < 8; i++) { fp@1126: bit = crc & 0x80; fp@1126: crc = (crc << 1) | ((byte >> (7 - i)) & 0x01); fp@1126: if (bit) crc ^= 0x07; fp@1126: } fp@1126: } fp@1126: fp@1126: for (i = 0; i < 8; i++) { fp@1126: bit = crc & 0x80; fp@1126: crc <<= 1; fp@1126: if (bit) crc ^= 0x07; fp@1126: } fp@1126: fp@1126: return crc; fp@1126: } fp@1126: fp@1126: /*****************************************************************************/