mirror of
https://github.com/openssl/openssl.git
synced 2025-01-18 13:44:20 +08:00
59a783d05a
If two threads both attempt to load the same provider at the same time, they will first both check to see if the provider already exists. If it doesn't then they will both then create new provider objects and call the init function. However only one of the threads will be successful in adding the provider to the store. For the "losing" thread we should still return "success", but we should deinitialise and free the no longer required provider object, and return the object that exists in the store. Reviewed-by: Paul Dale <pauli@openssl.org> Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/15854) |
||
---|---|---|
.. | ||
cms_add1_signing_cert.pod | ||
evp_generic_fetch.pod | ||
evp_keymgmt_newdata.pod | ||
evp_keymgmt_util_export_to_provider.pod | ||
evp_md_get_number.pod | ||
evp_pkey_export_to_provider.pod | ||
evp_pkey_get1_ED25519.pod | ||
OPENSSL_SA.pod | ||
OPTIONS.pod | ||
ossl_algorithm_do_all.pod | ||
ossl_cmp_asn1_octet_string_set1.pod | ||
ossl_cmp_certreq_new.pod | ||
ossl_cmp_ctx_set1_caPubs.pod | ||
ossl_cmp_hdr_init.pod | ||
ossl_cmp_mock_srv_new.pod | ||
ossl_cmp_msg_check_update.pod | ||
ossl_cmp_msg_create.pod | ||
ossl_cmp_msg_protect.pod | ||
ossl_cmp_pkisi_get_status.pod | ||
ossl_cmp_print_log.pod | ||
ossl_cmp_X509_STORE_add1_certs.pod | ||
OSSL_DEPRECATED.pod | ||
ossl_DER_w_begin_sequence.pod | ||
ossl_DER_w_bn.pod | ||
ossl_DER_w_precompiled.pod | ||
ossl_ends_with_dirsep.pod | ||
ossl_global_properties_no_mirrored.pod | ||
ossl_init_thread_deregister.pod | ||
ossl_lib_ctx_get_data.pod | ||
ossl_method_construct.pod | ||
OSSL_METHOD_STORE.pod | ||
ossl_namemap_new.pod | ||
ossl_provider_add_conf_module.pod | ||
ossl_provider_new.pod | ||
ossl_punycode_decode.pod | ||
ossl_rand_get_entropy.pod | ||
ossl_random_add_conf_module.pod | ||
ossl_rsa_get0_all_params.pod | ||
x509v3_cache_extensions.pod |