23 #elif defined(__linux__) || defined(__APPLE__) || defined(__FreeBSD__)
24 #include <sys/random.h>
25 #elif defined(__OpenBSD__)
28 #error "Couldn't identify the OS"
39 NTSTATUS res = BCryptGenRandom(NULL, data, size, BCRYPT_USE_SYSTEM_PREFERRED_RNG);
40 if (res != STATUS_SUCCESS || size > ULONG_MAX) {
45 #elif defined(__linux__) || defined(__FreeBSD__)
47 ssize_t res = getrandom(data, size, 0);
48 if (res < 0 || (
size_t)res != size ) {
53 #elif defined(__APPLE__) || defined(__OpenBSD__)
56 int res = getentropy(data, size);
66 static void print_hex(
unsigned char* data,
size_t size) {
69 for (i = 0; i < size; i++) {
83 SecureZeroMemory(ptr, len);
84 #elif defined(__GNUC__)
97 __asm__ __volatile__(
"" : :
"r"(ptr) :
"memory");
99 void *(*
volatile const volatile_memset)(
void *,
int,
size_t) = memset;
100 volatile_memset(ptr, 0, len);
static int fill_random(unsigned char *data, size_t size)
static void print_hex(unsigned char *data, size_t size)
static SECP256K1_INLINE void secure_erase(void *ptr, size_t len)