mirror of https://github.com/openssl/openssl.git
				
				
				
			
		
			
				
	
	
		
			181 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
			
		
		
	
	
			181 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| =pod
 | |
| 
 | |
| =head1 NAME
 | |
| 
 | |
| CRYPTO_EX_new, CRYPTO_EX_free, CRYPTO_EX_dup,
 | |
| CRYPTO_free_ex_index, CRYPTO_get_ex_new_index,
 | |
| CRYPTO_alloc_ex_data, CRYPTO_set_ex_data, CRYPTO_get_ex_data,
 | |
| CRYPTO_free_ex_data, CRYPTO_new_ex_data
 | |
| - functions supporting application-specific data
 | |
| 
 | |
| =head1 SYNOPSIS
 | |
| 
 | |
|  #include <openssl/crypto.h>
 | |
| 
 | |
|  int CRYPTO_get_ex_new_index(int class_index,
 | |
|                              long argl, void *argp,
 | |
|                              CRYPTO_EX_new *new_func,
 | |
|                              CRYPTO_EX_dup *dup_func,
 | |
|                              CRYPTO_EX_free *free_func);
 | |
| 
 | |
|  typedef void CRYPTO_EX_new(void *parent, void *ptr, CRYPTO_EX_DATA *ad,
 | |
|                             int idx, long argl, void *argp);
 | |
|  typedef void CRYPTO_EX_free(void *parent, void *ptr, CRYPTO_EX_DATA *ad,
 | |
|                              int idx, long argl, void *argp);
 | |
|  typedef int CRYPTO_EX_dup(CRYPTO_EX_DATA *to, const CRYPTO_EX_DATA *from,
 | |
|                            void **from_d, int idx, long argl, void *argp);
 | |
| 
 | |
|  int CRYPTO_new_ex_data(int class_index, void *obj, CRYPTO_EX_DATA *ad);
 | |
| 
 | |
|  int CRYPTO_alloc_ex_data(int class_index, void *obj, CRYPTO_EX_DATA *ad,
 | |
|                           int idx);
 | |
| 
 | |
|  int CRYPTO_set_ex_data(CRYPTO_EX_DATA *r, int idx, void *arg);
 | |
| 
 | |
|  void *CRYPTO_get_ex_data(const CRYPTO_EX_DATA *r, int idx);
 | |
| 
 | |
|  void CRYPTO_free_ex_data(int class_index, void *obj, CRYPTO_EX_DATA *r);
 | |
| 
 | |
|  int CRYPTO_free_ex_index(int class_index, int idx);
 | |
| 
 | |
| =head1 DESCRIPTION
 | |
| 
 | |
| Several OpenSSL structures can have application-specific data attached to them,
 | |
| known as "exdata."
 | |
| The specific structures are:
 | |
| 
 | |
|     BIO
 | |
|     DH
 | |
|     DSA
 | |
|     EC_KEY
 | |
|     ENGINE
 | |
|     EVP_PKEY
 | |
|     RSA
 | |
|     SSL
 | |
|     SSL_CTX
 | |
|     SSL_SESSION
 | |
|     UI
 | |
|     UI_METHOD
 | |
|     X509
 | |
|     X509_STORE
 | |
|     X509_STORE_CTX
 | |
| 
 | |
| In addition, the B<APP> name is reserved for use by application code.
 | |
| 
 | |
| Each is identified by an B<CRYPTO_EX_INDEX_xxx> define in the header file
 | |
| F<< <openssl/crypto.h> >>.  In addition, B<CRYPTO_EX_INDEX_APP> is reserved for
 | |
| applications to use this facility for their own structures.
 | |
| 
 | |
| The API described here is used by OpenSSL to manipulate exdata for specific
 | |
| structures.  Since the application data can be anything at all it is passed
 | |
| and retrieved as a B<void *> type.
 | |
| 
 | |
| The B<CRYPTO_EX_DATA> type is opaque.  To initialize the exdata part of
 | |
| a structure, call CRYPTO_new_ex_data(). This is only necessary for
 | |
| B<CRYPTO_EX_INDEX_APP> objects.
 | |
| 
 | |
| Exdata types are identified by an B<index>, an integer guaranteed to be
 | |
| unique within structures for the lifetime of the program.  Applications
 | |
| using exdata typically call B<CRYPTO_get_ex_new_index> at startup, and
 | |
| store the result in a global variable, or write a wrapper function to
 | |
| provide lazy evaluation.  The B<class_index> should be one of the
 | |
| B<CRYPTO_EX_INDEX_xxx> values. The B<argl> and B<argp> parameters are saved
 | |
| to be passed to the callbacks but are otherwise not used.  In order to
 | |
| transparently manipulate exdata, three callbacks must be provided. The
 | |
| semantics of those callbacks are described below.
 | |
| 
 | |
| When copying or releasing objects with exdata, the callback functions
 | |
| are called in increasing order of their B<index> value.
 | |
| 
 | |
| If a dynamic library can be unloaded, it should call CRYPTO_free_ex_index()
 | |
| when this is done.
 | |
| This will replace the callbacks with no-ops
 | |
| so that applications don't crash.  Any existing exdata will be leaked.
 | |
| 
 | |
| To set or get the exdata on an object, the appropriate type-specific
 | |
| routine must be used.  This is because the containing structure is opaque
 | |
| and the B<CRYPTO_EX_DATA> field is not accessible.  In both API's, the
 | |
| B<idx> parameter should be an already-created index value.
 | |
| 
 | |
| When setting exdata, the pointer specified with a particular index is saved,
 | |
| and returned on a subsequent "get" call.  If the application is going to
 | |
| release the data, it must make sure to set a B<NULL> value at the index,
 | |
| to avoid likely double-free crashes.
 | |
| 
 | |
| The function B<CRYPTO_free_ex_data> is used to free all exdata attached
 | |
| to a structure. The appropriate type-specific routine must be used.
 | |
| The B<class_index> identifies the structure type, the B<obj> is
 | |
| a pointer to the actual structure, and B<r> is a pointer to the
 | |
| structure's exdata field.
 | |
| 
 | |
| =head2 Callback Functions
 | |
| 
 | |
| This section describes how the callback functions are used. Applications
 | |
| that are defining their own exdata using B<CYPRTO_EX_INDEX_APP> must
 | |
| call them as described here.
 | |
| 
 | |
| When a structure is initially allocated (such as RSA_new()) then the
 | |
| new_func() is called for every defined index. There is no requirement
 | |
| that the entire parent, or containing, structure has been set up.
 | |
| The new_func() is typically used only to allocate memory to store the
 | |
| exdata, and perhaps an "initialized" flag within that memory.
 | |
| The exdata value may be allocated later on with CRYPTO_alloc_ex_data(),
 | |
| or may be set by calling CRYPTO_set_ex_data().
 | |
| 
 | |
| When a structure is free'd (such as SSL_CTX_free()) then the
 | |
| free_func() is called for every defined index.  Again, the state of the
 | |
| parent structure is not guaranteed.  The free_func() may be called with a
 | |
| NULL pointer.
 | |
| 
 | |
| Both new_func() and free_func() take the same parameters.
 | |
| The B<parent> is the pointer to the structure that contains the exdata.
 | |
| The B<ptr> is the current exdata item; for new_func() this will typically
 | |
| be NULL.  The B<r> parameter is a pointer to the exdata field of the object.
 | |
| The B<idx> is the index and is the value returned when the callbacks were
 | |
| initially registered via CRYPTO_get_ex_new_index() and can be used if
 | |
| the same callback handles different types of exdata.
 | |
| 
 | |
| dup_func() is called when a structure is being copied.  This is only done
 | |
| for B<SSL>, B<SSL_SESSION>, B<EC_KEY> objects and B<BIO> chains via
 | |
| BIO_dup_chain().  The B<to> and B<from> parameters
 | |
| are pointers to the destination and source B<CRYPTO_EX_DATA> structures,
 | |
| respectively.  The B<*from_d> parameter is a pointer to the source exdata.
 | |
| When the dup_func() returns, the value in B<*from_d> is copied to the
 | |
| destination ex_data.  If the pointer contained in B<*pptr> is not modified
 | |
| by the dup_func(), then both B<to> and B<from> will point to the same data.
 | |
| The B<idx>, B<argl> and B<argp> parameters are as described for the other
 | |
| two callbacks.  If the dup_func() returns B<0> the whole CRYPTO_dup_ex_data()
 | |
| will fail.
 | |
| 
 | |
| =head1 RETURN VALUES
 | |
| 
 | |
| CRYPTO_get_ex_new_index() returns a new index or -1 on failure.
 | |
| 
 | |
| CRYPTO_free_ex_index(), CRYPTO_alloc_ex_data() and CRYPTO_set_ex_data()
 | |
| return 1 on success or 0 on failure.
 | |
| 
 | |
| CRYPTO_get_ex_data() returns the application data or NULL on failure;
 | |
| note that NULL may be a valid value.
 | |
| 
 | |
| dup_func() should return 0 for failure and 1 for success.
 | |
| 
 | |
| =head1 HISTORY
 | |
| 
 | |
| CRYPTO_alloc_ex_data() was added in OpenSSL 3.0.
 | |
| 
 | |
| The signature of the dup_func() callback was changed in OpenSSL 3.0 to use the
 | |
| type B<void **> for B<from_d>.  Previously this parameter was of type B<void *>.
 | |
| 
 | |
| Support for ENGINE "exdata" was deprecated in OpenSSL 3.0.
 | |
| 
 | |
| =head1 COPYRIGHT
 | |
| 
 | |
| Copyright 2015-2021 The OpenSSL Project Authors. All Rights Reserved.
 | |
| 
 | |
| Licensed under the Apache License 2.0 (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
 |