zrhoffman / rpms / 389-ds-base

Forked from rpms/389-ds-base 3 years ago
Clone

Blame SOURCES/0010-Fix-double-free-in-_cl5NewDBFile-error-path.patch

6f51e1
From 8c39c9dbe69949065940019e930c37b8f5450a75 Mon Sep 17 00:00:00 2001
6f51e1
From: Adam Tkac <vonsch@gmail.com>
6f51e1
Date: Sat, 18 Mar 2017 23:34:54 +0100
6f51e1
Subject: [PATCH] Fix double-free in _cl5NewDBFile() error path
6f51e1
6f51e1
Although slapi_ch_free should prevent double-free errors, it doesn't work
6f51e1
in old code because after assignment
6f51e1
6f51e1
(*dbFile)->name = name;
6f51e1
6f51e1
two independent pointers points to the same allocated area and both pointers
6f51e1
are free()-ed (one directly in error path in _cl5NewDBFile and the second
6f51e1
in _cl5DBCloseFile, called in error path as well).
6f51e1
6f51e1
Signed-off-by: Mark Reynolds <mreynolds@redhat.com>
6f51e1
---
6f51e1
 ldap/servers/plugins/replication/cl5_api.c | 7 ++++---
6f51e1
 1 file changed, 4 insertions(+), 3 deletions(-)
6f51e1
6f51e1
diff --git a/ldap/servers/plugins/replication/cl5_api.c b/ldap/servers/plugins/replication/cl5_api.c
6f51e1
index fc70ab7..5c2233f 100644
6f51e1
--- a/ldap/servers/plugins/replication/cl5_api.c
6f51e1
+++ b/ldap/servers/plugins/replication/cl5_api.c
6f51e1
@@ -6269,9 +6269,10 @@ out:
6f51e1
 	}
6f51e1
 
6f51e1
     (*dbFile)->db = db;
6f51e1
-    (*dbFile)->name = name;  
6f51e1
-    (*dbFile)->replName = slapi_ch_strdup (replName);  
6f51e1
-    (*dbFile)->replGen = slapi_ch_strdup (replGen);  
6f51e1
+    (*dbFile)->name = name;
6f51e1
+    name = NULL; /* transfer ownership to dbFile struct */
6f51e1
+    (*dbFile)->replName = slapi_ch_strdup (replName);
6f51e1
+    (*dbFile)->replGen = slapi_ch_strdup (replGen);
6f51e1
 
6f51e1
 	/*
6f51e1
 	 * Considerations for setting up cl semaphore:
6f51e1
-- 
6f51e1
2.9.3
6f51e1