From 0d315ac668825bd7493129ecd6cf6717981ed522 Mon Sep 17 00:00:00 2001 From: Matthew Gregan Date: Thu, 6 Feb 2025 14:23:42 +0000 Subject: [PATCH] Bug 1944150 - Remove WASAPI stream shutdown timeout. r=cubeb-reviewers,padenot a=dmeehan Differential Revision: https://phabricator.services.mozilla.com/D236070 --- .../libcubeb/0005-remove-wasapi-timeout.patch | 33 +++++++++++++++++++ media/libcubeb/moz.yaml | 1 + media/libcubeb/src/cubeb_wasapi.cpp | 11 +------ 3 files changed, 35 insertions(+), 10 deletions(-) create mode 100644 media/libcubeb/0005-remove-wasapi-timeout.patch diff --git a/media/libcubeb/0005-remove-wasapi-timeout.patch b/media/libcubeb/0005-remove-wasapi-timeout.patch new file mode 100644 index 000000000000..396614052af2 --- /dev/null +++ b/media/libcubeb/0005-remove-wasapi-timeout.patch @@ -0,0 +1,33 @@ +From 2816b5a7b10899b8500352d6bd410a0f1a7699bf Mon Sep 17 00:00:00 2001 +From: Matthew Gregan +Date: Thu, 9 Jan 2025 10:36:24 +1300 +Subject: [PATCH] wasapi: Remove thread shutdown timeout. + +This was a workaround for rare pre-Windows 10 systems where the render +thread would hang inside OS API calls for multiple seconds. +--- + src/cubeb_wasapi.cpp | 11 +---------- + 1 file changed, 1 insertion(+), 10 deletions(-) + +diff --git a/src/cubeb_wasapi.cpp b/src/cubeb_wasapi.cpp +index f13c5ad7..d3786b68 100644 +--- a/src/cubeb_wasapi.cpp ++++ b/src/cubeb_wasapi.cpp +@@ -1780,16 +1780,7 @@ stop_and_join_render_thread(cubeb_stream * stm) + return false; + } + +- /* Wait five seconds for the rendering thread to return. It's supposed to +- * check its event loop very often, five seconds is rather conservative. +- * Note: 5*1s loop to work around timer sleep issues on pre-Windows 8. */ +- DWORD r; +- for (int i = 0; i < 5; ++i) { +- r = WaitForSingleObject(stm->thread, 1000); +- if (r == WAIT_OBJECT_0) { +- break; +- } +- } ++ DWORD r = WaitForSingleObject(stm->thread, INFINITE); + if (r != WAIT_OBJECT_0) { + LOG("stop_and_join_render_thread: WaitForSingleObject on thread failed: " + "%lx, %lx", diff --git a/media/libcubeb/moz.yaml b/media/libcubeb/moz.yaml index d617188b270c..69e8fc241150 100644 --- a/media/libcubeb/moz.yaml +++ b/media/libcubeb/moz.yaml @@ -21,6 +21,7 @@ vendoring: - 0002-disable-crash-reporter-death-test.patch - 0003-audiounit-ios-compile-fixes.patch - 0004-disable-cubeb_one_duplex_one_input-macos10.15.patch + - 0005-remove-wasapi-timeout.patch skip-vendoring-steps: - update-moz-build exclude: diff --git a/media/libcubeb/src/cubeb_wasapi.cpp b/media/libcubeb/src/cubeb_wasapi.cpp index 01417a52e333..eef58a228b49 100644 --- a/media/libcubeb/src/cubeb_wasapi.cpp +++ b/media/libcubeb/src/cubeb_wasapi.cpp @@ -1780,16 +1780,7 @@ stop_and_join_render_thread(cubeb_stream * stm) return false; } - /* Wait five seconds for the rendering thread to return. It's supposed to - * check its event loop very often, five seconds is rather conservative. - * Note: 5*1s loop to work around timer sleep issues on pre-Windows 8. */ - DWORD r; - for (int i = 0; i < 5; ++i) { - r = WaitForSingleObject(stm->thread, 1000); - if (r == WAIT_OBJECT_0) { - break; - } - } + DWORD r = WaitForSingleObject(stm->thread, INFINITE); if (r != WAIT_OBJECT_0) { LOG("stop_and_join_render_thread: WaitForSingleObject on thread failed: " "%lx, %lx",