diff options
Diffstat (limited to 'src/lib/libssl/ssl_lib.c')
-rw-r--r-- | src/lib/libssl/ssl_lib.c | 14 |
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) | |||
2734 | SSL_CTX * | 2734 | SSL_CTX * |
2735 | SSL_set_SSL_CTX(SSL *ssl, SSL_CTX* ctx) | 2735 | SSL_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; |