diff options
author | Kevin Mitchell <kevmitch@gmail.com> | 2016-02-26 10:36:40 -0800 |
---|---|---|
committer | Kevin Mitchell <kevmitch@gmail.com> | 2016-02-26 15:43:51 -0800 |
commit | af90616ebe973f3ed06cc1c502b23891e76e747a (patch) | |
tree | a20cd116d842cddd135974f5aa561e5d962dd778 | |
parent | 1841cac9f83c8f3a0ba589587e3b111ccdae09a1 (diff) |
ao_wasapi: move pre-resume reset into resume function
-rw-r--r-- | audio/out/ao_wasapi.c | 30 |
1 files changed, 14 insertions, 16 deletions
diff --git a/audio/out/ao_wasapi.c b/audio/out/ao_wasapi.c index 7d74cf2e2d..f472c7eeb6 100644 --- a/audio/out/ao_wasapi.c +++ b/audio/out/ao_wasapi.c @@ -147,21 +147,6 @@ exit_label: return false; } -static void thread_resume(struct ao *ao) -{ - struct wasapi_state *state = ao->priv; - HRESULT hr; - - MP_DBG(state, "Thread Resume\n"); - thread_feed(ao); - - hr = IAudioClient_Start(state->pAudioClient); - if (FAILED(hr)) { - MP_ERR(state, "IAudioClient_Start returned %s\n", - mp_HRESULT_to_str(hr)); - } -} - static void thread_reset(struct ao *ao) { struct wasapi_state *state = ao->priv; @@ -178,6 +163,20 @@ static void thread_reset(struct ao *ao) atomic_store(&state->sample_count, 0); } +static void thread_resume(struct ao *ao) +{ + struct wasapi_state *state = ao->priv; + MP_DBG(state, "Thread Resume\n"); + thread_reset(ao); + thread_feed(ao); + + HRESULT hr = IAudioClient_Start(state->pAudioClient); + if (FAILED(hr)) { + MP_ERR(state, "IAudioClient_Start returned %s\n", + mp_HRESULT_to_str(hr)); + } +} + static void thread_wakeup(void *ptr) { struct ao *ao = ptr; @@ -222,7 +221,6 @@ static DWORD __stdcall AudioThread(void *lpParameter) thread_reset(ao); break; case WASAPI_THREAD_RESUME: - thread_reset(ao); thread_resume(ao); break; case WASAPI_THREAD_SHUTDOWN: |