wasapi: Handle return value of WaitForSingleObject

The wait could've failed for whatever reason, we should handle that.
This commit is contained in:
Nirbheek Chauhan 2018-04-10 05:13:17 +05:30
parent 0a518c9be1
commit 5409cd4920
2 changed files with 16 additions and 2 deletions

View file

@ -616,9 +616,16 @@ gst_wasapi_sink_write (GstAudioSink * asink, gpointer data, guint length)
GST_OBJECT_UNLOCK (self); GST_OBJECT_UNLOCK (self);
while (pending > 0) { while (pending > 0) {
DWORD dwWaitResult;
guint can_frames, have_frames, n_frames, write_len; guint can_frames, have_frames, n_frames, write_len;
WaitForSingleObject (self->event_handle, INFINITE); dwWaitResult = WaitForSingleObject (self->event_handle, INFINITE);
if (dwWaitResult != WAIT_OBJECT_0) {
GST_ERROR_OBJECT (self, "Error waiting for event handle: %x",
(guint) dwWaitResult);
length -= pending;
goto beach;
}
/* We have N frames to be written out */ /* We have N frames to be written out */
have_frames = pending / (self->mix_format->nBlockAlign); have_frames = pending / (self->mix_format->nBlockAlign);

View file

@ -565,10 +565,17 @@ gst_wasapi_src_read (GstAudioSrc * asrc, gpointer data, guint length,
GST_OBJECT_UNLOCK (self); GST_OBJECT_UNLOCK (self);
while (wanted > 0) { while (wanted > 0) {
DWORD dwWaitResult;
guint have_frames, n_frames, want_frames, read_len; guint have_frames, n_frames, want_frames, read_len;
/* Wait for data to become available */ /* Wait for data to become available */
WaitForSingleObject (self->event_handle, INFINITE); dwWaitResult = WaitForSingleObject (self->event_handle, INFINITE);
if (dwWaitResult != WAIT_OBJECT_0) {
GST_ERROR_OBJECT (self, "Error waiting for event handle: %x",
(guint) dwWaitResult);
length = 0;
goto beach;
}
hr = IAudioCaptureClient_GetBuffer (self->capture_client, hr = IAudioCaptureClient_GetBuffer (self->capture_client,
(BYTE **) & from, &have_frames, &flags, NULL, NULL); (BYTE **) & from, &have_frames, &flags, NULL, NULL);