hash_drbg.h 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * Copyright 2014-2022 The GmSSL Project. All Rights Reserved.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the License); you may
  5. * not use this file except in compliance with the License.
  6. *
  7. * http://www.apache.org/licenses/LICENSE-2.0
  8. */
  9. /* NIST SP800-90A Rev.1 "Recommendation for Random Number Generation
  10. * Using Deterministic Random Bit Generators", 10.1.1 Hash_DRBG */
  11. #ifndef GMSSL_HASH_DRBG_H
  12. #define GMSSL_HASH_DRBG_H
  13. #include <stdint.h>
  14. #include <stdlib.h>
  15. #include <gmssl/digest.h>
  16. /* seedlen for hash_drgb, table 2 of nist sp 800-90a rev.1 */
  17. #define HASH_DRBG_SM3_SEED_BITS 440 /* 55 bytes */
  18. #define HASH_DRBG_SHA1_SEED_BITS 440
  19. #define HASH_DRBG_SHA224_SEED_BITS 440
  20. #define HASH_DRBG_SHA512_224_SEED_BITS 440
  21. #define HASH_DRBG_SHA256_SEED_BITS 440
  22. #define HASH_DRBG_SHA512_256_SEED_BITS 440
  23. #define HASH_DRBG_SHA384_SEED_BITS 888 /* 110 bytes */
  24. #define HASH_DRBG_SHA512_SEED_BITS 888
  25. #define HASH_DRBG_MAX_SEED_BITS 888
  26. #define HASH_DRBG_SM3_SEED_SIZE (HASH_DRBG_SM3_SEED_BITS/8)
  27. #define HASH_DRBG_SHA1_SEED_SIZE (HASH_DRBG_SHA1_SEED_BITS/8)
  28. #define HASH_DRBG_SHA224_SEED_SIZE (HASH_DRBG_SHA224_SEED_BITS/8)
  29. #define HASH_DRBG_SHA512_224_SEED_SIZE (HASH_DRBG_SHA512_224_SEED_BITS/8)
  30. #define HASH_DRBG_SHA256_SEED_SIZE (HASH_DRBG_SHA256_SEED_BITS/8)
  31. #define HASH_DRBG_SHA512_256_SEED_SIZE (HASH_DRBG_SHA512_256_SEED_BITS/8)
  32. #define HASH_DRBG_SHA384_SEED_SIZE (HASH_DRBG_SHA384_SEED_BITS/8)
  33. #define HASH_DRBG_SHA512_SEED_SIZE (HASH_DRBG_SHA512_SEED_BITS/8)
  34. #define HASH_DRBG_MAX_SEED_SIZE (HASH_DRBG_MAX_SEED_BITS/8)
  35. #define HASH_DRBG_RESEED_INTERVAL ((uint64_t)1 << 48)
  36. #ifdef __cplusplus
  37. extern "C" {
  38. #endif
  39. typedef struct {
  40. const DIGEST *digest;
  41. uint8_t V[HASH_DRBG_MAX_SEED_SIZE];
  42. uint8_t C[HASH_DRBG_MAX_SEED_SIZE];
  43. size_t seedlen;
  44. uint64_t reseed_counter;
  45. } HASH_DRBG;
  46. int hash_drbg_init(HASH_DRBG *drbg,
  47. const DIGEST *digest,
  48. const uint8_t *entropy, size_t entropy_len,
  49. const uint8_t *nonce, size_t nonce_len,
  50. const uint8_t *personalstr, size_t personalstr_len);
  51. int hash_drbg_reseed(HASH_DRBG *drbg,
  52. const uint8_t *entropy, size_t entropy_len,
  53. const uint8_t *additional, size_t additional_len);
  54. int hash_drbg_generate(HASH_DRBG *drbg,
  55. const uint8_t *additional, size_t additional_len,
  56. size_t outlen, uint8_t *out);
  57. #ifdef __cplusplus
  58. }
  59. #endif
  60. #endif