openssl/crypto/evp
wangcheng 4c41aa4b33 Add CTX copy function for EVP_MD to optimize the performance of EVP_MD_CTX_copy_ex.
1. Add OSSL_FUNC_digest_copyctx_fn function for EVP_MD, which is used to copy algctx from the old EVP_MD_CTX to the new one.

2. Add implementation of OSSL_FUNC_digest_copyctx_fn function for default providers.

3. Modify EVP_MD_CTX_copy_ex: When the fetched digest is the same in in and out contexts, use the copy function to copy the members in EVP_MD_CTX if the OSSL_FUNC_digest_copyctx_fn function exists. Otherwise, use the previous method to copy.

4. Add documentation for OSSL_FUNC_digest_copyctx function in doc/man7/provider-digest.pod.

5. Add testcase.

Fixes #25703

Signed-off-by: wangcheng <bangwangnj@163.com>

Reviewed-by: Dmitry Belyavskiy <beldmit@gmail.com>
Reviewed-by: Tomas Mraz <tomas@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/25726)
2024-11-20 14:12:53 +01:00
..
asymcipher.c
bio_b64.c Copyright year updates 2024-09-05 09:35:49 +02:00
bio_enc.c
bio_md.c
bio_ok.c Copyright year updates 2024-09-05 09:35:49 +02:00
build.info Exclude EVP_DigestSign and EVP_DigestVerify related APIs from the FIPS 2024-10-04 17:41:13 +02:00
c_allc.c
c_alld.c
cmeth_lib.c
ctrl_params_translate.c Bugfixes for params to legacy control translations for EC parameters 2024-11-07 10:35:54 +01:00
dh_ctrl.c
dh_support.c Copyright year updates 2024-09-05 09:35:49 +02:00
digest.c Add CTX copy function for EVP_MD to optimize the performance of EVP_MD_CTX_copy_ex. 2024-11-20 14:12:53 +01:00
dsa_ctrl.c
e_aes_cbc_hmac_sha1.c
e_aes_cbc_hmac_sha256.c
e_aes.c
e_aria.c
e_bf.c
e_camellia.c
e_cast.c
e_chacha20_poly1305.c
e_des3.c Copyright year updates 2024-09-05 09:35:49 +02:00
e_des.c
e_idea.c
e_null.c
e_old.c
e_rc2.c Rename all getters to use get/get0 in name 2021-06-01 12:40:00 +02:00
e_rc4_hmac_md5.c
e_rc4.c
e_rc5.c
e_seed.c
e_sm4.c
e_xcbc_d.c
ec_ctrl.c
ec_support.c
encode.c Copyright year updates 2024-09-05 09:35:49 +02:00
evp_cnf.c
evp_enc.c Copyright year updates 2024-09-05 09:35:49 +02:00
evp_err.c fix coding style 2024-08-27 13:56:28 +02:00
evp_fetch.c EVP_get_default_properties - implementation 2024-09-16 08:15:52 +10:00
evp_key.c
evp_lib.c Don't restrict what EVP_PKEY_Q_keygen can be used for 2024-09-17 16:25:44 +01:00
evp_local.h Implement functionality for direct use of composite signature algorithms 2024-08-21 08:21:06 +02:00
evp_pbe.c
evp_pkey.c
evp_rand.c
evp_utils.c
exchange.c
kdf_lib.c
kdf_meth.c
kem.c
keymgmt_lib.c
keymgmt_meth.c Add KeyManagement keygen parameter getter/gettable functions. 2024-08-06 11:01:13 +02:00
legacy_blake2.c
legacy_md2.c
legacy_md4.c
legacy_md5_sha1.c
legacy_md5.c
legacy_mdc2.c
legacy_meth.h
legacy_ripemd.c
legacy_sha.c
legacy_wp.c
m_null.c
m_sigver.c Exclude EVP_DigestSign and EVP_DigestVerify related APIs from the FIPS 2024-10-04 17:41:13 +02:00
mac_lib.c
mac_meth.c
names.c Copyright year updates 2024-09-05 09:35:49 +02:00
p5_crpt2.c
p5_crpt.c Copyright year updates 2024-09-05 09:35:49 +02:00
p_dec.c
p_enc.c Fix possible null pointer dereference of evp_pkey_get_legacy() 2022-06-02 12:06:08 +02:00
p_legacy.c
p_lib.c open brace '{' following struct go on the same line 2024-07-22 06:55:35 -04:00
p_open.c
p_seal.c
p_sign.c
p_verify.c
pbe_scrypt.c Add library context and property query support into the PKCS12 API 2021-04-30 09:15:50 +10:00
pmeth_check.c Make EVP_PKEY_check() be an alias for EVP_PKEY_pairwise_check() 2021-07-15 10:54:25 +10:00
pmeth_gn.c
pmeth_lib.c Add KeyManagement keygen parameter getter/gettable functions. 2024-08-06 11:01:13 +02:00
signature.c Refactor OpenSSL 'EdDSA' EVP_SIGNATURE to allow use with EVP_PKEY functions 2024-08-29 19:13:06 +02:00