BN_CTX_new,
BN_CTX_free — allocate and
free BN_CTX structures
#include
<openssl/bn.h>
BN_CTX *
BN_CTX_new(void);
void
BN_CTX_free(BN_CTX *c);
A BN_CTX is a structure that holds
BIGNUM temporary variables used by library functions.
Since dynamic memory allocation to create BIGNUMs is
rather expensive when used in conjunction with repeated subroutine calls,
the BN_CTX structure is used.
BN_CTX_new()
allocates and initializes a BN_CTX structure.
BN_CTX_free()
frees the components of the BN_CTX and, if it was
created by BN_CTX_new(), also the structure itself.
If
BN_CTX_start(3)
has been used on the BN_CTX,
BN_CTX_end(3)
must be called before the BN_CTX may be freed by
BN_CTX_free(). If c is a
NULL pointer, no action occurs.
BN_CTX_new() returns a pointer to the
BN_CTX. If the allocation fails, it returns
NULL and sets an error code that can be obtained by
ERR_get_error(3).
BN_CTX_new() and
BN_CTX_free() first appeared in SSLeay 0.5.1 and
have been available since OpenBSD 2.4.