diff options
Diffstat (limited to 'src/lib/libssl/ssl_cert.c')
-rw-r--r-- | src/lib/libssl/ssl_cert.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/src/lib/libssl/ssl_cert.c b/src/lib/libssl/ssl_cert.c index a711b5db5c..4c39925c60 100644 --- a/src/lib/libssl/ssl_cert.c +++ b/src/lib/libssl/ssl_cert.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: ssl_cert.c,v 1.85 2021/10/23 16:11:30 tb Exp $ */ | 1 | /* $OpenBSD: ssl_cert.c,v 1.86 2021/10/23 20:42:50 beck Exp $ */ |
2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) | 2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) |
3 | * All rights reserved. | 3 | * All rights reserved. |
4 | * | 4 | * |
@@ -447,6 +447,15 @@ ssl_verify_cert_chain(SSL *s, STACK_OF(X509) *sk) | |||
447 | ret = X509_verify_cert(ctx); | 447 | ret = X509_verify_cert(ctx); |
448 | 448 | ||
449 | s->verify_result = X509_STORE_CTX_get_error(ctx); | 449 | s->verify_result = X509_STORE_CTX_get_error(ctx); |
450 | sk_X509_pop_free(s->internal->verified_chain, X509_free); | ||
451 | s->internal->verified_chain = NULL; | ||
452 | if (X509_STORE_CTX_get0_chain(ctx) != NULL) { | ||
453 | s->internal->verified_chain = X509_STORE_CTX_get1_chain(ctx); | ||
454 | if (s->internal->verified_chain == NULL) { | ||
455 | SSLerrorx(ERR_R_MALLOC_FAILURE); | ||
456 | ret = 0; | ||
457 | } | ||
458 | } | ||
450 | 459 | ||
451 | err: | 460 | err: |
452 | X509_STORE_CTX_free(ctx); | 461 | X509_STORE_CTX_free(ctx); |