libressl-OPENSSL_init_crypto - initialise the crypto library


OPENSSL_INIT_CRYPTO(3) Library Functions Manual OPENSSL_INIT_CRYPTO(3)

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. GNU May 24, 2020 OPENSSL_INIT_CRYPTO(3)


Updated 2024-01-29 - jenkler.se | uex.se