CRC32.cpp 901 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. * Copyright (c) 2020-2022, the SerenityOS developers.
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <AK/Array.h>
  7. #include <AK/Span.h>
  8. #include <AK/Types.h>
  9. #include <LibCrypto/Checksum/CRC32.h>
  10. namespace Crypto::Checksum {
  11. static constexpr auto generate_table()
  12. {
  13. Array<u32, 256> data {};
  14. for (auto i = 0u; i < data.size(); i++) {
  15. u32 value = i;
  16. for (auto j = 0; j < 8; j++) {
  17. if (value & 1) {
  18. value = 0xEDB88320 ^ (value >> 1);
  19. } else {
  20. value = value >> 1;
  21. }
  22. }
  23. data[i] = value;
  24. }
  25. return data;
  26. }
  27. static constexpr auto table = generate_table();
  28. void CRC32::update(ReadonlyBytes data)
  29. {
  30. for (size_t i = 0; i < data.size(); i++) {
  31. m_state = table[(m_state ^ data.at(i)) & 0xFF] ^ (m_state >> 8);
  32. }
  33. };
  34. u32 CRC32::digest()
  35. {
  36. return ~m_state;
  37. }
  38. }