[tor-commits] [tor/master] Fix memory leak when sending configuration-changed event

nickm at torproject.org nickm at torproject.org
Fri Apr 19 01:48:23 UTC 2013


commit 0a9c17a61ad7193a051c53ea2a0cb91e012f014e
Author: Nick Mathewson <nickm at torproject.org>
Date:   Wed Apr 17 11:34:15 2013 -0400

    Fix memory leak when sending configuration-changed event
    
    Fix for bug #8718; bugfix on 0.2.3.3-alpha.
---
 changes/bug8716  |    3 +++
 src/or/config.c  |    3 ++-
 src/or/control.c |    2 +-
 src/or/control.h |    2 +-
 4 files changed, 7 insertions(+), 3 deletions(-)

diff --git a/changes/bug8716 b/changes/bug8716
new file mode 100644
index 0000000..74c74f8
--- /dev/null
+++ b/changes/bug8716
@@ -0,0 +1,3 @@
+  o Minor bugfixes (memory leak):
+    - Fix a memory leak that would occur whenever a configuration
+      option changed. Fixes bug #8718; bugfix on 0.2.3.3-alpha.
diff --git a/src/or/config.c b/src/or/config.c
index 16eadf9..236955b 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -785,12 +785,13 @@ set_options(or_options_t *new_val, char **msg)
             tor_free(line);
           }
         } else {
-          smartlist_add(elements, (char*)options_format.vars[i].name);
+          smartlist_add(elements, tor_strdup(options_format.vars[i].name));
           smartlist_add(elements, NULL);
         }
       }
     }
     control_event_conf_changed(elements);
+    SMARTLIST_FOREACH(elements, char *, cp, tor_free(cp));
     smartlist_free(elements);
   }
 
diff --git a/src/or/control.c b/src/or/control.c
index fc7bae2..417f6c6 100644
--- a/src/or/control.c
+++ b/src/or/control.c
@@ -4347,7 +4347,7 @@ control_event_guard(const char *nickname, const char *digest,
  * a smartlist_t containing (key, value, ...) pairs in sequence.
  * <b>value</b> can be NULL. */
 int
-control_event_conf_changed(smartlist_t *elements)
+control_event_conf_changed(const smartlist_t *elements)
 {
   int i;
   char *result;
diff --git a/src/or/control.h b/src/or/control.h
index f301ce9..943d67e 100644
--- a/src/or/control.h
+++ b/src/or/control.h
@@ -71,7 +71,7 @@ int control_event_server_status(int severity, const char *format, ...)
   CHECK_PRINTF(2,3);
 int control_event_guard(const char *nickname, const char *digest,
                         const char *status);
-int control_event_conf_changed(smartlist_t *elements);
+int control_event_conf_changed(const smartlist_t *elements);
 int control_event_buildtimeout_set(const circuit_build_times_t *cbt,
                                    buildtimeout_set_event_t type);
 int control_event_signal(uintptr_t signal);





More information about the tor-commits mailing list