aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar Kevin Mitchell <kevmitch@gmail.com>2014-11-30 06:10:16 -0800
committerGravatar Kevin Mitchell <kevmitch@gmail.com>2014-12-01 03:40:24 -0800
commit146561cc9184fc8a17bd8cc857a8941fe2928132 (patch)
tree5bae20af7e1522dcb7a4734d5240c46f7eb573b3
parent524cdfc3f145afdd17f6cf7c204826094f756406 (diff)
ao/wasapi: fix set_ao_format
Before it used whatever was in ao->format and changed the bits even though this might have nothing to do with the actual WAVEFORMAT negotiated with WASAPI. For example, if the initial ao->format was a float and we had set the WAVEFORMAT to s24, this would create a non-existent float24 format. Worse, it might put an u16 into ao->format when WAVEFORMAT described s16. WASAPI doesn't support unsigned at all as far as I can tell.
-rwxr-xr-xaudio/out/ao_wasapi_utils.c33
1 files changed, 10 insertions, 23 deletions
diff --git a/audio/out/ao_wasapi_utils.c b/audio/out/ao_wasapi_utils.c
index 03e7ccad16..8d374dfca9 100755
--- a/audio/out/ao_wasapi_utils.c
+++ b/audio/out/ao_wasapi_utils.c
@@ -238,21 +238,8 @@ static void waveformat_copy(WAVEFORMATEXTENSIBLE* dst, WAVEFORMATEX* src)
dst->Format = *src;
}
-static int format_set_bits(int old_format, int bits, bool fp)
-{
- if (fp) {
- switch (bits) {
- case 64: return AF_FORMAT_DOUBLE;
- case 32: return AF_FORMAT_FLOAT;
- default: return 0;
- }
- }
-
- return af_fmt_change_bits(old_format, bits);
-}
-
static bool set_ao_format(struct ao *ao,
- WAVEFORMATEXTENSIBLE wformat)
+ WAVEFORMATEXTENSIBLE wformat)
{
struct wasapi_state *state = (struct wasapi_state *)ao->priv;
// explicitly disallow 8 bits - this will catch if the
@@ -261,16 +248,17 @@ static bool set_ao_format(struct ao *ao,
if (wformat.Format.wBitsPerSample < 16)
return false;
- bool is_float =
- !mp_GUID_compare(&mp_KSDATAFORMAT_SUBTYPE_IEEE_FLOAT, &wformat.SubFormat);
-
- if ( !is_float &&
- mp_GUID_compare(&mp_KSDATAFORMAT_SUBTYPE_PCM, &wformat.SubFormat) ) {
+ int format;
+ if ( !mp_GUID_compare(&mp_KSDATAFORMAT_SUBTYPE_IEEE_FLOAT, &wformat.SubFormat) ) {
+ format = AF_FORMAT_FLOAT;
+ } else if ( !mp_GUID_compare(&mp_KSDATAFORMAT_SUBTYPE_PCM, &wformat.SubFormat) ) {
+ format = AF_FORMAT_S32;
+ } else {
MP_ERR(ao, "Unknown SubFormat %s\n", mp_GUID_to_str(&wformat.SubFormat));
return false;
}
- int format = format_set_bits(ao->format, wformat.Format.wBitsPerSample, is_float);
-
+ // set the correct number of bits (the 32-bits assumed above may be wrong)
+ format = af_fmt_change_bits(format, wformat.Format.wBitsPerSample);
if (!format)
return false;
@@ -278,9 +266,8 @@ static bool set_ao_format(struct ao *ao,
ao->bps = wformat.Format.nAvgBytesPerSec;
ao->format = format;
- if (ao->channels.num != wformat.Format.nChannels) {
+ if (ao->channels.num != wformat.Format.nChannels)
mp_chmap_from_channels(&ao->channels, wformat.Format.nChannels);
- }
state->format = wformat;
return true;