| =pod |
| |
| =head1 NAME |
| |
| RAND_DRBG_set_ex_data, |
| RAND_DRBG_get_ex_data, |
| RAND_DRBG_get_ex_new_index |
| - store and retrieve extra data from the DRBG instance |
| |
| =head1 SYNOPSIS |
| |
| #include <openssl/rand_drbg.h> |
| |
| int RAND_DRBG_set_ex_data(RAND_DRBG *drbg, int idx, void *data); |
| |
| void *RAND_DRBG_get_ex_data(const RAND_DRBG *drbg, int idx); |
| |
| int RAND_DRBG_get_ex_new_index(long argl, void *argp, |
| CRYPTO_EX_new *new_func, |
| CRYPTO_EX_dup *dup_func, |
| CRYPTO_EX_free *free_func); |
| |
| |
| |
| =head1 DESCRIPTION |
| |
| RAND_DRBG_set_ex_data() enables an application to store arbitrary application |
| specific data B<data> in a RAND_DRBG instance B<drbg>. The index B<idx> should |
| be a value previously returned from a call to RAND_DRBG_get_ex_new_index(). |
| |
| RAND_DRBG_get_ex_data() retrieves application specific data previously stored |
| in an RAND_DRBG instance B<drbg>. The B<idx> value should be the same as that |
| used when originally storing the data. |
| |
| For more detailed information see L<CRYPTO_get_ex_data(3)> and |
| L<CRYPTO_set_ex_data(3)> which implement these functions and |
| L<CRYPTO_get_ex_new_index(3)> for generating a unique index. |
| |
| =head1 RETURN VALUES |
| |
| RAND_DRBG_set_ex_data() returns 1 for success or 0 for failure. |
| |
| RAND_DRBG_get_ex_data() returns the previously stored value or NULL on |
| failure. NULL may also be a valid value. |
| |
| |
| =head1 NOTES |
| |
| RAND_DRBG_get_ex_new_index(...) is implemented as a macro and equivalent to |
| CRYPTO_get_ex_new_index(CRYPTO_EX_INDEX_DRBG,...). |
| |
| =head1 SEE ALSO |
| |
| L<CRYPTO_get_ex_data(3)>, |
| L<CRYPTO_set_ex_data(3)>, |
| L<CRYPTO_get_ex_new_index(3)>, |
| L<RAND_DRBG(7)> |
| |
| =head1 COPYRIGHT |
| |
| Copyright 2017-2018 The OpenSSL Project Authors. All Rights Reserved. |
| |
| Licensed under the OpenSSL license (the "License"). You may not use |
| this file except in compliance with the License. You can obtain a copy |
| in the file LICENSE in the source distribution or at |
| L<https://www.openssl.org/source/license.html>. |
| |
| =cut |