aboutsummaryrefslogtreecommitdiff
path: root/databases/foundationdb/files/patch-fdbmonitor_fdbmonitor.cpp
blob: 862461539f539463fe093b7b74550954c545ab70 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
--- fdbmonitor/fdbmonitor.cpp.orig	2022-09-19 11:42:41 UTC
+++ fdbmonitor/fdbmonitor.cpp
@@ -27,6 +27,8 @@
 
 #ifdef __linux__
 #include <sys/prctl.h>
+#elif defined(__FreeBSD__)
+#include <sys/procctl.h>
 #endif
 
 #include <sys/wait.h>
@@ -751,6 +753,10 @@ void start_process(Command* cmd, ProcessID id, uid_t u
 		signal(SIGHUP, SIG_DFL);
 		signal(SIGINT, SIG_DFL);
 		signal(SIGTERM, SIG_DFL);
+#ifdef __linux__
+		signal(SIGCHLD, SIG_DFL);
+#endif
+		sigprocmask(SIG_SETMASK, mask, nullptr);
 
 		/* All output in this block should be to stdout (for SevInfo messages) or stderr (for SevError messages) */
 		/* Using log_msg() or log_err() from the child will cause the logs to be written incorrectly */
@@ -780,13 +786,15 @@ void start_process(Command* cmd, ProcessID id, uid_t u
 		}
 
 #ifdef __linux__
-		signal(SIGCHLD, SIG_DFL);
-
-		sigprocmask(SIG_SETMASK, mask, nullptr);
-
 		/* death of our parent raises SIGHUP */
 		prctl(PR_SET_PDEATHSIG, SIGHUP);
 		if (getppid() == 1) /* parent already died before prctl */
+			exit(0);
+#elif defined(__FreeBSD__)
+		/* death of our parent raises SIGHUP */
+		const int sig = SIGHUP;
+		procctl(P_PID, 0, PROC_PDEATHSIG_CTL, (void*)&sig);
+		if (getppid() == 1) /* parent already died before procctl */
 			exit(0);
 #endif