summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
Diffstat (limited to 'src/or')
-rw-r--r--src/or/cpuworker.c2
-rw-r--r--src/or/dns.c2
-rw-r--r--src/or/main.c15
-rw-r--r--src/or/or.h1
4 files changed, 12 insertions, 8 deletions
diff --git a/src/or/cpuworker.c b/src/or/cpuworker.c
index 3a1a61a8ea..1f4f4aec1d 100644
--- a/src/or/cpuworker.c
+++ b/src/or/cpuworker.c
@@ -214,7 +214,7 @@ static int cpuworker_main(void *data) {
fd = fdarray[1]; /* this side is ours */
#ifndef TOR_IS_MULTITHREADED
tor_close_socket(fdarray[0]); /* this is the side of the socketpair the parent uses */
- connection_free_all(); /* so the child doesn't hold the parent's fd's open */
+ tor_free_all(1); /* so the child doesn't hold the parent's fd's open */
handle_signals(0); /* ignore interrupts from the keyboard, etc */
#endif
tor_free(data);
diff --git a/src/or/dns.c b/src/or/dns.c
index ff02efc050..805218f68e 100644
--- a/src/or/dns.c
+++ b/src/or/dns.c
@@ -721,7 +721,7 @@ static int dnsworker_main(void *data) {
fd = fdarray[1]; /* this side is ours */
#ifndef TOR_IS_MULTITHREADED
tor_close_socket(fdarray[0]); /* this is the side of the socketpair the parent uses */
- connection_free_all(); /* so the child doesn't hold the parent's fd's open */
+ connection_free_all(1); /* so the child doesn't hold the parent's fd's open */
handle_signals(0); /* ignore interrupts from the keyboard, etc */
#endif
tor_free(data);
diff --git a/src/or/main.c b/src/or/main.c
index 12e8536aad..1dbc396589 100644
--- a/src/or/main.c
+++ b/src/or/main.c
@@ -40,7 +40,6 @@ static void conn_write_callback(int fd, short event, void *_conn);
static void signal_callback(int fd, short events, void *arg);
static void second_elapsed_callback(int fd, short event, void *args);
static int conn_close_if_marked(int i);
-void tor_free_all(void);
/********* START VARIABLES **********/
@@ -1227,7 +1226,7 @@ static int tor_init(int argc, char *argv[]) {
*
* Also valgrind should then report 0 reachable in its
* leak report */
-void tor_free_all(void)
+void tor_free_all(int postfork)
{
routerlist_free_current();
free_trusted_dir_servers();
@@ -1242,13 +1241,17 @@ void tor_free_all(void)
clear_pending_onions();
circuit_free_all();
connection_free_all();
- config_free_all();
- router_free_all_keys();
+ if (!postfork) {
+ config_free_all();
+ router_free_all_keys();
+ }
tor_tls_free_all();
/* stuff in main.c */
smartlist_free(closeable_connection_lst);
- close_logs(); /* free log strings. do this last so logs keep working. */
+ if (!postfork) {
+ close_logs(); /* free log strings. do this last so logs keep working. */
+ }
}
/** Do whatever cleanup is necessary before shutting Tor down. */
@@ -1260,7 +1263,7 @@ void tor_cleanup(void) {
unlink(options->PidFile);
if (accounting_is_enabled(options))
accounting_record_bandwidth_usage(time(NULL));
- tor_free_all(); /* move tor_free_all back into the ifdef below later. XXX*/
+ tor_free_all(0); /* move tor_free_all back into the ifdef below later. XXX*/
crypto_global_cleanup();
#ifdef USE_DMALLOC
dmalloc_log_unfreed();
diff --git a/src/or/or.h b/src/or/or.h
index a83907d6ed..f778daf72f 100644
--- a/src/or/or.h
+++ b/src/or/or.h
@@ -1543,6 +1543,7 @@ void directory_has_arrived(time_t now, char *identity_digest);
int control_signal_act(int the_signal);
void handle_signals(int is_parent);
void tor_cleanup(void);
+void tor_free_all(int postfork);
int tor_main(int argc, char *argv[]);