5 BN_new, BN_secure_new, BN_clear, BN_free, BN_clear_free - allocate and free BIGNUMs
9 #include <openssl/bn.h>
13 BIGNUM *BN_secure_new(void);
15 void BN_clear(BIGNUM *a);
17 void BN_free(BIGNUM *a);
19 void BN_clear_free(BIGNUM *a);
23 BN_new() allocates and initializes a B<BIGNUM> structure.
24 BN_secure_new() does the same except that the secure heap
25 OPENSSL_secure_malloc(3) is used to store the value.
27 BN_clear() is used to destroy sensitive data such as keys when they
28 are no longer needed. It erases the memory used by B<a> and sets it
31 BN_free() frees the components of the B<BIGNUM>, and if it was created
32 by BN_new(), also the structure itself. BN_clear_free() additionally
33 overwrites the data before the memory is returned to the system.
34 If B<a> is NULL, nothing is done.
38 BN_new() and BN_secure_new()
39 return a pointer to the B<BIGNUM> initialised to the value 0.
40 If the allocation fails,
41 they return B<NULL> and set an error code that can be obtained
42 by L<ERR_get_error(3)>.
44 BN_clear(), BN_free() and BN_clear_free() have no return values.
52 BN_init() was removed in OpenSSL 1.1.0; use BN_new() instead.
56 Copyright 2000-2017 The OpenSSL Project Authors. All Rights Reserved.
58 Licensed under the OpenSSL license (the "License"). You may not use
59 this file except in compliance with the License. You can obtain a copy
60 in the file LICENSE in the source distribution or at
61 L<https://www.openssl.org/source/license.html>.