1*8fb009dcSAndroid Build Coastguard Worker /* Copyright (C) 1995-1998 Eric Young ([email protected]) 2*8fb009dcSAndroid Build Coastguard Worker * All rights reserved. 3*8fb009dcSAndroid Build Coastguard Worker * 4*8fb009dcSAndroid Build Coastguard Worker * This package is an SSL implementation written 5*8fb009dcSAndroid Build Coastguard Worker * by Eric Young ([email protected]). 6*8fb009dcSAndroid Build Coastguard Worker * The implementation was written so as to conform with Netscapes SSL. 7*8fb009dcSAndroid Build Coastguard Worker * 8*8fb009dcSAndroid Build Coastguard Worker * This library is free for commercial and non-commercial use as long as 9*8fb009dcSAndroid Build Coastguard Worker * the following conditions are aheared to. The following conditions 10*8fb009dcSAndroid Build Coastguard Worker * apply to all code found in this distribution, be it the RC4, RSA, 11*8fb009dcSAndroid Build Coastguard Worker * lhash, DES, etc., code; not just the SSL code. The SSL documentation 12*8fb009dcSAndroid Build Coastguard Worker * included with this distribution is covered by the same copyright terms 13*8fb009dcSAndroid Build Coastguard Worker * except that the holder is Tim Hudson ([email protected]). 14*8fb009dcSAndroid Build Coastguard Worker * 15*8fb009dcSAndroid Build Coastguard Worker * Copyright remains Eric Young's, and as such any Copyright notices in 16*8fb009dcSAndroid Build Coastguard Worker * the code are not to be removed. 17*8fb009dcSAndroid Build Coastguard Worker * If this package is used in a product, Eric Young should be given attribution 18*8fb009dcSAndroid Build Coastguard Worker * as the author of the parts of the library used. 19*8fb009dcSAndroid Build Coastguard Worker * This can be in the form of a textual message at program startup or 20*8fb009dcSAndroid Build Coastguard Worker * in documentation (online or textual) provided with the package. 21*8fb009dcSAndroid Build Coastguard Worker * 22*8fb009dcSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 23*8fb009dcSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 24*8fb009dcSAndroid Build Coastguard Worker * are met: 25*8fb009dcSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the copyright 26*8fb009dcSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 27*8fb009dcSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright 28*8fb009dcSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the 29*8fb009dcSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution. 30*8fb009dcSAndroid Build Coastguard Worker * 3. All advertising materials mentioning features or use of this software 31*8fb009dcSAndroid Build Coastguard Worker * must display the following acknowledgement: 32*8fb009dcSAndroid Build Coastguard Worker * "This product includes cryptographic software written by 33*8fb009dcSAndroid Build Coastguard Worker * Eric Young ([email protected])" 34*8fb009dcSAndroid Build Coastguard Worker * The word 'cryptographic' can be left out if the rouines from the library 35*8fb009dcSAndroid Build Coastguard Worker * being used are not cryptographic related :-). 36*8fb009dcSAndroid Build Coastguard Worker * 4. If you include any Windows specific code (or a derivative thereof) from 37*8fb009dcSAndroid Build Coastguard Worker * the apps directory (application code) you must include an acknowledgement: 38*8fb009dcSAndroid Build Coastguard Worker * "This product includes software written by Tim Hudson ([email protected])" 39*8fb009dcSAndroid Build Coastguard Worker * 40*8fb009dcSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND 41*8fb009dcSAndroid Build Coastguard Worker * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 42*8fb009dcSAndroid Build Coastguard Worker * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 43*8fb009dcSAndroid Build Coastguard Worker * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 44*8fb009dcSAndroid Build Coastguard Worker * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 45*8fb009dcSAndroid Build Coastguard Worker * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 46*8fb009dcSAndroid Build Coastguard Worker * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 47*8fb009dcSAndroid Build Coastguard Worker * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 48*8fb009dcSAndroid Build Coastguard Worker * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 49*8fb009dcSAndroid Build Coastguard Worker * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 50*8fb009dcSAndroid Build Coastguard Worker * SUCH DAMAGE. 51*8fb009dcSAndroid Build Coastguard Worker * 52*8fb009dcSAndroid Build Coastguard Worker * The licence and distribution terms for any publically available version or 53*8fb009dcSAndroid Build Coastguard Worker * derivative of this code cannot be changed. i.e. this code cannot simply be 54*8fb009dcSAndroid Build Coastguard Worker * copied and put under another distribution licence 55*8fb009dcSAndroid Build Coastguard Worker * [including the GNU Public Licence.] 56*8fb009dcSAndroid Build Coastguard Worker */ 57*8fb009dcSAndroid Build Coastguard Worker /* ==================================================================== 58*8fb009dcSAndroid Build Coastguard Worker * Copyright (c) 1998-2001 The OpenSSL Project. All rights reserved. 59*8fb009dcSAndroid Build Coastguard Worker * 60*8fb009dcSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 61*8fb009dcSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 62*8fb009dcSAndroid Build Coastguard Worker * are met: 63*8fb009dcSAndroid Build Coastguard Worker * 64*8fb009dcSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright 65*8fb009dcSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 66*8fb009dcSAndroid Build Coastguard Worker * 67*8fb009dcSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright 68*8fb009dcSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in 69*8fb009dcSAndroid Build Coastguard Worker * the documentation and/or other materials provided with the 70*8fb009dcSAndroid Build Coastguard Worker * distribution. 71*8fb009dcSAndroid Build Coastguard Worker * 72*8fb009dcSAndroid Build Coastguard Worker * 3. All advertising materials mentioning features or use of this 73*8fb009dcSAndroid Build Coastguard Worker * software must display the following acknowledgment: 74*8fb009dcSAndroid Build Coastguard Worker * "This product includes software developed by the OpenSSL Project 75*8fb009dcSAndroid Build Coastguard Worker * for use in the OpenSSL Toolkit. (http://www.openssl.org/)" 76*8fb009dcSAndroid Build Coastguard Worker * 77*8fb009dcSAndroid Build Coastguard Worker * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to 78*8fb009dcSAndroid Build Coastguard Worker * endorse or promote products derived from this software without 79*8fb009dcSAndroid Build Coastguard Worker * prior written permission. For written permission, please contact 80*8fb009dcSAndroid Build Coastguard Worker * [email protected]. 81*8fb009dcSAndroid Build Coastguard Worker * 82*8fb009dcSAndroid Build Coastguard Worker * 5. Products derived from this software may not be called "OpenSSL" 83*8fb009dcSAndroid Build Coastguard Worker * nor may "OpenSSL" appear in their names without prior written 84*8fb009dcSAndroid Build Coastguard Worker * permission of the OpenSSL Project. 85*8fb009dcSAndroid Build Coastguard Worker * 86*8fb009dcSAndroid Build Coastguard Worker * 6. Redistributions of any form whatsoever must retain the following 87*8fb009dcSAndroid Build Coastguard Worker * acknowledgment: 88*8fb009dcSAndroid Build Coastguard Worker * "This product includes software developed by the OpenSSL Project 89*8fb009dcSAndroid Build Coastguard Worker * for use in the OpenSSL Toolkit (http://www.openssl.org/)" 90*8fb009dcSAndroid Build Coastguard Worker * 91*8fb009dcSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY 92*8fb009dcSAndroid Build Coastguard Worker * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 93*8fb009dcSAndroid Build Coastguard Worker * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 94*8fb009dcSAndroid Build Coastguard Worker * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR 95*8fb009dcSAndroid Build Coastguard Worker * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 96*8fb009dcSAndroid Build Coastguard Worker * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 97*8fb009dcSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 98*8fb009dcSAndroid Build Coastguard Worker * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 99*8fb009dcSAndroid Build Coastguard Worker * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 100*8fb009dcSAndroid Build Coastguard Worker * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 101*8fb009dcSAndroid Build Coastguard Worker * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED 102*8fb009dcSAndroid Build Coastguard Worker * OF THE POSSIBILITY OF SUCH DAMAGE. 103*8fb009dcSAndroid Build Coastguard Worker * ==================================================================== 104*8fb009dcSAndroid Build Coastguard Worker * 105*8fb009dcSAndroid Build Coastguard Worker * This product includes cryptographic software written by Eric Young 106*8fb009dcSAndroid Build Coastguard Worker * ([email protected]). This product includes software written by Tim 107*8fb009dcSAndroid Build Coastguard Worker * Hudson ([email protected]). */ 108*8fb009dcSAndroid Build Coastguard Worker 109*8fb009dcSAndroid Build Coastguard Worker #ifndef OPENSSL_HEADER_EX_DATA_H 110*8fb009dcSAndroid Build Coastguard Worker #define OPENSSL_HEADER_EX_DATA_H 111*8fb009dcSAndroid Build Coastguard Worker 112*8fb009dcSAndroid Build Coastguard Worker #include <openssl/base.h> 113*8fb009dcSAndroid Build Coastguard Worker 114*8fb009dcSAndroid Build Coastguard Worker #include <openssl/stack.h> 115*8fb009dcSAndroid Build Coastguard Worker 116*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 117*8fb009dcSAndroid Build Coastguard Worker extern "C" { 118*8fb009dcSAndroid Build Coastguard Worker #endif 119*8fb009dcSAndroid Build Coastguard Worker 120*8fb009dcSAndroid Build Coastguard Worker 121*8fb009dcSAndroid Build Coastguard Worker // ex_data is a mechanism for associating arbitrary extra data with objects. 122*8fb009dcSAndroid Build Coastguard Worker // For each type of object that supports ex_data, different users can be 123*8fb009dcSAndroid Build Coastguard Worker // assigned indexes in which to store their data. Each index has callback 124*8fb009dcSAndroid Build Coastguard Worker // functions that are called when an object of that type is freed or 125*8fb009dcSAndroid Build Coastguard Worker // duplicated. 126*8fb009dcSAndroid Build Coastguard Worker 127*8fb009dcSAndroid Build Coastguard Worker 128*8fb009dcSAndroid Build Coastguard Worker typedef struct crypto_ex_data_st CRYPTO_EX_DATA; 129*8fb009dcSAndroid Build Coastguard Worker 130*8fb009dcSAndroid Build Coastguard Worker 131*8fb009dcSAndroid Build Coastguard Worker // Type-specific functions. 132*8fb009dcSAndroid Build Coastguard Worker 133*8fb009dcSAndroid Build Coastguard Worker #if 0 // Sample 134*8fb009dcSAndroid Build Coastguard Worker 135*8fb009dcSAndroid Build Coastguard Worker // Each type that supports ex_data provides three functions: 136*8fb009dcSAndroid Build Coastguard Worker 137*8fb009dcSAndroid Build Coastguard Worker // TYPE_get_ex_new_index allocates a new index for |TYPE|. An optional 138*8fb009dcSAndroid Build Coastguard Worker // |free_func| argument may be provided which is called when the owning object 139*8fb009dcSAndroid Build Coastguard Worker // is destroyed. See |CRYPTO_EX_free| for details. The |argl| and |argp| 140*8fb009dcSAndroid Build Coastguard Worker // arguments are opaque values that are passed to the callback. It returns the 141*8fb009dcSAndroid Build Coastguard Worker // new index or a negative number on error. 142*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int TYPE_get_ex_new_index(long argl, void *argp, 143*8fb009dcSAndroid Build Coastguard Worker CRYPTO_EX_unused *unused, 144*8fb009dcSAndroid Build Coastguard Worker CRYPTO_EX_dup *dup_unused, 145*8fb009dcSAndroid Build Coastguard Worker CRYPTO_EX_free *free_func); 146*8fb009dcSAndroid Build Coastguard Worker 147*8fb009dcSAndroid Build Coastguard Worker // TYPE_set_ex_data sets an extra data pointer on |t|. The |index| argument 148*8fb009dcSAndroid Build Coastguard Worker // must have been returned from a previous call to |TYPE_get_ex_new_index|. 149*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int TYPE_set_ex_data(TYPE *t, int index, void *arg); 150*8fb009dcSAndroid Build Coastguard Worker 151*8fb009dcSAndroid Build Coastguard Worker // TYPE_get_ex_data returns an extra data pointer for |t|, or NULL if no such 152*8fb009dcSAndroid Build Coastguard Worker // pointer exists. The |index| argument should have been returned from a 153*8fb009dcSAndroid Build Coastguard Worker // previous call to |TYPE_get_ex_new_index|. 154*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void *TYPE_get_ex_data(const TYPE *t, int index); 155*8fb009dcSAndroid Build Coastguard Worker 156*8fb009dcSAndroid Build Coastguard Worker // Some types additionally preallocate index zero, with all callbacks set to 157*8fb009dcSAndroid Build Coastguard Worker // NULL. Applications that do not need the general ex_data machinery may use 158*8fb009dcSAndroid Build Coastguard Worker // this instead. 159*8fb009dcSAndroid Build Coastguard Worker 160*8fb009dcSAndroid Build Coastguard Worker // TYPE_set_app_data sets |t|'s application data pointer to |arg|. It returns 161*8fb009dcSAndroid Build Coastguard Worker // one on success and zero on error. 162*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int TYPE_set_app_data(TYPE *t, void *arg); 163*8fb009dcSAndroid Build Coastguard Worker 164*8fb009dcSAndroid Build Coastguard Worker // TYPE_get_app_data returns the application data pointer for |t|, or NULL if no 165*8fb009dcSAndroid Build Coastguard Worker // such pointer exists. 166*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void *TYPE_get_app_data(const TYPE *t); 167*8fb009dcSAndroid Build Coastguard Worker 168*8fb009dcSAndroid Build Coastguard Worker #endif // Sample 169*8fb009dcSAndroid Build Coastguard Worker 170*8fb009dcSAndroid Build Coastguard Worker 171*8fb009dcSAndroid Build Coastguard Worker // Callback types. 172*8fb009dcSAndroid Build Coastguard Worker 173*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_EX_free is a callback function that is called when an object of the 174*8fb009dcSAndroid Build Coastguard Worker // class with extra data pointers is being destroyed. For example, if this 175*8fb009dcSAndroid Build Coastguard Worker // callback has been passed to |SSL_get_ex_new_index| then it may be called each 176*8fb009dcSAndroid Build Coastguard Worker // time an |SSL*| is destroyed. 177*8fb009dcSAndroid Build Coastguard Worker // 178*8fb009dcSAndroid Build Coastguard Worker // The callback is passed the to-be-destroyed object (i.e. the |SSL*|) in 179*8fb009dcSAndroid Build Coastguard Worker // |parent|. As |parent| will shortly be destroyed, callers must not perform 180*8fb009dcSAndroid Build Coastguard Worker // operations that would increment its reference count, pass ownership, or 181*8fb009dcSAndroid Build Coastguard Worker // assume the object outlives the function call. The arguments |argl| and |argp| 182*8fb009dcSAndroid Build Coastguard Worker // contain opaque values that were given to |CRYPTO_get_ex_new_index_ex|. 183*8fb009dcSAndroid Build Coastguard Worker // 184*8fb009dcSAndroid Build Coastguard Worker // This callback may be called with a NULL value for |ptr| if |parent| has no 185*8fb009dcSAndroid Build Coastguard Worker // value set for this index. However, the callbacks may also be skipped entirely 186*8fb009dcSAndroid Build Coastguard Worker // if no extra data pointers are set on |parent| at all. 187*8fb009dcSAndroid Build Coastguard Worker typedef void CRYPTO_EX_free(void *parent, void *ptr, CRYPTO_EX_DATA *ad, 188*8fb009dcSAndroid Build Coastguard Worker int index, long argl, void *argp); 189*8fb009dcSAndroid Build Coastguard Worker 190*8fb009dcSAndroid Build Coastguard Worker 191*8fb009dcSAndroid Build Coastguard Worker // Deprecated functions. 192*8fb009dcSAndroid Build Coastguard Worker 193*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_cleanup_all_ex_data does nothing. 194*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_cleanup_all_ex_data(void); 195*8fb009dcSAndroid Build Coastguard Worker 196*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_EX_dup is a legacy callback function type which is ignored. 197*8fb009dcSAndroid Build Coastguard Worker typedef int CRYPTO_EX_dup(CRYPTO_EX_DATA *to, const CRYPTO_EX_DATA *from, 198*8fb009dcSAndroid Build Coastguard Worker void **from_d, int index, long argl, void *argp); 199*8fb009dcSAndroid Build Coastguard Worker 200*8fb009dcSAndroid Build Coastguard Worker 201*8fb009dcSAndroid Build Coastguard Worker // Private structures. 202*8fb009dcSAndroid Build Coastguard Worker 203*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_EX_unused is a placeholder for an unused callback. It is aliased to 204*8fb009dcSAndroid Build Coastguard Worker // int to ensure non-NULL callers fail to compile rather than fail silently. 205*8fb009dcSAndroid Build Coastguard Worker typedef int CRYPTO_EX_unused; 206*8fb009dcSAndroid Build Coastguard Worker 207*8fb009dcSAndroid Build Coastguard Worker struct crypto_ex_data_st { 208*8fb009dcSAndroid Build Coastguard Worker STACK_OF(void) *sk; 209*8fb009dcSAndroid Build Coastguard Worker }; 210*8fb009dcSAndroid Build Coastguard Worker 211*8fb009dcSAndroid Build Coastguard Worker 212*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 213*8fb009dcSAndroid Build Coastguard Worker } // extern C 214*8fb009dcSAndroid Build Coastguard Worker #endif 215*8fb009dcSAndroid Build Coastguard Worker 216*8fb009dcSAndroid Build Coastguard Worker #endif // OPENSSL_HEADER_EX_DATA_H 217