crn_checksum.cpp 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. // File: crn_checksum.cpp
  2. #include "crn_core.h"
  3. namespace crnlib
  4. {
  5. // From the public domain stb.h header.
  6. uint adler32(const void* pBuf, size_t buflen, uint adler32)
  7. {
  8. const uint8* buffer = static_cast<const uint8*>(pBuf);
  9. const unsigned long ADLER_MOD = 65521;
  10. unsigned long s1 = adler32 & 0xffff, s2 = adler32 >> 16;
  11. size_t blocklen;
  12. unsigned long i;
  13. blocklen = buflen % 5552;
  14. while (buflen) {
  15. for (i=0; i + 7 < blocklen; i += 8) {
  16. s1 += buffer[0], s2 += s1;
  17. s1 += buffer[1], s2 += s1;
  18. s1 += buffer[2], s2 += s1;
  19. s1 += buffer[3], s2 += s1;
  20. s1 += buffer[4], s2 += s1;
  21. s1 += buffer[5], s2 += s1;
  22. s1 += buffer[6], s2 += s1;
  23. s1 += buffer[7], s2 += s1;
  24. buffer += 8;
  25. }
  26. for (; i < blocklen; ++i)
  27. s1 += *buffer++, s2 += s1;
  28. s1 %= ADLER_MOD, s2 %= ADLER_MOD;
  29. buflen -= blocklen;
  30. blocklen = 5552;
  31. }
  32. return (s2 << 16) + s1;
  33. }
  34. uint16 crc16(const void* pBuf, size_t len, uint16 crc)
  35. {
  36. crc = ~crc;
  37. const uint8* p = reinterpret_cast<const uint8*>(pBuf);
  38. while (len)
  39. {
  40. const uint16 q = *p++ ^ (crc >> 8);
  41. crc <<= 8U;
  42. uint16 r = (q >> 4) ^ q;
  43. crc ^= r;
  44. r <<= 5U;
  45. crc ^= r;
  46. r <<= 7U;
  47. crc ^= r;
  48. len--;
  49. }
  50. return static_cast<uint16>(~crc);
  51. }
  52. } // namespace crnlib