diff options
author | Klaus Schmidinger <vdr@tvdr.de> | 2007-06-17 12:45:57 +0200 |
---|---|---|
committer | Klaus Schmidinger <vdr@tvdr.de> | 2007-06-17 12:45:57 +0200 |
commit | efbb48dbaf648caccd0a7591558252f8e00f0071 (patch) | |
tree | d6ae44924c27bef2ba4f627e2ba9d30dd26eedf7 | |
parent | 3ad941de73f411f42be4439aaf9e73837915376f (diff) | |
download | vdr-efbb48dbaf648caccd0a7591558252f8e00f0071.tar.gz vdr-efbb48dbaf648caccd0a7591558252f8e00f0071.tar.bz2 |
Fixed handling detached processes in SystemExec()
-rw-r--r-- | CONTRIBUTORS | 1 | ||||
-rw-r--r-- | HISTORY | 1 | ||||
-rw-r--r-- | thread.c | 8 |
3 files changed, 8 insertions, 2 deletions
diff --git a/CONTRIBUTORS b/CONTRIBUTORS index 77ddbaf8..9fdb083c 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -1497,6 +1497,7 @@ Udo Richter <udo_richter@gmx.de> up at a particular time for making the HUP signal force a restart of VDR for fixing a race condition with signal handlers at program exit + for fixing handling detached processes in SystemExec() Sven Kreiensen <svenk@kammer.uni-hannover.de> for his help in keeping 'channels.conf.terr' up to date @@ -5251,3 +5251,4 @@ Video Disk Recorder Revision History - Updated the Finnish OSD texts (thanks to Rolf Ahrenberg). - Changed the parameter "OSD font" to "Default font" in "Setup/OSD" (suggested by Rolf Ahrenberg). +- Fixed handling detached processes in SystemExec() (thanks to Udo Richter). @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: thread.c 1.60 2007/02/24 16:13:33 kls Exp $ + * $Id: thread.c 1.61 2007/06/17 12:43:40 kls Exp $ */ #include "thread.h" @@ -12,6 +12,7 @@ #include <linux/unistd.h> #include <malloc.h> #include <stdarg.h> +#include <stdlib.h> #include <sys/resource.h> #include <sys/syscall.h> #include <sys/time.h> @@ -507,7 +508,7 @@ int SystemExec(const char *Command, bool Detached) if (pid > 0) { // parent process int status = 0; - if (!Detached && waitpid(pid, &status, 0) < 0) { + if (waitpid(pid, &status, 0) < 0) { LOG_ERROR; return -1; } @@ -515,6 +516,9 @@ int SystemExec(const char *Command, bool Detached) } else { // child process if (Detached) { + // Fork again and let first child die - grandchild stays alive without parent + if (fork() > 0) + exit(0); // Start a new session pid_t sid = setsid(); if (sid < 0) |