You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

54 lines
1.8 KiB

  1. /* Copyright (c) 2014, Google Inc.
  2. *
  3. * Permission to use, copy, modify, and/or distribute this software for any
  4. * purpose with or without fee is hereby granted, provided that the above
  5. * copyright notice and this permission notice appear in all copies.
  6. *
  7. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  8. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  9. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
  10. * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  11. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
  12. * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  13. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */
  14. #include <openssl/rand.h>
  15. #if defined(OPENSSL_WINDOWS) && !defined(BORINGSSL_UNSAFE_DETERMINISTIC_MODE)
  16. #include <limits.h>
  17. #include <stdlib.h>
  18. OPENSSL_MSVC_PRAGMA(warning(push, 3))
  19. #include <windows.h>
  20. // #define needed to link in RtlGenRandom(), a.k.a. SystemFunction036. See the
  21. // "Community Additions" comment on MSDN here:
  22. // http://msdn.microsoft.com/en-us/library/windows/desktop/aa387694.aspx
  23. #define SystemFunction036 NTAPI SystemFunction036
  24. #include <ntsecapi.h>
  25. #undef SystemFunction036
  26. OPENSSL_MSVC_PRAGMA(warning(pop))
  27. #include "../fipsmodule/rand/internal.h"
  28. void CRYPTO_sysrand(uint8_t *out, size_t requested) {
  29. while (requested > 0) {
  30. ULONG output_bytes_this_pass = ULONG_MAX;
  31. if (requested < output_bytes_this_pass) {
  32. output_bytes_this_pass = (ULONG)requested;
  33. }
  34. if (RtlGenRandom(out, output_bytes_this_pass) == FALSE) {
  35. abort();
  36. }
  37. requested -= output_bytes_this_pass;
  38. out += output_bytes_this_pass;
  39. }
  40. return;
  41. }
  42. #endif // OPENSSL_WINDOWS && !BORINGSSL_UNSAFE_DETERMINISTIC_MODE