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 #ifndef OPENSSL_HEADER_THREAD_H 58*8fb009dcSAndroid Build Coastguard Worker #define OPENSSL_HEADER_THREAD_H 59*8fb009dcSAndroid Build Coastguard Worker 60*8fb009dcSAndroid Build Coastguard Worker #include <sys/types.h> 61*8fb009dcSAndroid Build Coastguard Worker 62*8fb009dcSAndroid Build Coastguard Worker #include <openssl/base.h> 63*8fb009dcSAndroid Build Coastguard Worker 64*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 65*8fb009dcSAndroid Build Coastguard Worker extern "C" { 66*8fb009dcSAndroid Build Coastguard Worker #endif 67*8fb009dcSAndroid Build Coastguard Worker 68*8fb009dcSAndroid Build Coastguard Worker 69*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_refcount_t is the type of a reference count. 70*8fb009dcSAndroid Build Coastguard Worker // 71*8fb009dcSAndroid Build Coastguard Worker // Since some platforms use C11 atomics to access this, it should have the 72*8fb009dcSAndroid Build Coastguard Worker // _Atomic qualifier. However, this header is included by C++ programs as well 73*8fb009dcSAndroid Build Coastguard Worker // as C code that might not set -std=c11. So, in practice, it's not possible to 74*8fb009dcSAndroid Build Coastguard Worker // do that. Instead we statically assert that the size and native alignment of 75*8fb009dcSAndroid Build Coastguard Worker // a plain uint32_t and an _Atomic uint32_t are equal in refcount.c. 76*8fb009dcSAndroid Build Coastguard Worker typedef uint32_t CRYPTO_refcount_t; 77*8fb009dcSAndroid Build Coastguard Worker 78*8fb009dcSAndroid Build Coastguard Worker 79*8fb009dcSAndroid Build Coastguard Worker // Deprecated functions. 80*8fb009dcSAndroid Build Coastguard Worker // 81*8fb009dcSAndroid Build Coastguard Worker // Historically, OpenSSL required callers to provide locking callbacks. 82*8fb009dcSAndroid Build Coastguard Worker // BoringSSL is thread-safe by default, but some old code calls these functions 83*8fb009dcSAndroid Build Coastguard Worker // and so no-op implementations are provided. 84*8fb009dcSAndroid Build Coastguard Worker 85*8fb009dcSAndroid Build Coastguard Worker // These defines do nothing but are provided to make old code easier to 86*8fb009dcSAndroid Build Coastguard Worker // compile. 87*8fb009dcSAndroid Build Coastguard Worker #define CRYPTO_LOCK 1 88*8fb009dcSAndroid Build Coastguard Worker #define CRYPTO_UNLOCK 2 89*8fb009dcSAndroid Build Coastguard Worker #define CRYPTO_READ 4 90*8fb009dcSAndroid Build Coastguard Worker #define CRYPTO_WRITE 8 91*8fb009dcSAndroid Build Coastguard Worker 92*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_num_locks returns one. (This is non-zero that callers who allocate 93*8fb009dcSAndroid Build Coastguard Worker // sizeof(lock) times this value don't get zero and then fail because malloc(0) 94*8fb009dcSAndroid Build Coastguard Worker // returned NULL.) 95*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int CRYPTO_num_locks(void); 96*8fb009dcSAndroid Build Coastguard Worker 97*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_set_locking_callback does nothing. 98*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_set_locking_callback( 99*8fb009dcSAndroid Build Coastguard Worker void (*func)(int mode, int lock_num, const char *file, int line)); 100*8fb009dcSAndroid Build Coastguard Worker 101*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_set_add_lock_callback does nothing. 102*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_set_add_lock_callback(int (*func)( 103*8fb009dcSAndroid Build Coastguard Worker int *num, int amount, int lock_num, const char *file, int line)); 104*8fb009dcSAndroid Build Coastguard Worker 105*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_get_locking_callback returns NULL. 106*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void (*CRYPTO_get_locking_callback(void))(int mode, int lock_num, 107*8fb009dcSAndroid Build Coastguard Worker const char *file, 108*8fb009dcSAndroid Build Coastguard Worker int line); 109*8fb009dcSAndroid Build Coastguard Worker 110*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_get_lock_name returns a fixed, dummy string. 111*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT const char *CRYPTO_get_lock_name(int lock_num); 112*8fb009dcSAndroid Build Coastguard Worker 113*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_THREADID_set_callback returns one. 114*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int CRYPTO_THREADID_set_callback( 115*8fb009dcSAndroid Build Coastguard Worker void (*threadid_func)(CRYPTO_THREADID *threadid)); 116*8fb009dcSAndroid Build Coastguard Worker 117*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_THREADID_set_numeric does nothing. 118*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_THREADID_set_numeric(CRYPTO_THREADID *id, 119*8fb009dcSAndroid Build Coastguard Worker unsigned long val); 120*8fb009dcSAndroid Build Coastguard Worker 121*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_THREADID_set_pointer does nothing. 122*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_THREADID_set_pointer(CRYPTO_THREADID *id, void *ptr); 123*8fb009dcSAndroid Build Coastguard Worker 124*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_THREADID_current does nothing. 125*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_THREADID_current(CRYPTO_THREADID *id); 126*8fb009dcSAndroid Build Coastguard Worker 127*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_set_id_callback does nothing. 128*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_set_id_callback(unsigned long (*func)(void)); 129*8fb009dcSAndroid Build Coastguard Worker 130*8fb009dcSAndroid Build Coastguard Worker typedef struct { 131*8fb009dcSAndroid Build Coastguard Worker int references; 132*8fb009dcSAndroid Build Coastguard Worker struct CRYPTO_dynlock_value *data; 133*8fb009dcSAndroid Build Coastguard Worker } CRYPTO_dynlock; 134*8fb009dcSAndroid Build Coastguard Worker 135*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_set_dynlock_create_callback does nothing. 136*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_set_dynlock_create_callback( 137*8fb009dcSAndroid Build Coastguard Worker struct CRYPTO_dynlock_value *(*dyn_create_function)(const char *file, 138*8fb009dcSAndroid Build Coastguard Worker int line)); 139*8fb009dcSAndroid Build Coastguard Worker 140*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_set_dynlock_lock_callback does nothing. 141*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_set_dynlock_lock_callback(void (*dyn_lock_function)( 142*8fb009dcSAndroid Build Coastguard Worker int mode, struct CRYPTO_dynlock_value *l, const char *file, int line)); 143*8fb009dcSAndroid Build Coastguard Worker 144*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_set_dynlock_destroy_callback does nothing. 145*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void CRYPTO_set_dynlock_destroy_callback( 146*8fb009dcSAndroid Build Coastguard Worker void (*dyn_destroy_function)(struct CRYPTO_dynlock_value *l, 147*8fb009dcSAndroid Build Coastguard Worker const char *file, int line)); 148*8fb009dcSAndroid Build Coastguard Worker 149*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_get_dynlock_create_callback returns NULL. 150*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT struct CRYPTO_dynlock_value *( 151*8fb009dcSAndroid Build Coastguard Worker *CRYPTO_get_dynlock_create_callback(void))(const char *file, int line); 152*8fb009dcSAndroid Build Coastguard Worker 153*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_get_dynlock_lock_callback returns NULL. 154*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void (*CRYPTO_get_dynlock_lock_callback(void))( 155*8fb009dcSAndroid Build Coastguard Worker int mode, struct CRYPTO_dynlock_value *l, const char *file, int line); 156*8fb009dcSAndroid Build Coastguard Worker 157*8fb009dcSAndroid Build Coastguard Worker // CRYPTO_get_dynlock_destroy_callback returns NULL. 158*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void (*CRYPTO_get_dynlock_destroy_callback(void))( 159*8fb009dcSAndroid Build Coastguard Worker struct CRYPTO_dynlock_value *l, const char *file, int line); 160*8fb009dcSAndroid Build Coastguard Worker 161*8fb009dcSAndroid Build Coastguard Worker 162*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 163*8fb009dcSAndroid Build Coastguard Worker } // extern C 164*8fb009dcSAndroid Build Coastguard Worker #endif 165*8fb009dcSAndroid Build Coastguard Worker 166*8fb009dcSAndroid Build Coastguard Worker #endif // OPENSSL_HEADER_THREAD_H 167