From f51cf14b85e489a8ab357fc16719efb711e76a1f Mon Sep 17 00:00:00 2001 From: =?utf8?q?Bodo=20M=C3=B6ller?= Date: Mon, 12 Mar 2001 18:07:20 +0000 Subject: [PATCH] fix memory leak in err.c --- CHANGES | 3 +++ crypto/err/err.c | 10 +++++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index 8ed1b98633..4c8a93cb1b 100644 --- a/CHANGES +++ b/CHANGES @@ -3,6 +3,9 @@ Changes between 0.9.6 and 0.9.7 [xx XXX 2000] + *) Fix a memory leak in err.c: free err_data string if necessary. + [Bodo Moeller] + *) Function EC_POINTs_mul for simultaneous scalar multiplication of an arbitrary number of elliptic curve points, optionally including the generator defined for the EC_GROUP. diff --git a/crypto/err/err.c b/crypto/err/err.c index 145fdc58d1..91b0295fb5 100644 --- a/crypto/err/err.c +++ b/crypto/err/err.c @@ -466,7 +466,15 @@ static unsigned long get_error_values(int inc, const char **file, int *line, } } - if (data != NULL) + if (data == NULL) + { + if (inc && (es->err_data[i] != NULL) && (es->err_data_flags[i] & ERR_TXT_MALLOCED)) + { + OPENSSL_free(es->err_data[i]); + es->err_data[i] = NULL; + } + } + else { if (es->err_data[i] == NULL) { -- 2.25.1