diff options
author | Eneas U de Queiroz <cote2004-github@yahoo.com> | 2018-11-05 18:59:44 +0100 |
---|---|---|
committer | Richard Levitte <levitte@openssl.org> | 2018-12-10 13:19:26 +0100 |
commit | a67203a19d379a8cc8b369587c60c46eb4e19014 (patch) | |
tree | 03cdc4786a005d812b99475d01807050da5dde76 /crypto/engine/eng_devcrypto.c | |
parent | eng_devcrypto: fix copy of unitilialized digest (diff) | |
download | openssl-a67203a19d379a8cc8b369587c60c46eb4e19014.tar.xz openssl-a67203a19d379a8cc8b369587c60c46eb4e19014.zip |
eng_devcrypto: close session on cleanup, not final
Close the session in digest_cleanup instead of digest_final. A failure
in closing the session does not mean a previous successful digest final
has failed as well.
Signed-off-by: Eneas U de Queiroz <cote2004-github@yahoo.com>
Reviewed-by: Matthias St. Pierre <Matthias.St.Pierre@ncp-e.com>
Reviewed-by: Richard Levitte <levitte@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/7585)
Diffstat (limited to 'crypto/engine/eng_devcrypto.c')
-rw-r--r-- | crypto/engine/eng_devcrypto.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/crypto/engine/eng_devcrypto.c b/crypto/engine/eng_devcrypto.c index 1bb6308adc..513ea7af9f 100644 --- a/crypto/engine/eng_devcrypto.c +++ b/crypto/engine/eng_devcrypto.c @@ -461,10 +461,6 @@ static int digest_final(EVP_MD_CTX *ctx, unsigned char *md) SYSerr(SYS_F_IOCTL, errno); return 0; } - if (ioctl(cfd, CIOCFSESSION, &digest_ctx->sess.ses) < 0) { - SYSerr(SYS_F_IOCTL, errno); - return 0; - } return 1; } @@ -496,6 +492,15 @@ static int digest_copy(EVP_MD_CTX *to, const EVP_MD_CTX *from) static int digest_cleanup(EVP_MD_CTX *ctx) { + struct digest_ctx *digest_ctx = + (struct digest_ctx *)EVP_MD_CTX_md_data(ctx); + + if (digest_ctx == NULL) + return 1; + if (ioctl(cfd, CIOCFSESSION, &digest_ctx->sess.ses) < 0) { + SYSerr(SYS_F_IOCTL, errno); + return 0; + } return 1; } |