#include "../system.h"
#include <openssl/rand.h>
-#include <openssl/evp.h>
#include <openssl/engine.h>
#include "../crypto.h"
}
void randomize(void *vout, size_t outlen) {
- char *out = vout;
+ uint8_t *out = vout;
while(outlen) {
ssize_t len = read(random_fd, out, outlen);
#include <wincrypt.h>
HCRYPTPROV prov;
-void random_init(void) {
+static void random_init(void) {
if(!CryptAcquireContext(&prov, NULL, NULL, PROV_RSA_FULL, CRYPT_VERIFYCONTEXT)) {
fprintf(stderr, "CryptAcquireContext() failed!\n");
abort();
}
}
-void random_exit(void) {
+static void random_exit(void) {
CryptReleaseContext(prov, 0);
}
void crypto_init(void) {
random_init();
+#if OPENSSL_VERSION_MAJOR < 3
ENGINE_load_builtin_engines();
- ENGINE_register_all_complete();
-#if OPENSSL_API_COMPAT < 0x10100000L
- ERR_load_crypto_strings();
- OpenSSL_add_all_algorithms();
#endif
if(!RAND_status()) {
}
void crypto_exit(void) {
-#if OPENSSL_API_COMPAT < 0x10100000L
- EVP_cleanup();
- ERR_free_strings();
- ENGINE_cleanup();
-#endif
random_exit();
}