diff options
author | Gerd Hoffmann <kraxel@redhat.com> | 2019-01-24 12:20:53 +0100 |
---|---|---|
committer | Gerd Hoffmann <kraxel@redhat.com> | 2019-01-24 13:11:08 +0100 |
commit | d175505bd68dc35150664a50f51eb9ec1eeee333 (patch) | |
tree | 0d83eeb84cd9f3373f316ea498200af1d936ea2c /audio/paaudio.c | |
parent | f92c7168cdb2a08e183b64f193cdd10535c68c2d (diff) |
audio: check for pulseaudio daemon pidfile
Check whenever the pulseaudio daemon pidfile is present before trying to
initialize the pulseaudio backend. Just return NULL if that is not the
case, so qemu will check the next backend in line.
In case the user explicitly configured a non-default pulseaudio server
skip the check.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Message-id: 20190124112055.547-5-kraxel@redhat.com
Diffstat (limited to 'audio/paaudio.c')
-rw-r--r-- | audio/paaudio.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/audio/paaudio.c b/audio/paaudio.c index 4c100bc318..6153b908da 100644 --- a/audio/paaudio.c +++ b/audio/paaudio.c @@ -814,6 +814,21 @@ static PAConf glob_conf = { static void *qpa_audio_init (void) { + if (glob_conf.server == NULL) { + char pidfile[64]; + char *runtime; + struct stat st; + + runtime = getenv("XDG_RUNTIME_DIR"); + if (!runtime) { + return NULL; + } + snprintf(pidfile, sizeof(pidfile), "%s/pulse/pid", runtime); + if (stat(pidfile, &st) != 0) { + return NULL; + } + } + paaudio *g = g_malloc(sizeof(paaudio)); g->conf = glob_conf; g->mainloop = NULL; |