From 8c22b91a70a7d354029e7d12ad4cb7c323efc9e9 Mon Sep 17 00:00:00 2001 From: Rusty Russell Date: Mon, 18 Feb 2019 12:00:00 +1030 Subject: [PATCH] lightningd: activate crashlog before forking off as daemon. This avoids cases like #2348 where the user gets *no* clue as to what went wrong. Signed-off-by: Rusty Russell --- lightningd/lightningd.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/lightningd/lightningd.c b/lightningd/lightningd.c index de14eb374..056ce3a92 100644 --- a/lightningd/lightningd.c +++ b/lightningd/lightningd.c @@ -764,6 +764,11 @@ int main(int argc, char *argv[]) * can start talking to us. */ plugins_config(ld->plugins); + /*~ Setting this (global) activates the crash log: we don't usually need + * a backtrace if we fail during startup. We do this before daemonize, + * in case that runs into trouble. */ + crashlog = ld->log; + /*~ We defer --daemon until we've completed most initialization: that * way we'll exit with an error rather than silently exiting 0, then * realizing we can't start and forcing the confused user to read the @@ -808,10 +813,6 @@ int main(int argc, char *argv[]) * can start the poll loop which queries bitcoind for new blocks. */ begin_topology(ld->topology); - /*~ Setting this (global) activates the crash log: we don't usually need - * a backtrace if we fail during startup. */ - crashlog = ld->log; - /*~ The root of every backtrace (almost). This is our main event * loop. */ for (;;) {