From ad3b39ccf6afb25a37c4b84183fda61aa7976da6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Sun, 5 Apr 2020 23:41:37 +0200 Subject: [PATCH] pulse: periodically check if vchan connection is alive If the remote domain is killed, vchan may not get the notification. To avoid hanging process in such a case, periodically check if vchan connection is open (as other vchan applications do). This partially reverts d0fcc6ce396ce4a9417c22eec8f962aec7c2b25a. Fixes QubesOS/qubes-issues#5760 --- pulse/pacat-simple-vchan.c | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/pulse/pacat-simple-vchan.c b/pulse/pacat-simple-vchan.c index 8054c227..bcb78dd2 100644 --- a/pulse/pacat-simple-vchan.c +++ b/pulse/pacat-simple-vchan.c @@ -580,6 +580,24 @@ static void context_state_callback(pa_context *c, void *userdata) { } +static void check_vchan_eof_timer(pa_mainloop_api*a, pa_time_event* e, + const struct timeval *UNUSED(tv), void *userdata) +{ + struct userdata *u = userdata; + struct timeval restart_tv; + assert(u); + + if (!libvchan_is_open(u->play_ctrl)) { + pacat_log("vchan_is_eof (timer)"); + quit(u, 0); + return; + } + + pa_gettimeofday(&restart_tv); + pa_timeval_add(&restart_tv, (pa_usec_t) 5 * 1000 * PA_USEC_PER_MSEC); + a->time_restart(e, &restart_tv); +} + int main(int argc, char *argv[]) { struct timeval tv; @@ -680,6 +698,12 @@ int main(int argc, char *argv[]) pa_gettimeofday(&tv); pa_timeval_add(&tv, (pa_usec_t) 5 * 1000 * PA_USEC_PER_MSEC); + time_event = u.mainloop_api->time_new(u.mainloop_api, &tv, check_vchan_eof_timer, &u); + if (!time_event) { + pacat_log("time_event create failed"); + goto quit; + } + if (!(u.context = pa_context_new_with_proplist(u.mainloop_api, NULL, u.proplist))) { pacat_log("pa_context_new() failed."); goto quit;