2018-05-28 15:22:23 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
|
|
|
*
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
2020-09-14 16:20:40 -07:00
|
|
|
* file, you can obtain one at https://mozilla.org/MPL/2.0/.
|
2018-05-28 15:22:23 +02:00
|
|
|
*
|
|
|
|
* See the COPYRIGHT file distributed with this work for additional
|
|
|
|
* information regarding copyright ownership.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include <isc/lang.h>
|
|
|
|
|
2018-06-06 14:36:33 +02:00
|
|
|
/*! \file isc/entropy_private.h
|
2018-05-28 15:22:23 +02:00
|
|
|
* \brief Implements wrapper around CSPRNG cryptographic library calls
|
|
|
|
* for getting cryptographically secure pseudo-random numbers.
|
|
|
|
*
|
|
|
|
* - If OpenSSL is used, it uses RAND_bytes()
|
|
|
|
* - If PKCS#11 is used, it uses pkcs_C_GenerateRandom()
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
ISC_LANG_BEGINDECLS
|
|
|
|
|
|
|
|
void
|
|
|
|
isc_entropy_get(void *buf, size_t buflen);
|
|
|
|
/*!<
|
|
|
|
* \brief Get cryptographically-secure pseudo-random data.
|
|
|
|
*/
|
|
|
|
|
|
|
|
ISC_LANG_ENDDECLS
|