From 0c704e3208713fc9baf5006671edf39a365e1009 Mon Sep 17 00:00:00 2001 From: miod <> Date: Fri, 11 Jul 2014 15:40:32 +0000 Subject: Fix a memory leak in BIO_free() which no current BIO can trigger; OpenSSL PR #3439 via OpenSSL trunk --- src/lib/libcrypto/bio/bio_lib.c | 7 +++---- src/lib/libssl/src/crypto/bio/bio_lib.c | 7 +++---- 2 files changed, 6 insertions(+), 8 deletions(-) (limited to 'src/lib') diff --git a/src/lib/libcrypto/bio/bio_lib.c b/src/lib/libcrypto/bio/bio_lib.c index 41b3d31678..a2b34a2f80 100644 --- a/src/lib/libcrypto/bio/bio_lib.c +++ b/src/lib/libcrypto/bio/bio_lib.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bio_lib.c,v 1.19 2014/07/11 08:44:47 jsing Exp $ */ +/* $OpenBSD: bio_lib.c,v 1.20 2014/07/11 15:40:32 miod Exp $ */ /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) * All rights reserved. * @@ -125,9 +125,8 @@ BIO_free(BIO *a) CRYPTO_free_ex_data(CRYPTO_EX_INDEX_BIO, a, &a->ex_data); - if ((a->method == NULL) || (a->method->destroy == NULL)) - return (1); - a->method->destroy(a); + if (a->method != NULL && a->method->destroy != NULL) + a->method->destroy(a); free(a); return (1); } diff --git a/src/lib/libssl/src/crypto/bio/bio_lib.c b/src/lib/libssl/src/crypto/bio/bio_lib.c index 41b3d31678..a2b34a2f80 100644 --- a/src/lib/libssl/src/crypto/bio/bio_lib.c +++ b/src/lib/libssl/src/crypto/bio/bio_lib.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bio_lib.c,v 1.19 2014/07/11 08:44:47 jsing Exp $ */ +/* $OpenBSD: bio_lib.c,v 1.20 2014/07/11 15:40:32 miod Exp $ */ /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) * All rights reserved. * @@ -125,9 +125,8 @@ BIO_free(BIO *a) CRYPTO_free_ex_data(CRYPTO_EX_INDEX_BIO, a, &a->ex_data); - if ((a->method == NULL) || (a->method->destroy == NULL)) - return (1); - a->method->destroy(a); + if (a->method != NULL && a->method->destroy != NULL) + a->method->destroy(a); free(a); return (1); } -- cgit v1.2.3-55-g6feb