[tor-commits] [tor/master] Merge remote-tracking branch 'tor-github/pr/1303' into maint-0.4.1
nickm at torproject.org
nickm at torproject.org
Tue Oct 22 16:15:43 UTC 2019
commit 9769df89fe5bd8ccd802064273cca09efddc2b02
Merge: c1bf4260b ebce7059f
Author: Nick Mathewson <nickm at torproject.org>
Date: Tue Oct 22 12:15:06 2019 -0400
Merge remote-tracking branch 'tor-github/pr/1303' into maint-0.4.1
changes/bug31594 | 5 +++
src/lib/err/backtrace.c | 2 +-
src/lib/err/torerr.c | 64 +++++++++++++++++++++++++++++++---
src/lib/err/torerr.h | 7 ++--
src/lib/err/torerr_sys.c | 5 ++-
src/lib/log/log.c | 85 +++++++++++++++++++++++++++++++++++++++------
src/lib/log/log.h | 1 +
src/lib/log/util_bug.c | 11 +++---
src/trunnel/trunnel-local.h | 1 +
9 files changed, 158 insertions(+), 23 deletions(-)
diff --cc src/lib/log/log.c
index 6667c2686,4adcc5cf5..ec7c2fa24
--- a/src/lib/log/log.c
+++ b/src/lib/log/log.c
@@@ -806,12 -831,33 +832,36 @@@ logs_free_all(void
}
/* We _could_ destroy the log mutex here, but that would screw up any logs
- * that happened between here and the end of execution. */
+ * that happened between here and the end of execution.
+ * If tor is re-initialized, log_mutex_initialized will still be 1. So we
+ * won't trigger any undefined behaviour by trying to re-initialize the
+ * log mutex. */
}
+ /** Close signal-safe log files.
+ * Closing the log files makes the process and OS flush log buffers.
+ *
+ * This function is safe to call from a signal handler. It should only be
+ * called when shutting down the log or err modules. It is currenly called
+ * by the err module, when terminating the process on an abnormal condition.
+ */
+ void
+ logs_close_sigsafe(void)
+ {
+ logfile_t *victim, *next;
+ /* We can't LOCK_LOGS() in a signal handler, because it may call
+ * signal-unsafe functions. And we can't deallocate memory, either. */
+ next = logfiles;
+ logfiles = NULL;
+ while (next) {
+ victim = next;
+ next = next->next;
+ if (victim->needs_close) {
+ close_log_sigsafe(victim);
+ }
+ }
+ }
+
/** Remove and free the log entry <b>victim</b> from the linked-list
* logfiles (it is probably present, but it might not be due to thread
* racing issues). After this function is called, the caller shouldn't
More information about the tor-commits
mailing list