Zbigniew Jędrzejewski-Szmek d66047
From 246592d8f7eaf899ec6292cac4985f7bcc8b65fd Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek d66047
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek d66047
Date: Wed, 20 Nov 2013 22:11:10 +0100
Zbigniew Jędrzejewski-Szmek d66047
Subject: [PATCH] valgrind: make running PID 1 in valgrind useful
Zbigniew Jędrzejewski-Szmek d66047
Zbigniew Jędrzejewski-Szmek d66047
Since valgrind only generates useful output on exit() (rather than
Zbigniew Jędrzejewski-Szmek d66047
exec()) we need to explicitly exit when valgrind is detected.
Zbigniew Jędrzejewski-Szmek d66047
Zbigniew Jędrzejewski-Szmek d66047
Conflicts:
Zbigniew Jędrzejewski-Szmek d66047
	src/core/main.c
Zbigniew Jędrzejewski-Szmek d66047
---
Zbigniew Jędrzejewski-Szmek d66047
 configure.ac    |  2 +-
Zbigniew Jędrzejewski-Szmek d66047
 src/core/main.c | 13 +++++++++++++
Zbigniew Jędrzejewski-Szmek d66047
 2 files changed, 14 insertions(+), 1 deletion(-)
Zbigniew Jędrzejewski-Szmek d66047
Zbigniew Jędrzejewski-Szmek d66047
diff --git a/configure.ac b/configure.ac
Zbigniew Jędrzejewski-Szmek d66047
index 9904e25..6232cf8 100644
Zbigniew Jędrzejewski-Szmek d66047
--- a/configure.ac
Zbigniew Jędrzejewski-Szmek d66047
+++ b/configure.ac
Zbigniew Jędrzejewski-Szmek d66047
@@ -814,7 +814,7 @@ AC_DEFINE_UNQUOTED(TELINIT, ["$TELINIT"], [Path to telinit])
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
 AC_SUBST(TELINIT)
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
-AC_CHECK_HEADERS_ONCE([valgrind/memcheck.h])
Zbigniew Jędrzejewski-Szmek d66047
+AC_CHECK_HEADERS_ONCE([valgrind/memcheck.h valgrind/valgrind.h])
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
 # ------------------------------------------------------------------------------
Zbigniew Jędrzejewski-Szmek d66047
 have_myhostname=no
Zbigniew Jędrzejewski-Szmek d66047
diff --git a/src/core/main.c b/src/core/main.c
Zbigniew Jędrzejewski-Szmek d66047
index 00fd394..58c3a9e 100644
Zbigniew Jędrzejewski-Szmek d66047
--- a/src/core/main.c
Zbigniew Jędrzejewski-Szmek d66047
+++ b/src/core/main.c
Zbigniew Jędrzejewski-Szmek d66047
@@ -34,6 +34,10 @@
Zbigniew Jędrzejewski-Szmek d66047
 #include <sys/prctl.h>
Zbigniew Jędrzejewski-Szmek d66047
 #include <sys/mount.h>
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
+#ifdef HAVE_VALGRIND_VALGRIND_H
Zbigniew Jędrzejewski-Szmek d66047
+#include <valgrind/valgrind.h>
Zbigniew Jędrzejewski-Szmek d66047
+#endif
Zbigniew Jędrzejewski-Szmek d66047
+
Zbigniew Jędrzejewski-Szmek d66047
 #include "manager.h"
Zbigniew Jędrzejewski-Szmek d66047
 #include "log.h"
Zbigniew Jędrzejewski-Szmek d66047
 #include "load-fragment.h"
Zbigniew Jędrzejewski-Szmek d66047
@@ -1855,6 +1859,15 @@ finish:
Zbigniew Jędrzejewski-Szmek d66047
         if (fds)
Zbigniew Jędrzejewski-Szmek d66047
                 fdset_free(fds);
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
+#ifdef HAVE_VALGRIND_VALGRIND_H
Zbigniew Jędrzejewski-Szmek d66047
+        /* If we are PID 1 and running under valgrind, then let's exit
Zbigniew Jędrzejewski-Szmek d66047
+         * here explicitly. valgrind will only generate nice output on
Zbigniew Jędrzejewski-Szmek d66047
+         * exit(), not on exec(), hence let's do the former not the
Zbigniew Jędrzejewski-Szmek d66047
+         * latter here. */
Zbigniew Jędrzejewski-Szmek d66047
+        if (getpid() == 1 && RUNNING_ON_VALGRIND)
Zbigniew Jędrzejewski-Szmek d66047
+                return 0;
Zbigniew Jędrzejewski-Szmek d66047
+#endif
Zbigniew Jędrzejewski-Szmek d66047
+
Zbigniew Jędrzejewski-Szmek d66047
         if (shutdown_verb) {
Zbigniew Jędrzejewski-Szmek d66047
                 const char * command_line[] = {
Zbigniew Jędrzejewski-Szmek d66047
                         SYSTEMD_SHUTDOWN_BINARY_PATH,