2
0

fips_rand_lib.c 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. /* ====================================================================
  2. * Copyright (c) 2011 The OpenSSL Project. All rights reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. *
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. *
  11. * 2. Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in
  13. * the documentation and/or other materials provided with the
  14. * distribution.
  15. *
  16. * 3. All advertising materials mentioning features or use of this
  17. * software must display the following acknowledgment:
  18. * "This product includes software developed by the OpenSSL Project
  19. * for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
  20. *
  21. * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
  22. * endorse or promote products derived from this software without
  23. * prior written permission. For written permission, please contact
  24. * openssl-core@openssl.org.
  25. *
  26. * 5. Products derived from this software may not be called "OpenSSL"
  27. * nor may "OpenSSL" appear in their names without prior written
  28. * permission of the OpenSSL Project.
  29. *
  30. * 6. Redistributions of any form whatsoever must retain the following
  31. * acknowledgment:
  32. * "This product includes software developed by the OpenSSL Project
  33. * for use in the OpenSSL Toolkit (http://www.openssl.org/)"
  34. *
  35. * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
  36. * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  37. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  38. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
  39. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  40. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  41. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  42. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  43. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  44. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  45. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
  46. * OF THE POSSIBILITY OF SUCH DAMAGE.
  47. *
  48. */
  49. #define OPENSSL_FIPSAPI
  50. #include <openssl/crypto.h>
  51. #include <openssl/rand.h>
  52. #include <openssl/err.h>
  53. #include <openssl/fips.h>
  54. #include <openssl/fips_rand.h>
  55. #include "e_os.h"
  56. /* FIPS API for PRNG use. Similar to RAND functionality but without
  57. * ENGINE and additional checking for non-FIPS rand methods.
  58. */
  59. static const RAND_METHOD *fips_rand_meth = NULL;
  60. static int fips_approved_rand_meth = 0;
  61. int FIPS_rand_set_method(const RAND_METHOD *meth)
  62. {
  63. if (meth == FIPS_drbg_method())
  64. fips_approved_rand_meth = 1;
  65. else if (meth == FIPS_x931_method())
  66. fips_approved_rand_meth = 2;
  67. else
  68. fips_approved_rand_meth = 0;
  69. if (!fips_approved_rand_meth && FIPS_mode())
  70. {
  71. FIPSerr(FIPS_F_FIPS_RAND_SET_METHOD, FIPS_R_NON_FIPS_METHOD);
  72. return 0;
  73. }
  74. fips_rand_meth = meth;
  75. return 1;
  76. }
  77. void FIPS_rand_seed(const void *buf, int num)
  78. {
  79. if (!fips_approved_rand_meth && FIPS_mode())
  80. {
  81. FIPSerr(FIPS_F_FIPS_RAND_SEED, FIPS_R_NON_FIPS_METHOD);
  82. return;
  83. }
  84. if (fips_rand_meth && fips_rand_meth->seed)
  85. fips_rand_meth->seed(buf,num);
  86. }
  87. void FIPS_rand_add(const void *buf, int num, double entropy)
  88. {
  89. if (!fips_approved_rand_meth && FIPS_mode())
  90. {
  91. FIPSerr(FIPS_F_FIPS_RAND_ADD, FIPS_R_NON_FIPS_METHOD);
  92. return;
  93. }
  94. if (fips_rand_meth && fips_rand_meth->add)
  95. fips_rand_meth->add(buf,num,entropy);
  96. }
  97. int FIPS_rand_bytes(unsigned char *buf, int num)
  98. {
  99. if (!fips_approved_rand_meth && FIPS_mode())
  100. {
  101. FIPSerr(FIPS_F_FIPS_RAND_BYTES, FIPS_R_NON_FIPS_METHOD);
  102. return 0;
  103. }
  104. if (fips_rand_meth && fips_rand_meth->bytes)
  105. return fips_rand_meth->bytes(buf,num);
  106. return 0;
  107. }
  108. int FIPS_rand_pseudo_bytes(unsigned char *buf, int num)
  109. {
  110. if (!fips_approved_rand_meth && FIPS_mode())
  111. {
  112. FIPSerr(FIPS_F_FIPS_RAND_PSEUDO_BYTES, FIPS_R_NON_FIPS_METHOD);
  113. return 0;
  114. }
  115. if (fips_rand_meth && fips_rand_meth->pseudorand)
  116. return fips_rand_meth->pseudorand(buf,num);
  117. return -1;
  118. }
  119. int FIPS_rand_status(void)
  120. {
  121. if (!fips_approved_rand_meth && FIPS_mode())
  122. {
  123. FIPSerr(FIPS_F_FIPS_RAND_STATUS, FIPS_R_NON_FIPS_METHOD);
  124. return 0;
  125. }
  126. if (fips_rand_meth && fips_rand_meth->status)
  127. return fips_rand_meth->status();
  128. return 0;
  129. }
  130. /* Return instantiated strength of PRNG. For DRBG this is an internal
  131. * parameter. For X9.31 PRNG it is 80 bits (from SP800-131). Any other
  132. * type of PRNG is not approved and returns 0 in FIPS mode and maximum
  133. * 256 outside FIPS mode.
  134. */
  135. int FIPS_rand_strength(void)
  136. {
  137. if (fips_approved_rand_meth == 1)
  138. return FIPS_drbg_get_strength(FIPS_get_default_drbg());
  139. else if (fips_approved_rand_meth == 2)
  140. return 80;
  141. else if (fips_approved_rand_meth == 0)
  142. {
  143. if (FIPS_mode())
  144. return 0;
  145. else
  146. return 256;
  147. }
  148. return 0;
  149. }