diff options
Diffstat (limited to 'src/lib/libcrypto/evp/p_sign.c')
| -rw-r--r-- | src/lib/libcrypto/evp/p_sign.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/src/lib/libcrypto/evp/p_sign.c b/src/lib/libcrypto/evp/p_sign.c index dfa48c157c..bb893f5bde 100644 --- a/src/lib/libcrypto/evp/p_sign.c +++ b/src/lib/libcrypto/evp/p_sign.c | |||
| @@ -80,20 +80,18 @@ int EVP_SignFinal(EVP_MD_CTX *ctx, unsigned char *sigret, unsigned int *siglen, | |||
| 80 | { | 80 | { |
| 81 | unsigned char m[EVP_MAX_MD_SIZE]; | 81 | unsigned char m[EVP_MAX_MD_SIZE]; |
| 82 | unsigned int m_len; | 82 | unsigned int m_len; |
| 83 | int i=0,ok=0,v; | 83 | int i,ok=0,v; |
| 84 | EVP_MD_CTX tmp_ctx; | 84 | EVP_MD_CTX tmp_ctx; |
| 85 | EVP_PKEY_CTX *pkctx = NULL; | ||
| 86 | 85 | ||
| 87 | *siglen=0; | 86 | *siglen=0; |
| 88 | EVP_MD_CTX_init(&tmp_ctx); | 87 | EVP_MD_CTX_init(&tmp_ctx); |
| 89 | if (!EVP_MD_CTX_copy_ex(&tmp_ctx,ctx)) | 88 | EVP_MD_CTX_copy_ex(&tmp_ctx,ctx); |
| 90 | goto err; | 89 | EVP_DigestFinal_ex(&tmp_ctx,&(m[0]),&m_len); |
| 91 | if (!EVP_DigestFinal_ex(&tmp_ctx,&(m[0]),&m_len)) | ||
| 92 | goto err; | ||
| 93 | EVP_MD_CTX_cleanup(&tmp_ctx); | 90 | EVP_MD_CTX_cleanup(&tmp_ctx); |
| 94 | 91 | ||
| 95 | if (ctx->digest->flags & EVP_MD_FLAG_PKEY_METHOD_SIGNATURE) | 92 | if (ctx->digest->flags & EVP_MD_FLAG_PKEY_METHOD_SIGNATURE) |
| 96 | { | 93 | { |
| 94 | EVP_PKEY_CTX *pkctx = NULL; | ||
| 97 | size_t sltmp = (size_t)EVP_PKEY_size(pkey); | 95 | size_t sltmp = (size_t)EVP_PKEY_size(pkey); |
| 98 | i = 0; | 96 | i = 0; |
| 99 | pkctx = EVP_PKEY_CTX_new(pkey, NULL); | 97 | pkctx = EVP_PKEY_CTX_new(pkey, NULL); |
