crc.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. // Copyright (C) 2020 Michael McMaster <michael@codesrc.com>
  2. //
  3. // This file is part of SCSI2SD.
  4. //
  5. // SCSI2SD is free software: you can redistribute it and/or modify
  6. // it under the terms of the GNU General Public License as published by
  7. // the Free Software Foundation, either version 3 of the License, or
  8. // (at your option) any later version.
  9. //
  10. // SCSI2SD is distributed in the hope that it will be useful,
  11. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. // GNU General Public License for more details.
  14. //
  15. // You should have received a copy of the GNU General Public License
  16. // along with SCSI2SD. If not, see <http://www.gnu.org/licenses/>.
  17. #include "crc.h"
  18. // Use standard CRC-32 reversed poly
  19. #define POLYNOMIAL 0xEDB88320
  20. // Slow (but small) implementation that doesn't use lookup tables.
  21. uint32_t s2s_crc32(uint8_t* data, int len)
  22. {
  23. uint32_t crc = 0xFFFFFFFF;
  24. for (int i = 0; i < len; ++i)
  25. {
  26. uint32_t byte = data[i];
  27. crc = crc ^ byte;
  28. for (int j = 7; j >= 0; j--)
  29. {
  30. uint32_t mask = -(crc & 1);
  31. crc = (crc >> 1) ^ (POLYNOMIAL & mask);
  32. }
  33. }
  34. return ~crc;
  35. }