From 4987c1906d26745cb6a69449f6aa579387e1d9fe Mon Sep 17 00:00:00 2001 From: Kevin Mitchell Date: Wed, 1 Apr 2015 02:20:12 -0700 Subject: [PATCH] ao_wasapi: abstract HRESULT_to_str --- audio/out/ao_wasapi.c | 33 +++------ audio/out/ao_wasapi_changenotify.c | 2 +- audio/out/ao_wasapi_utils.c | 107 ++++++++++++++--------------- audio/out/ao_wasapi_utils.h | 4 +- 4 files changed, 67 insertions(+), 79 deletions(-) diff --git a/audio/out/ao_wasapi.c b/audio/out/ao_wasapi.c index afd606f5c5..a08364ad29 100644 --- a/audio/out/ao_wasapi.c +++ b/audio/out/ao_wasapi.c @@ -63,8 +63,7 @@ static HRESULT get_device_delay(struct wasapi_state *state, double *delay) { return S_OK; exit_label: - MP_ERR(state, "Error getting device delay: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error getting device delay: %s\n", mp_HRESULT_to_str(hr)); return hr; } @@ -106,8 +105,7 @@ static void thread_feed(struct ao *ao) return; exit_label: - MP_ERR(state, "Error feeding audio: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error feeding audio: %s\n", mp_HRESULT_to_str(hr)); MP_VERBOSE(ao, "Requesting ao reload\n"); ao_request_reload(ao); return; @@ -122,8 +120,8 @@ static void thread_resume(struct ao *ao) UINT32 padding = 0; hr = IAudioClient_GetCurrentPadding(state->pAudioClient, &padding); if (hr != S_OK) { - MP_ERR(state, "IAudioClient_GetCurrentPadding returned %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "IAudioClient_GetCurrentPadding returned %s\n", + mp_HRESULT_to_str(hr)); } /* Fill the buffer before starting, but only if there is no audio queued to play. */ @@ -132,10 +130,8 @@ static void thread_resume(struct ao *ao) thread_feed(ao); hr = IAudioClient_Start(state->pAudioClient); - if (hr != S_OK) { - MP_ERR(state, "IAudioClient_Start returned %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); - } + if (hr != S_OK) + MP_ERR(state, "IAudioClient_Start returned %s\n", mp_HRESULT_to_str(hr)); return; } @@ -147,19 +143,13 @@ static void thread_reset(struct ao *ao) MP_DBG(state, "Thread Reset\n"); hr = IAudioClient_Stop(state->pAudioClient); /* we may get S_FALSE if the stream is already stopped */ - if (hr != S_OK && - hr != S_FALSE) { - MP_ERR(state, "IAudioClient_Stop returned: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); - } + if (hr != S_OK && hr != S_FALSE) + MP_ERR(state, "IAudioClient_Stop returned: %s\n", mp_HRESULT_to_str(hr)); /* we may get S_FALSE if the stream is already reset */ hr = IAudioClient_Reset(state->pAudioClient); - if (hr != S_OK && - hr != S_FALSE) { - MP_ERR(state, "IAudioClient_Reset returned: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); - } + if (hr != S_OK && hr != S_FALSE) + MP_ERR(state, "IAudioClient_Reset returned: %s\n", mp_HRESULT_to_str(hr)); atomic_store(&state->sample_count, 0); return; @@ -408,8 +398,7 @@ static int hotplug_init(struct ao *ao) return 0; exit_label: - MP_ERR(state, "Error setting up audio hotplug: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error setting up audio hotplug: %s\n", mp_HRESULT_to_str(hr)); hotplug_uninit(ao); return -1; } diff --git a/audio/out/ao_wasapi_changenotify.c b/audio/out/ao_wasapi_changenotify.c index 83def775d3..1521578b19 100755 --- a/audio/out/ao_wasapi_changenotify.c +++ b/audio/out/ao_wasapi_changenotify.c @@ -227,7 +227,7 @@ HRESULT wasapi_change_init(struct ao *ao, bool is_hotplug) return hr; exit_label: MP_ERR(state, "Error setting up device change monitoring: %s\n", - wasapi_explain_err(hr)); + mp_HRESULT_to_str(hr)); wasapi_change_uninit(ao); return hr; } diff --git a/audio/out/ao_wasapi_utils.c b/audio/out/ao_wasapi_utils.c index c82fe149a2..e8bf1df92e 100755 --- a/audio/out/ao_wasapi_utils.c +++ b/audio/out/ao_wasapi_utils.c @@ -63,36 +63,7 @@ char *mp_PKEY_to_str_buf(char *buf, size_t buf_size, const PROPERTYKEY *pkey) return buf; } -bool wasapi_fill_VistaBlob(wasapi_state *state) -{ - if (!state) - goto exit_label; - state->VistaBlob.hAvrt = LoadLibraryW(L"avrt.dll"); - if (!state->VistaBlob.hAvrt) - goto exit_label; - - state->VistaBlob.pAvSetMmThreadCharacteristicsW = - (HANDLE (WINAPI *)(LPCWSTR, LPDWORD)) - GetProcAddress(state->VistaBlob.hAvrt, "AvSetMmThreadCharacteristicsW"); - if (!state->VistaBlob.pAvSetMmThreadCharacteristicsW) - goto exit_label; - - state->VistaBlob.pAvRevertMmThreadCharacteristics = - (WINBOOL (WINAPI *)(HANDLE)) - GetProcAddress(state->VistaBlob.hAvrt, "AvRevertMmThreadCharacteristics"); - if (!state->VistaBlob.pAvRevertMmThreadCharacteristics) - goto exit_label; - - return true; -exit_label: - if (state->VistaBlob.hAvrt) { - FreeLibrary(state->VistaBlob.hAvrt); - state->VistaBlob.hAvrt = NULL; - } - return false; -} - -const char *wasapi_explain_err(const HRESULT hr) +static char *wasapi_explain_err(const HRESULT hr) { #define E(x) case x : return # x ; switch (hr) { @@ -144,6 +115,42 @@ const char *wasapi_explain_err(const HRESULT hr) #undef E } +char *mp_HRESULT_to_str_buf(char *buf, size_t buf_size, HRESULT hr) +{ + snprintf(buf,buf_size,"%s (0x%"PRIx32")", + wasapi_explain_err(hr), (uint32_t) hr); + return buf; +} + +bool wasapi_fill_VistaBlob(wasapi_state *state) +{ + if (!state) + goto exit_label; + state->VistaBlob.hAvrt = LoadLibraryW(L"avrt.dll"); + if (!state->VistaBlob.hAvrt) + goto exit_label; + + state->VistaBlob.pAvSetMmThreadCharacteristicsW = + (HANDLE (WINAPI *)(LPCWSTR, LPDWORD)) + GetProcAddress(state->VistaBlob.hAvrt, "AvSetMmThreadCharacteristicsW"); + if (!state->VistaBlob.pAvSetMmThreadCharacteristicsW) + goto exit_label; + + state->VistaBlob.pAvRevertMmThreadCharacteristics = + (WINBOOL (WINAPI *)(HANDLE)) + GetProcAddress(state->VistaBlob.hAvrt, "AvRevertMmThreadCharacteristics"); + if (!state->VistaBlob.pAvRevertMmThreadCharacteristics) + goto exit_label; + + return true; +exit_label: + if (state->VistaBlob.hAvrt) { + FreeLibrary(state->VistaBlob.hAvrt); + state->VistaBlob.hAvrt = NULL; + } + return false; +} + static void update_waveformat_datarate_pcm(WAVEFORMATEXTENSIBLE *wformat) { WAVEFORMATEX *wf = &wformat->Format; @@ -348,8 +355,7 @@ static bool try_format_exclusive(struct ao *ao, WAVEFORMATEXTENSIBLE *wformat) return hr == S_OK; exit_label: - MP_ERR(state, "Error testing exclusive format: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error testing exclusive format: %s\n", mp_HRESULT_to_str(hr)); return false; } @@ -524,8 +530,7 @@ static bool find_formats_shared(struct ao *ao) af_fmt_to_str(ao->format), ao->samplerate); return true; exit_label: - MP_ERR(state, "Error finding shared mode format: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error finding shared mode format: %s\n", mp_HRESULT_to_str(hr)); return false; } @@ -602,8 +607,8 @@ static HRESULT init_clock(struct wasapi_state *state) { return S_OK; exit_label: - MP_ERR(state, "Error obtaining the audio device's timing: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error obtaining the audio device's timing: %s\n", + mp_HRESULT_to_str(hr)); return hr; } @@ -625,8 +630,8 @@ static HRESULT init_session_display(struct wasapi_state *state) { return S_OK; exit_label: - MP_WARN(state, "Error setting audio session display name: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_WARN(state, "Error setting audio session display name: %s\n", + mp_HRESULT_to_str(hr)); return S_OK; // No reason to abort initialization. } @@ -665,8 +670,8 @@ reinit: } else { retries ++; } - MP_VERBOSE(state, "IAudioClient::Initialize negotiation failed with %s (0x%"PRIx32"), used %lld * 100ns\n", - wasapi_explain_err(hr), (uint32_t) hr, bufferDuration); + MP_VERBOSE(state, "IAudioClient::Initialize negotiation failed with %s, used %lld * 100ns\n", + mp_HRESULT_to_str(hr), bufferDuration); IAudioClient_GetBufferSize(state->pAudioClient, &state->bufferFrameCount); bufferPeriod = bufferDuration = @@ -729,8 +734,7 @@ reinit: return S_OK; exit_label: - MP_ERR(state, "Error initializing device: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error initializing device: %s\n", mp_HRESULT_to_str(hr)); return hr; } @@ -865,8 +869,7 @@ void wasapi_list_devs(struct ao *ao, struct ao_device_list *list) return; exit_label: - MP_ERR(ao, "Error enumerating devices: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(ao, "Error enumerating devices: %s\n", mp_HRESULT_to_str(hr)); talloc_free(name); talloc_free(id); SAFE_RELEASE(pDevice, IMMDevice_Release(pDevice)); @@ -887,8 +890,7 @@ static HRESULT load_default_device(struct ao *ao, IMMDeviceEnumerator* pEnumerat return S_OK; exit_label: - MP_ERR(ao , "Error loading default device: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(ao , "Error loading default device: %s\n", mp_HRESULT_to_str(hr)); return hr; } @@ -1017,8 +1019,7 @@ HRESULT wasapi_setup_proxies(struct wasapi_state *state) { return S_OK; exit_label: - MP_ERR(state, "Error reading COM proxy: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error reading COM proxy: %s\n", mp_HRESULT_to_str(hr)); return hr; } @@ -1046,8 +1047,7 @@ static HRESULT create_proxies(struct wasapi_state *state) { return S_OK; exit_label: - MP_ERR(state, "Error creating COM proxy: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error creating COM proxy: %s\n", mp_HRESULT_to_str(hr)); return hr; } @@ -1108,8 +1108,8 @@ retry: hr = IAudioEndpointVolume_QueryHardwareSupport(state->pEndpointVolume, &state->vol_hw_support); if (hr != S_OK) { - MP_WARN(ao, "Error querying hardware volume control: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_WARN(ao, "Error querying hardware volume control: %s\n", + mp_HRESULT_to_str(hr)); } MP_DBG(ao, "Probing formats\n"); @@ -1151,8 +1151,7 @@ retry: MP_DBG(ao, "Init wasapi thread done\n"); return S_OK; exit_label: - MP_ERR(state, "Error setting up audio thread: %s (0x%"PRIx32")\n", - wasapi_explain_err(hr), (uint32_t) hr); + MP_ERR(state, "Error setting up audio thread: %s\n", mp_HRESULT_to_str(hr)); return hr; } diff --git a/audio/out/ao_wasapi_utils.h b/audio/out/ao_wasapi_utils.h index c0eb77388d..330a502046 100755 --- a/audio/out/ao_wasapi_utils.h +++ b/audio/out/ao_wasapi_utils.h @@ -29,13 +29,13 @@ char *mp_GUID_to_str_buf(char *buf, size_t buf_size, const GUID *guid); char *mp_PKEY_to_str_buf(char *buf, size_t buf_size, const PROPERTYKEY *pkey); +char *mp_HRESULT_to_str_buf(char *buf, size_t buf_size, HRESULT hr); #define mp_GUID_to_str(guid) mp_GUID_to_str_buf((char[40]){0}, 40, (guid)) #define mp_PKEY_to_str(pkey) mp_PKEY_to_str_buf((char[42]){0}, 42, (pkey)) +#define mp_HRESULT_to_str(hr) mp_HRESULT_to_str_buf((char[60]){0}, 60, (hr)) bool wasapi_fill_VistaBlob(wasapi_state *state); -const char *wasapi_explain_err(const HRESULT hr); - void wasapi_list_devs(struct ao *ao, struct ao_device_list *list); void wasapi_dispatch(void);