Sortix
Sortix Download Manual Development Source Code News Blog More
current nightly

Sortix cross-nightly manual

This manual documents Sortix cross-nightly. You can instead view this document in the latest official manual.

NAME

OPENSSL_init_crypto, OPENSSL_init — initialise the crypto library

SYNOPSIS

#include <openssl/crypto.h>
int
OPENSSL_init_crypto(uint64_t options, const void *dummy);
void
OPENSSL_init(void);

DESCRIPTION

These functions are deprecated. It is never useful for an application program to call either of them explicitly.
The library automatically calls OPENSSL_init_crypto() internally with an options argument of 0 whenever needed. It is safest to assume that any function may do so.
To enable or disable the standard configuration file, instead use OPENSSL_config(3) or OPENSSL_no_config(3), respectively. To load a non-standard configuration file, refer to CONF_modules_load_file(3).
If OPENSSL_init_crypto() is called before any other crypto or ssl functions, the crypto library is initialised by allocating various internal resources, in particular calling ERR_load_crypto_strings(3), OpenSSL_add_all_ciphers(3), and OpenSSL_add_all_digests(3).
The following options are supported:
OPENSSL_INIT_LOAD_CONFIG
At the end of the initialization, call OPENSSL_config(3) with a NULL argument, loading the default configuration file.
OPENSSL_INIT_NO_LOAD_CONFIG
Ignore any later calls to OPENSSL_config(3).
The other options flags defined by OpenSSL are all ignored by LibreSSL. The dummy argument has no effect.
If this function is called more than once, none of the calls except the first one have any effect.
OPENSSL_init() has no effect at all.

RETURN VALUES

OPENSSL_init_crypto() is intended to return 1 on success or 0 on error.

SEE ALSO

CONF_modules_load_file(3), OPENSSL_config(3), OPENSSL_load_builtin_modules(3), openssl.cnf(5)

HISTORY

OPENSSL_init() first appeared in OpenSSL 1.0.0e and has been available since OpenBSD 5.3. It stopped having any effect in OpenSSL 1.1.1 and in OpenBSD 5.6.
OPENSSL_init_crypto() first appeared in OpenSSL 1.1.0 and has been available since OpenBSD 6.3.

BUGS

OPENSSL_init_crypto() silently ignores almost all kinds of errors. In particular, if memory allocation fails, initialisation is likely to remain incomplete, the library may be in an inconsistent internal state, but the return value will usually indicate success anyway. There is no way for the application program to find out whether library initialisation is actually complete, nor to get back to a consistent state if it isn't.
Copyright 2011-2025 Jonas 'Sortie' Termansen and contributors.
Sortix's source code is free software under the ISC license.
#sortix on irc.sortix.org
@sortix_org