diff options
author | Dr. Stephen Henson <steve@openssl.org> | 2017-10-09 15:37:21 +0200 |
---|---|---|
committer | Dr. Stephen Henson <steve@openssl.org> | 2017-10-12 01:03:32 +0200 |
commit | c2976edf4b22691d8bebb0e3ca2db18b3d0c71c6 (patch) | |
tree | aff97c6aebad3065495b30c1f17c6679ff63d35b /crypto/evp | |
parent | Ensure we test all parameters for BN_FLG_CONSTTIME (diff) | |
download | openssl-c2976edf4b22691d8bebb0e3ca2db18b3d0c71c6.tar.xz openssl-c2976edf4b22691d8bebb0e3ca2db18b3d0c71c6.zip |
Don't ignore passed ENGINE.
If we are passed an ENGINE to use in int_ctx_new e.g. via EVP_PKEY_CTX_new()
use it instead of the default.
Reviewed-by: Matt Caswell <matt@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/4503)
Diffstat (limited to 'crypto/evp')
-rw-r--r-- | crypto/evp/pmeth_lib.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/crypto/evp/pmeth_lib.c b/crypto/evp/pmeth_lib.c index 2b9b8a92f8..31ec09261f 100644 --- a/crypto/evp/pmeth_lib.c +++ b/crypto/evp/pmeth_lib.c @@ -105,7 +105,7 @@ static EVP_PKEY_CTX *int_ctx_new(EVP_PKEY *pkey, ENGINE *e, int id) id = pkey->ameth->pkey_id; } #ifndef OPENSSL_NO_ENGINE - if (pkey && pkey->engine) + if (e == NULL && pkey != NULL) e = pkey->engine; /* Try to find an ENGINE which implements this method */ if (e) { @@ -113,8 +113,9 @@ static EVP_PKEY_CTX *int_ctx_new(EVP_PKEY *pkey, ENGINE *e, int id) EVPerr(EVP_F_INT_CTX_NEW, ERR_R_ENGINE_LIB); return NULL; } - } else + } else { e = ENGINE_get_pkey_meth_engine(id); + } /* * If an ENGINE handled this method look it up. Otherwise use internal |