diff options
author | Nick Mathewson <nickm@torproject.org> | 2017-08-08 20:07:39 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-08-08 20:08:43 -0400 |
commit | 72832086e2144158308b30133aa15b39f0d2eb5d (patch) | |
tree | 2bdb396011480bea194ed212c63227e773a60776 /src/common/confline.c | |
parent | a47b8fcf9295111339b80e5bc81c3de428241cad (diff) | |
download | tor-72832086e2144158308b30133aa15b39f0d2eb5d.tar.gz tor-72832086e2144158308b30133aa15b39f0d2eb5d.zip |
Use a single free-and-exit strategy in config_process_include.
This avoids a double-free when a pointer already freed with
tor_free(config_line) is freed again in the cleanup-and-exit code.
Fixes bug 23155.
Diffstat (limited to 'src/common/confline.c')
-rw-r--r-- | src/common/confline.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/src/common/confline.c b/src/common/confline.c index 691cbf8c6f..15fd96bf38 100644 --- a/src/common/confline.c +++ b/src/common/confline.c @@ -294,24 +294,26 @@ config_process_include(const char *path, int recursion_level, int extended, return -1; } - SMARTLIST_FOREACH_BEGIN(config_files, char *, config_file) { + int rv = -1; + SMARTLIST_FOREACH_BEGIN(config_files, const char *, config_file) { config_line_t *included_list = NULL; if (config_get_included_list(config_file, recursion_level, extended, &included_list, list_last) < 0) { - SMARTLIST_FOREACH(config_files, char *, f, tor_free(f)); - smartlist_free(config_files); - return -1; + goto done; } - tor_free(config_file); *next = included_list; if (*list_last) next = &(*list_last)->next; } SMARTLIST_FOREACH_END(config_file); - smartlist_free(config_files); *list = ret_list; - return 0; + rv = 0; + + done: + SMARTLIST_FOREACH(config_files, char *, f, tor_free(f)); + smartlist_free(config_files); + return rv; } /** |