(patch) memory leak in loadparm.c

Colin Walters walters at debian.org
Fri Dec 28 23:30:33 EST 2001


Hi, I spent a little bit of time trying to debug a segfault in rsync
2.5.0, and after discovering it was in loadparm.c, I noticed that the
bug had been worked around in the current CVS by removing a free()
statement.

That fix seems less than optimal; here's a patch which should fix the
memory leak.


-------------- next part --------------
--- loadparm.c.~1.40.~	Sun Dec  2 03:16:15 2001
+++ loadparm.c	Fri Dec 28 07:22:25 2001
@@ -108,7 +108,8 @@
 
 
 /* 
- * This structure describes a single service. 
+ * This structure describes a single service.  If you update this, be
+ * sure to update init_globals below!
  */
 typedef struct
 {
@@ -179,6 +180,7 @@
 static int iNumServices = 0;
 static int iServiceIndex = 0;
 static BOOL bInGlobalSection = True;
+static BOOL bsDefaultInitialized = False;
 
 #define NUMPARAMETERS (sizeof(parm_table) / sizeof(struct parm_struct))
 
@@ -297,6 +299,28 @@
 #ifdef LOG_DAEMON
 	Globals.syslog_facility = LOG_DAEMON;
 #endif
+  if (!bsDefaultInitialized) {
+    bsDefaultInitialized = True;
+#define maybe_init(x) if (sDefault.x != NULL) sDefault.x = strdup(sDefault.x)
+    maybe_init(name);
+    maybe_init(path);
+    maybe_init(comment);
+    maybe_init(lock_file);
+    maybe_init(uid);
+    maybe_init(gid);
+    maybe_init(hosts_allow);
+    maybe_init(hosts_deny);
+    maybe_init(auth_users);
+    maybe_init(secrets_file);
+    maybe_init(exclude);
+    maybe_init(exclude_from);
+    maybe_init(include);
+    maybe_init(include_from);
+    maybe_init(log_format);
+    maybe_init(refuse_options);
+    maybe_init(dont_compress);
+#undef maybe_init
+  }
 }
 
 /***************************************************************************
@@ -386,16 +410,9 @@
 
 
 /**
- * Assign a copy of @p v to @p *s.  Handles NULL strings.  @p *v must
- * be initialized when this is called, either to NULL or a malloc'd
- * string.
- *
- * @fixme There is a small leak here in that sometimes the existing
- * value will be dynamically allocated, and the old copy is lost.
- * However, we can't always deallocate the old value, because in the
- * case of sDefault, it points to a static string.  It would be nice
- * to have either all-strdup'd values, or to never need to free
- * memory.
+ * Assign a copy of @p v to @p *s, freeing any existing values and
+ * handling NULL strings.  @p *v must be initialized when this is
+ * called, either to NULL or a malloc'd string.
  **/
 static void string_set(char **s, const char *v)
 {
@@ -403,6 +420,8 @@
 		*s = NULL;
 		return;
 	}
+	if (*s)
+		free(*s);
 	*s = strdup(v);
 	if (!*s)
 		exit_cleanup(RERR_MALLOC);


More information about the rsync mailing list