streebog.h 949 B

12345678910111213141516171819202122232425262728293031323334353637
  1. /* SPDX-License-Identifier: GPL-2.0+ OR BSD-2-Clause */
  2. /*
  3. * Copyright (c) 2013 Alexey Degtyarev <[email protected]>
  4. * Copyright (c) 2018 Vitaly Chikunov <[email protected]>
  5. *
  6. * This program is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU General Public License as published by the Free
  8. * Software Foundation; either version 2 of the License, or (at your option)
  9. * any later version.
  10. */
  11. #ifndef _CRYPTO_STREEBOG_H_
  12. #define _CRYPTO_STREEBOG_H_
  13. #include <linux/types.h>
  14. #define STREEBOG256_DIGEST_SIZE 32
  15. #define STREEBOG512_DIGEST_SIZE 64
  16. #define STREEBOG_BLOCK_SIZE 64
  17. struct streebog_uint512 {
  18. __le64 qword[8];
  19. };
  20. struct streebog_state {
  21. union {
  22. u8 buffer[STREEBOG_BLOCK_SIZE];
  23. struct streebog_uint512 m;
  24. };
  25. struct streebog_uint512 hash;
  26. struct streebog_uint512 h;
  27. struct streebog_uint512 N;
  28. struct streebog_uint512 Sigma;
  29. size_t fillsize;
  30. };
  31. #endif /* !_CRYPTO_STREEBOG_H_ */