Fix memory leak in hx509_context_init().
OpenSSL_add_all_algorithms() should only be run once per application or it will cause data structures to expand. It's not a classic memory leak as all of the memory will be free(3)d when EVP_cleanup() is called but as we are a library we cannot call this. We provide a short term fix here which is using heim_base_once_f() to ensure that we only call it once. But the long term fix should be to stop using OpenSSL_add_all_algorithms() entirely because it both has side effects outside our library and the caller may destroy our OpenSSL global variables by calling EVP_cleanup() on his own. It is suboptimal to have potential interactions between our library and other code in this way.
This commit is contained in:
		| @@ -93,6 +93,14 @@ typedef struct hx509_name_constraints { | ||||
| #define GeneralSubtrees_SET(g,var) \ | ||||
| 	(g)->len = (var)->len, (g)->val = (var)->val; | ||||
|  | ||||
| static void | ||||
| init_context_once(void *ignored) | ||||
| { | ||||
|  | ||||
|     ENGINE_add_conf_module(); | ||||
|     OpenSSL_add_all_algorithms(); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Creates a hx509 context that most functions in the library | ||||
|  * uses. The context is only allowed to be used by one thread at each | ||||
| @@ -108,10 +116,14 @@ typedef struct hx509_name_constraints { | ||||
| int | ||||
| hx509_context_init(hx509_context *context) | ||||
| { | ||||
|     static heim_base_once_t init_context = HEIM_BASE_ONCE_INIT; | ||||
|  | ||||
|     *context = calloc(1, sizeof(**context)); | ||||
|     if (*context == NULL) | ||||
| 	return ENOMEM; | ||||
|  | ||||
|     heim_base_once_f(&init_context, NULL, init_context_once); | ||||
|  | ||||
|     _hx509_ks_null_register(*context); | ||||
|     _hx509_ks_mem_register(*context); | ||||
|     _hx509_ks_file_register(*context); | ||||
| @@ -120,9 +132,6 @@ hx509_context_init(hx509_context *context) | ||||
|     _hx509_ks_dir_register(*context); | ||||
|     _hx509_ks_keychain_register(*context); | ||||
|  | ||||
|     ENGINE_add_conf_module(); | ||||
|     OpenSSL_add_all_algorithms(); | ||||
|  | ||||
|     (*context)->ocsp_time_diff = HX509_DEFAULT_OCSP_TIME_DIFF; | ||||
|  | ||||
|     initialize_hx_error_table_r(&(*context)->et_list); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Roland C. Dowdeswell
					Roland C. Dowdeswell