sha512.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /* sha512.h
  2. *
  3. * Copyright (C) 2006-2011 Sawtooth Consulting Ltd.
  4. *
  5. * This file is part of CyaSSL.
  6. *
  7. * CyaSSL is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * CyaSSL is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
  20. */
  21. #ifdef CYASSL_SHA512
  22. #ifndef CTAO_CRYPT_SHA512_H
  23. #define CTAO_CRYPT_SHA512_H
  24. #include "types.h"
  25. #ifdef __cplusplus
  26. extern "C" {
  27. #endif
  28. /* in bytes */
  29. enum {
  30. SHA512 = 4, /* hash type unique */
  31. SHA512_BLOCK_SIZE = 128,
  32. SHA512_DIGEST_SIZE = 64,
  33. SHA512_PAD_SIZE = 112
  34. };
  35. /* Sha512 digest */
  36. typedef struct Sha512 {
  37. word32 buffLen; /* in bytes */
  38. word32 loLen; /* length in bytes */
  39. word32 hiLen; /* length in bytes */
  40. word64 digest[SHA512_DIGEST_SIZE / sizeof(word64)];
  41. word64 buffer[SHA512_BLOCK_SIZE / sizeof(word64)];
  42. } Sha512;
  43. void InitSha512(Sha512*);
  44. void Sha512Update(Sha512*, const byte*, word32);
  45. void Sha512Final(Sha512*, byte*);
  46. #ifdef __cplusplus
  47. } /* extern "C" */
  48. #endif
  49. #endif /* CTAO_CRYPT_SHA512_H */
  50. #endif /* CYASSL_SHA512 */