Fix potential double-free in calloc selftest
Where calloc returns two references to the same buffer, avoid calling free() on both references by setting one to NULL. Signed-off-by: David Horstmann <david.horstmann@arm.com>
This commit is contained in:
parent
90d07118ad
commit
64cd2f21ed
1 changed files with 3 additions and 0 deletions
|
@ -79,6 +79,7 @@ static int calloc_self_test(int verbose)
|
|||
if (verbose) {
|
||||
mbedtls_printf(" CALLOC(0,1): passed (same non-null)\n");
|
||||
}
|
||||
empty2 = NULL;
|
||||
} else {
|
||||
if (verbose) {
|
||||
mbedtls_printf(" CALLOC(0,1): passed (distinct non-null)\n");
|
||||
|
@ -103,6 +104,7 @@ static int calloc_self_test(int verbose)
|
|||
if (verbose) {
|
||||
mbedtls_printf(" CALLOC(1,0): passed (same non-null)\n");
|
||||
}
|
||||
empty2 = NULL;
|
||||
} else {
|
||||
if (verbose) {
|
||||
mbedtls_printf(" CALLOC(1,0): passed (distinct non-null)\n");
|
||||
|
@ -119,6 +121,7 @@ static int calloc_self_test(int verbose)
|
|||
mbedtls_printf(" CALLOC(1): failed (same buffer twice)\n");
|
||||
}
|
||||
++failures;
|
||||
buffer2 = NULL;
|
||||
} else {
|
||||
if (verbose) {
|
||||
mbedtls_printf(" CALLOC(1): passed\n");
|
||||
|
|
Loading…
Reference in a new issue