OPENSSL_ADD_ALL_ALGORITHMS(3)OpenSSLOPENSSL_ADD_ALL_ALGORITHMS(3)
OpenSSL_add_all_algorithms, OpenSSL_add_all_ciphers,
OpenSSL_add_all_digests - add algorithms to internal table
#include <openssl/evp.h>
void OpenSSL_add_all_algorithms(void);
void OpenSSL_add_all_ciphers(void);
void OpenSSL_add_all_digests(void);
void EVP_cleanup(void);
OpenSSL keeps an internal table of digest algorithms and
ciphers. It uses this table to lookup ciphers via functions
such as EVP_get_cipher_byname().
OpenSSL_add_all_digests() adds all digest algorithms to the
table.
OpenSSL_add_all_algorithms() adds all algorithms to the
table (digests and ciphers).
OpenSSL_add_all_ciphers() adds all encryption algorithms to
the table including password based encryption algorithms.
EVP_cleanup() removes all ciphers and digests from the
table.
None of the functions return a value.
A typical application will call OpenSSL_add_all_algorithms()
initially and EVP_cleanup() before exiting.
An application does not need to add algorithms to use them
explicitly, for example by EVP_sha1(). It just needs to add
them if it (or any of the functions it calls) needs to
lookup algorithms.
The cipher and digest lookup functions are used in many
parts of the library. If the table is not initialized
several functions will misbehave and complain they cannot
find algorithms. This includes the PEM, PKCS#12, SSL and
S/MIME libraries. This is a common query in the OpenSSL
mailing lists.
Calling OpenSSL_add_all_algorithms() links in all algo-
rithms: as a result a statically linked executable can be
quite large. If this is important it is possible to just add
MirOS BSD #10-current 2005-02-05 1
OPENSSL_ADD_ALL_ALGORITHMS(3)OpenSSLOPENSSL_ADD_ALL_ALGORITHMS(3)
the required ciphers and digests.
Although the functions do not return error codes it is pos-
sible for them to fail. This will only happen as a result of
a memory allocation failure so this is not too much of a
problem in practice.
evp(3), EVP_DigestInit(3), EVP_EncryptInit(3)
MirOS BSD #10-current 2005-02-05 2
Generated on 2012-02-20 02:47:02 by $MirOS: src/scripts/roff2htm,v 1.70 2011/12/03 18:21:12 tg Exp $
These manual pages and other documentation are copyrighted by their respective writers;
their source is available at our CVSweb,
AnonCVS, and other mirrors. The rest is Copyright © 2002‒2011 The MirOS Project, Germany.
This product includes material
provided by Thorsten Glaser.
This manual page’s HTML representation is supposed to be valid XHTML/1.1; if not, please send a bug report – diffs preferred.