summaryrefslogtreecommitdiff
path: root/src/lib/libssl/ssl_lib.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/libssl/ssl_lib.c')
-rw-r--r--src/lib/libssl/ssl_lib.c14
1 files changed, 4 insertions, 10 deletions
diff --git a/src/lib/libssl/ssl_lib.c b/src/lib/libssl/ssl_lib.c
index 70a4c6d16f..adcaa1b3cc 100644
--- a/src/lib/libssl/ssl_lib.c
+++ b/src/lib/libssl/ssl_lib.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: ssl_lib.c,v 1.203 2019/03/25 17:21:18 jsing Exp $ */ 1/* $OpenBSD: ssl_lib.c,v 1.204 2019/03/25 17:33:26 jsing 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 *
@@ -2734,20 +2734,14 @@ SSL_get_SSL_CTX(const SSL *ssl)
2734SSL_CTX * 2734SSL_CTX *
2735SSL_set_SSL_CTX(SSL *ssl, SSL_CTX* ctx) 2735SSL_set_SSL_CTX(SSL *ssl, SSL_CTX* ctx)
2736{ 2736{
2737 CERT *ocert = ssl->cert;
2738
2739 if (ssl->ctx == ctx) 2737 if (ssl->ctx == ctx)
2740 return (ssl->ctx); 2738 return (ssl->ctx);
2741 if (ctx == NULL) 2739 if (ctx == NULL)
2742 ctx = ssl->initial_ctx; 2740 ctx = ssl->initial_ctx;
2741
2742 ssl_cert_free(ssl->cert);
2743 ssl->cert = ssl_cert_dup(ctx->internal->cert); 2743 ssl->cert = ssl_cert_dup(ctx->internal->cert);
2744 if (ocert != NULL) { 2744
2745 int i;
2746 /* Copy negotiated sigalg from original certificate. */
2747 for (i = 0; i < SSL_PKEY_NUM; i++)
2748 ssl->cert->pkeys[i].sigalg = ocert->pkeys[i].sigalg;
2749 ssl_cert_free(ocert);
2750 }
2751 CRYPTO_add(&ctx->references, 1, CRYPTO_LOCK_SSL_CTX); 2745 CRYPTO_add(&ctx->references, 1, CRYPTO_LOCK_SSL_CTX);
2752 SSL_CTX_free(ssl->ctx); /* decrement reference count */ 2746 SSL_CTX_free(ssl->ctx); /* decrement reference count */
2753 ssl->ctx = ctx; 2747 ssl->ctx = ctx;