]> code.delx.au - pulseaudio/commitdiff
autospawn: refuse autospawning if process disabled waitpid()
authorLennart Poettering <lennart@poettering.net>
Fri, 24 Jul 2009 16:22:13 +0000 (18:22 +0200)
committerLennart Poettering <lennart@poettering.net>
Fri, 24 Jul 2009 16:22:13 +0000 (18:22 +0200)
src/pulse/context.c

index 4ded556519bce1760ae17eb6ccfc2056907295af..ab1c163892f97757f70f0f5592aba02ac0c219c3 100644 (file)
@@ -668,11 +668,24 @@ static pa_strlist *prepend_per_user(pa_strlist *l) {
 static int context_autospawn(pa_context *c) {
     pid_t pid;
     int status, r;
-
-    pa_log_debug("Trying to autospawn...");
+    struct sigaction sa;
 
     pa_context_ref(c);
 
+    if (sigaction(SIGCHLD, NULL, &sa) < 0) {
+        pa_log_debug("sigaction() failed: %s", pa_cstrerror(errno));
+        pa_context_fail(c, PA_ERR_INTERNAL);
+        goto fail;
+    }
+
+    if ((sa.sa_flags & SA_NOCLDWAIT) || sa.sa_handler == SIG_IGN) {
+        pa_log_debug("Process disabled waitpid(), cannot autospawn.");
+        pa_context_fail(c, PA_ERR_CONNECTIONREFUSED);
+        goto fail;
+    }
+
+    pa_log_debug("Trying to autospawn...");
+
     if (c->spawn_api.prefork)
         c->spawn_api.prefork();