Blame winpr/libwinpr/crypto/rand.c

Packit Service fa4841
/**
Packit Service fa4841
 * WinPR: Windows Portable Runtime
Packit Service fa4841
 *
Packit Service fa4841
 * Copyright 2015 Marc-Andre Moreau <marcandre.moreau@gmail.com>
Packit Service fa4841
 *
Packit Service fa4841
 * Licensed under the Apache License, Version 2.0 (the "License");
Packit Service fa4841
 * you may not use this file except in compliance with the License.
Packit Service fa4841
 * You may obtain a copy of the License at
Packit Service fa4841
 *
Packit Service fa4841
 *     http://www.apache.org/licenses/LICENSE-2.0
Packit Service fa4841
 *
Packit Service fa4841
 * Unless required by applicable law or agreed to in writing, software
Packit Service fa4841
 * distributed under the License is distributed on an "AS IS" BASIS,
Packit Service fa4841
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
Packit Service fa4841
 * See the License for the specific language governing permissions and
Packit Service fa4841
 * limitations under the License.
Packit Service fa4841
 */
Packit Service fa4841
Packit Service fa4841
#ifdef HAVE_CONFIG_H
Packit Service fa4841
#include "config.h"
Packit Service fa4841
#endif
Packit Service fa4841
Packit Service fa4841
#include <winpr/crt.h>
Packit Service fa4841
Packit Service fa4841
#include <winpr/crypto.h>
Packit Service fa4841
Packit Service fa4841
#ifdef WITH_OPENSSL
Packit Service fa4841
#include <openssl/crypto.h>
Packit Service fa4841
#include <openssl/rand.h>
Packit Service fa4841
#endif
Packit Service fa4841
Packit Service fa4841
#ifdef WITH_MBEDTLS
Packit Service fa4841
#include <mbedtls/md.h>
Packit Service fa4841
#include <mbedtls/entropy.h>
Packit Service fa4841
#include <mbedtls/havege.h>
Packit Service fa4841
#include <mbedtls/hmac_drbg.h>
Packit Service fa4841
#endif
Packit Service fa4841
Packit Service fa4841
int winpr_RAND(BYTE* output, size_t len)
Packit Service fa4841
{
Packit Service fa4841
#if defined(WITH_OPENSSL)
Packit Service fa4841
	if (RAND_bytes(output, len) != 1)
Packit Service fa4841
		return -1;
Packit Service fa4841
#elif defined(WITH_MBEDTLS) && defined(MBEDTLS_HAVEGE_C)
Packit Service fa4841
	mbedtls_havege_state hs;
Packit Service fa4841
	mbedtls_havege_init(&hs);
Packit Service fa4841
Packit Service fa4841
	if (mbedtls_havege_random(&hs, output, len) != 0)
Packit Service fa4841
		return -1;
Packit Service fa4841
Packit Service fa4841
	mbedtls_havege_free(&hs);
Packit Service fa4841
#endif
Packit Service fa4841
	return 0;
Packit Service fa4841
}
Packit Service fa4841
Packit Service fa4841
int winpr_RAND_pseudo(BYTE* output, size_t len)
Packit Service fa4841
{
Packit Service fa4841
	return winpr_RAND(output, len);
Packit Service fa4841
}