diff --git a/Makefile.common b/Makefile.common
index 468b5493d0..f10309deb4 100644
--- a/Makefile.common
+++ b/Makefile.common
@@ -660,6 +660,7 @@ ifeq ($(HAVE_DSOUND), 1)
endif
ifeq ($(HAVE_WASAPI), 1)
+ HAVE_MMDEVICE_COMMON = 1
OBJ += audio/drivers/wasapi.o
DEFINES += -DHAVE_WASAPI
LIBS += -lole32 -lksuser
@@ -671,6 +672,10 @@ ifeq ($(HAVE_XAUDIO), 1)
LIBS += -lole32
endif
+ifeq ($(HAVE_MMDEVICE_COMMON), 1)
+ OBJ += audio/common/mmdevice_common.o
+endif
+
ifeq ($(HAVE_WINMM), 1)
OBJ += midi/drivers/winmm_midi.o
DEFINES += -DHAVE_WINMM
diff --git a/audio/common/mmdevice_common.c b/audio/common/mmdevice_common.c
new file mode 100644
index 0000000000..56623bdc96
--- /dev/null
+++ b/audio/common/mmdevice_common.c
@@ -0,0 +1,166 @@
+/* RetroArch - A frontend for libretro.
+ * Copyright (C) 2011-2017 - Daniel De Matteis
+ *
+ * RetroArch is free software: you can redistribute it and/or modify it under the terms
+ * of the GNU General Public License as published by the Free Software Found-
+ * ation, either version 3 of the License, or (at your option) any later version.
+ *
+ * RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+ * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * PURPOSE. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along with RetroArch.
+ * If not, see .
+ */
+
+#include
+
+#include
+#include
+
+#include "mmdevice_common.h"
+
+#include "../../retroarch.h"
+#include "../../verbosity.h"
+#include "../../configuration.h"
+
+void *mmdevice_list_new(void *u)
+{
+ HRESULT hr;
+ UINT i;
+ PROPVARIANT prop_var;
+ int ir;
+ union string_list_elem_attr attr;
+ IMMDeviceEnumerator *enumerator = NULL;
+ IMMDeviceCollection *collection = NULL;
+ UINT dev_count = 0;
+ IMMDevice *device = NULL;
+ LPWSTR dev_id_wstr = NULL;
+ IPropertyStore *prop_store = NULL;
+ bool prop_var_init = false;
+ bool br = false;
+ char *dev_id_str = NULL;
+ char *dev_name_str = NULL;
+ struct string_list *sl = string_list_new();
+
+ if (!sl)
+ return NULL;
+
+ attr.i = 0;
+#ifdef __cplusplus
+ hr = CoCreateInstance(CLSID_MMDeviceEnumerator, NULL, CLSCTX_ALL,
+ IID_IMMDeviceEnumerator, (void **)&enumerator);
+#else
+ hr = CoCreateInstance(&CLSID_MMDeviceEnumerator, NULL, CLSCTX_ALL,
+ &IID_IMMDeviceEnumerator, (void **)&enumerator);
+#endif
+ if (FAILED(hr))
+ goto error;
+
+ hr = _IMMDeviceEnumerator_EnumAudioEndpoints(enumerator,
+ eRender, DEVICE_STATE_ACTIVE, &collection);
+ if (FAILED(hr))
+ goto error;
+
+ hr = _IMMDeviceCollection_GetCount(collection, &dev_count);
+ if (FAILED(hr))
+ goto error;
+
+ for (i = 0; i < dev_count; ++i)
+ {
+ hr = _IMMDeviceCollection_Item(collection, i, &device);
+ if (FAILED(hr))
+ goto error;
+
+ hr = _IMMDevice_GetId(device, &dev_id_wstr);
+ if (FAILED(hr))
+ goto error;
+
+ ir = WideCharToMultiByte(CP_ACP, 0, dev_id_wstr, -1,
+ NULL, 0, NULL, NULL);
+ if (!ir)
+ goto error;
+
+ dev_id_str = (char *)malloc(ir);
+ if (!dev_id_str)
+ goto error;
+
+ ir = WideCharToMultiByte(CP_ACP, 0, dev_id_wstr, -1,
+ dev_id_str, ir, NULL, NULL);
+ if (!ir)
+ goto error;
+
+ hr = _IMMDevice_OpenPropertyStore(device, STGM_READ, &prop_store);
+ if (FAILED(hr))
+ goto error;
+
+ PropVariantInit(&prop_var);
+ prop_var_init = true;
+ hr = _IPropertyStore_GetValue(prop_store, PKEY_Device_FriendlyName,
+ &prop_var);
+ if (FAILED(hr))
+ goto error;
+
+ ir = WideCharToMultiByte(CP_ACP, 0, prop_var.pwszVal, -1,
+ NULL, 0, NULL, NULL);
+ if (!ir)
+ goto error;
+
+ dev_name_str = (char *)malloc(ir);
+ if (!dev_name_str)
+ goto error;
+
+ ir = WideCharToMultiByte(CP_ACP, 0, prop_var.pwszVal, -1,
+ dev_name_str, ir, NULL, NULL);
+ if (!ir)
+ goto error;
+
+ RARCH_LOG("[WASAPI]: %s %s\n", dev_name_str, dev_id_str);
+
+ br = string_list_append(sl, dev_id_str, attr);
+ if (!br)
+ goto error;
+
+ PropVariantClear(&prop_var);
+ prop_var_init = false;
+ if (dev_id_wstr)
+ CoTaskMemFree(dev_id_wstr);
+ if (dev_id_str)
+ free(dev_id_str);
+ if (dev_name_str)
+ free(dev_name_str);
+ dev_id_str = NULL;
+ dev_name_str = NULL;
+ dev_id_wstr = NULL;
+ IFACE_RELEASE(prop_store);
+ IFACE_RELEASE(device);
+ }
+
+ IFACE_RELEASE(collection);
+ IFACE_RELEASE(enumerator);
+
+ return sl;
+
+error:
+ if (dev_id_str)
+ free(dev_id_str);
+ if (dev_name_str)
+ free(dev_name_str);
+ dev_id_str = NULL;
+ dev_name_str = NULL;
+ if (prop_var_init)
+ PropVariantClear(&prop_var);
+ IFACE_RELEASE(prop_store);
+ if (dev_id_wstr)
+ CoTaskMemFree(dev_id_wstr);
+ dev_id_wstr = NULL;
+ IFACE_RELEASE(device);
+ IFACE_RELEASE(collection);
+ IFACE_RELEASE(enumerator);
+ if (sl)
+ string_list_free(sl);
+
+ RARCH_ERR("[WASAPI]: Device enumeration failed.\n");
+
+ return NULL;
+}
diff --git a/audio/common/mmdevice_common.h b/audio/common/mmdevice_common.h
new file mode 100644
index 0000000000..f3228e3b51
--- /dev/null
+++ b/audio/common/mmdevice_common.h
@@ -0,0 +1,120 @@
+/* RetroArch - A frontend for libretro.
+ * Copyright (C) 2011-2017 - Daniel De Matteis
+ *
+ * RetroArch is free software: you can redistribute it and/or modify it under the terms
+ * of the GNU General Public License as published by the Free Software Found-
+ * ation, either version 3 of the License, or (at your option) any later version.
+ *
+ * RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+ * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * PURPOSE. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along with RetroArch.
+ * If not, see .
+ */
+
+#ifndef _MMDEVICE_COMMON_H
+#define _MMDEVICE_COMMON_H
+
+#include
+
+#ifdef _WIN32_WINNT
+#undef _WIN32_WINNT
+#endif
+#define _WIN32_WINNT 0x0600
+#define WIN32_LEAN_AND_MEAN
+
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+
+#include
+
+#ifdef _MSC_VER
+DEFINE_GUID(IID_IAudioClient, 0x1CB9AD4C, 0xDBFA, 0x4C32, 0xB1, 0x78, 0xC2, 0xF5, 0x68, 0xA7, 0x03, 0xB2);
+DEFINE_GUID(IID_IAudioRenderClient, 0xF294ACFC, 0x3146, 0x4483, 0xA7, 0xBF, 0xAD, 0xDC, 0xA7, 0xC2, 0x60, 0xE2);
+DEFINE_GUID(IID_IMMDeviceEnumerator, 0xA95664D2, 0x9614, 0x4F35, 0xA7, 0x46, 0xDE, 0x8D, 0xB6, 0x36, 0x17, 0xE6);
+DEFINE_GUID(CLSID_MMDeviceEnumerator, 0xBCDE0395, 0xE52F, 0x467C, 0x8E, 0x3D, 0xC4, 0x57, 0x92, 0x91, 0x69, 0x2E);
+#undef KSDATAFORMAT_SUBTYPE_IEEE_FLOAT
+DEFINE_GUID(KSDATAFORMAT_SUBTYPE_IEEE_FLOAT, 0x00000003, 0x0000, 0x0010, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71);
+#endif
+
+DEFINE_PROPERTYKEY(PKEY_Device_FriendlyName, 0xa45c254e, 0xdf1c, 0x4efd, 0x80, 0x20, 0x67, 0xd1, 0x46, 0xa8, 0x50, 0xe0, 14); /* DEVPROP_TYPE_STRING */
+
+#ifdef __cplusplus
+#define _IMMDeviceCollection_Item(This,nDevice,ppdevice) (This)->Item(nDevice,ppdevice)
+#define _IAudioClient_Start(This) ( (This)->Start() )
+#define _IAudioClient_Stop(This) ( (This)->Stop() )
+#define _IAudioClient_GetCurrentPadding(This,pNumPaddingFrames) \
+ ( (This)->GetCurrentPadding(pNumPaddingFrames) )
+#define _IAudioRenderClient_GetBuffer(This,NumFramesRequested,ppData) \
+ ( (This)->GetBuffer(NumFramesRequested,ppData) )
+#define _IAudioRenderClient_ReleaseBuffer(This,NumFramesWritten,dwFlags) \
+ ( (This)->ReleaseBuffer(NumFramesWritten,dwFlags) )
+#define _IAudioClient_GetService(This,riid,ppv) ( (This)->GetService(riid,ppv) )
+#define _IAudioClient_SetEventHandle(This,eventHandle) ( (This)->SetEventHandle(eventHandle) )
+#define _IAudioClient_GetBufferSize(This,pNumBufferFrames) ( (This)->GetBufferSize(pNumBufferFrames) )
+#define _IAudioClient_GetStreamLatency(This,phnsLatency) ( (This)->GetStreamLatency(phnsLatency) )
+#define _IAudioClient_GetDevicePeriod(This,phnsDefaultDevicePeriod,phnsMinimumDevicePeriod) ( (This)->GetDevicePeriod(phnsDefaultDevicePeriod,phnsMinimumDevicePeriod) )
+#define _IMMDevice_Activate(This,iid,dwClsCtx,pActivationParams,ppv) ((This)->Activate(iid,(dwClsCtx),pActivationParams,ppv))
+#define _IMMDeviceEnumerator_EnumAudioEndpoints(This,dataFlow,dwStateMask,ppDevices) (This)->EnumAudioEndpoints(dataFlow,dwStateMask,ppDevices)
+#define _IMMDeviceEnumerator_GetDefaultAudioEndpoint(This,dataFlow,role,ppEndpoint) (This)->GetDefaultAudioEndpoint(dataFlow,role,ppEndpoint)
+#define _IMMDevice_OpenPropertyStore(This,stgmAccess,ppProperties) (This)->OpenPropertyStore(stgmAccess,ppProperties)
+#define _IMMDevice_GetId(This,ppstrId) ((This)->GetId(ppstrId))
+#define _IPropertyStore_GetValue(This,key,pv) ( (This)->GetValue(key,pv) )
+#define _IMMDeviceCollection_GetCount(This,cProps) ( (This)->GetCount(cProps) )
+#else
+#define _IMMDeviceCollection_Item(This,nDevice,ppdevice) (This)->lpVtbl->Item(This,nDevice,ppdevice)
+#define _IAudioClient_Start(This) ( (This)->lpVtbl -> Start(This) )
+#define _IAudioClient_Stop(This) ( (This)->lpVtbl -> Stop(This) )
+#define _IAudioClient_GetCurrentPadding(This,pNumPaddingFrames) \
+ ( (This)->lpVtbl -> GetCurrentPadding(This,pNumPaddingFrames) )
+#define _IAudioRenderClient_GetBuffer(This,NumFramesRequested,ppData) \
+ ( (This)->lpVtbl -> GetBuffer(This,NumFramesRequested,ppData) )
+#define _IAudioRenderClient_ReleaseBuffer(This,NumFramesWritten,dwFlags) \
+ ( (This)->lpVtbl -> ReleaseBuffer(This,NumFramesWritten,dwFlags) )
+#define _IAudioClient_GetService(This,riid,ppv) ( (This)->lpVtbl -> GetService(This,&(riid),ppv) )
+#define _IAudioClient_SetEventHandle(This,eventHandle) ( (This)->lpVtbl -> SetEventHandle(This,eventHandle) )
+#define _IAudioClient_GetBufferSize(This,pNumBufferFrames) ( (This)->lpVtbl -> GetBufferSize(This,pNumBufferFrames) )
+#define _IAudioClient_GetStreamLatency(This,phnsLatency) ( (This)->lpVtbl -> GetStreamLatency(This,phnsLatency) )
+#define _IAudioClient_GetDevicePeriod(This,phnsDefaultDevicePeriod,phnsMinimumDevicePeriod) ( (This)->lpVtbl -> GetDevicePeriod(This,phnsDefaultDevicePeriod,phnsMinimumDevicePeriod) )
+#define _IMMDevice_Activate(This,iid,dwClsCtx,pActivationParams,ppv) ((This)->lpVtbl->Activate(This,&(iid),dwClsCtx,pActivationParams,ppv))
+#define _IMMDeviceEnumerator_EnumAudioEndpoints(This,dataFlow,dwStateMask,ppDevices) (This)->lpVtbl->EnumAudioEndpoints(This,dataFlow,dwStateMask,ppDevices)
+#define _IMMDeviceEnumerator_GetDefaultAudioEndpoint(This,dataFlow,role,ppEndpoint) (This)->lpVtbl->GetDefaultAudioEndpoint(This,dataFlow,role,ppEndpoint)
+#define _IMMDevice_OpenPropertyStore(This,stgmAccess,ppProperties) (This)->lpVtbl->OpenPropertyStore(This,stgmAccess,ppProperties)
+#define _IMMDevice_GetId(This,ppstrId) (This)->lpVtbl->GetId(This,ppstrId)
+#define _IPropertyStore_GetValue(This,key,pv) ( (This)->lpVtbl -> GetValue(This,&(key),pv) )
+#define _IMMDeviceCollection_GetCount(This,cProps) ( (This)->lpVtbl -> GetCount(This,cProps) )
+#endif
+
+#ifdef __cplusplus
+#ifndef IFACE_RELEASE
+#define IFACE_RELEASE(iface) \
+ if (iface) \
+ { \
+ iface->Release(); \
+ iface = NULL; \
+ }
+#endif
+#else
+#ifndef IFACE_RELEASE
+#define IFACE_RELEASE(iface) \
+ if (iface) \
+ { \
+ iface->lpVtbl->Release(iface);\
+ iface = NULL; \
+ }
+#endif
+#endif
+
+RETRO_BEGIN_DECLS
+
+void *mmdevice_list_new(void *u);
+
+RETRO_END_DECLS
+
+#endif
diff --git a/audio/drivers/wasapi.c b/audio/drivers/wasapi.c
index 32b1f0bc2e..3ca814bc6f 100644
--- a/audio/drivers/wasapi.c
+++ b/audio/drivers/wasapi.c
@@ -15,100 +15,15 @@
#include
-#ifdef _WIN32_WINNT
-#undef _WIN32_WINNT
-#endif
-#define _WIN32_WINNT 0x0600
-#define WIN32_LEAN_AND_MEAN
-
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-
-#ifdef _MSC_VER
-DEFINE_GUID(IID_IAudioClient, 0x1CB9AD4C, 0xDBFA, 0x4C32, 0xB1, 0x78, 0xC2, 0xF5, 0x68, 0xA7, 0x03, 0xB2);
-DEFINE_GUID(IID_IAudioRenderClient, 0xF294ACFC, 0x3146, 0x4483, 0xA7, 0xBF, 0xAD, 0xDC, 0xA7, 0xC2, 0x60, 0xE2);
-DEFINE_GUID(IID_IMMDeviceEnumerator, 0xA95664D2, 0x9614, 0x4F35, 0xA7, 0x46, 0xDE, 0x8D, 0xB6, 0x36, 0x17, 0xE6);
-DEFINE_GUID(CLSID_MMDeviceEnumerator, 0xBCDE0395, 0xE52F, 0x467C, 0x8E, 0x3D, 0xC4, 0x57, 0x92, 0x91, 0x69, 0x2E);
-#undef KSDATAFORMAT_SUBTYPE_IEEE_FLOAT
-DEFINE_GUID(KSDATAFORMAT_SUBTYPE_IEEE_FLOAT, 0x00000003, 0x0000, 0x0010, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71);
-#endif
-
#include
#include
+#include "../common/mmdevice_common.h"
+
#include "../../retroarch.h"
#include "../../verbosity.h"
#include "../../configuration.h"
-DEFINE_PROPERTYKEY(PKEY_Device_FriendlyName, 0xa45c254e, 0xdf1c, 0x4efd, 0x80, 0x20, 0x67, 0xd1, 0x46, 0xa8, 0x50, 0xe0, 14); /* DEVPROP_TYPE_STRING */
-
-#ifdef __cplusplus
-#define _IMMDeviceCollection_Item(This,nDevice,ppdevice) (This)->Item(nDevice,ppdevice)
-#define _IAudioClient_Start(This) ( (This)->Start() )
-#define _IAudioClient_Stop(This) ( (This)->Stop() )
-#define _IAudioClient_GetCurrentPadding(This,pNumPaddingFrames) \
- ( (This)->GetCurrentPadding(pNumPaddingFrames) )
-#define _IAudioRenderClient_GetBuffer(This,NumFramesRequested,ppData) \
- ( (This)->GetBuffer(NumFramesRequested,ppData) )
-#define _IAudioRenderClient_ReleaseBuffer(This,NumFramesWritten,dwFlags) \
- ( (This)->ReleaseBuffer(NumFramesWritten,dwFlags) )
-#define _IAudioClient_GetService(This,riid,ppv) ( (This)->GetService(riid,ppv) )
-#define _IAudioClient_SetEventHandle(This,eventHandle) ( (This)->SetEventHandle(eventHandle) )
-#define _IAudioClient_GetBufferSize(This,pNumBufferFrames) ( (This)->GetBufferSize(pNumBufferFrames) )
-#define _IAudioClient_GetStreamLatency(This,phnsLatency) ( (This)->GetStreamLatency(phnsLatency) )
-#define _IAudioClient_GetDevicePeriod(This,phnsDefaultDevicePeriod,phnsMinimumDevicePeriod) ( (This)->GetDevicePeriod(phnsDefaultDevicePeriod,phnsMinimumDevicePeriod) )
-#define _IMMDevice_Activate(This,iid,dwClsCtx,pActivationParams,ppv) ((This)->Activate(iid,(dwClsCtx),pActivationParams,ppv))
-#define _IMMDeviceEnumerator_EnumAudioEndpoints(This,dataFlow,dwStateMask,ppDevices) (This)->EnumAudioEndpoints(dataFlow,dwStateMask,ppDevices)
-#define _IMMDeviceEnumerator_GetDefaultAudioEndpoint(This,dataFlow,role,ppEndpoint) (This)->GetDefaultAudioEndpoint(dataFlow,role,ppEndpoint)
-#define _IMMDevice_OpenPropertyStore(This,stgmAccess,ppProperties) (This)->OpenPropertyStore(stgmAccess,ppProperties)
-#define _IMMDevice_GetId(This,ppstrId) ((This)->GetId(ppstrId))
-#define _IPropertyStore_GetValue(This,key,pv) ( (This)->GetValue(key,pv) )
-#define _IMMDeviceCollection_GetCount(This,cProps) ( (This)->GetCount(cProps) )
-#else
-#define _IMMDeviceCollection_Item(This,nDevice,ppdevice) (This)->lpVtbl->Item(This,nDevice,ppdevice)
-#define _IAudioClient_Start(This) ( (This)->lpVtbl -> Start(This) )
-#define _IAudioClient_Stop(This) ( (This)->lpVtbl -> Stop(This) )
-#define _IAudioClient_GetCurrentPadding(This,pNumPaddingFrames) \
- ( (This)->lpVtbl -> GetCurrentPadding(This,pNumPaddingFrames) )
-#define _IAudioRenderClient_GetBuffer(This,NumFramesRequested,ppData) \
- ( (This)->lpVtbl -> GetBuffer(This,NumFramesRequested,ppData) )
-#define _IAudioRenderClient_ReleaseBuffer(This,NumFramesWritten,dwFlags) \
- ( (This)->lpVtbl -> ReleaseBuffer(This,NumFramesWritten,dwFlags) )
-#define _IAudioClient_GetService(This,riid,ppv) ( (This)->lpVtbl -> GetService(This,&(riid),ppv) )
-#define _IAudioClient_SetEventHandle(This,eventHandle) ( (This)->lpVtbl -> SetEventHandle(This,eventHandle) )
-#define _IAudioClient_GetBufferSize(This,pNumBufferFrames) ( (This)->lpVtbl -> GetBufferSize(This,pNumBufferFrames) )
-#define _IAudioClient_GetStreamLatency(This,phnsLatency) ( (This)->lpVtbl -> GetStreamLatency(This,phnsLatency) )
-#define _IAudioClient_GetDevicePeriod(This,phnsDefaultDevicePeriod,phnsMinimumDevicePeriod) ( (This)->lpVtbl -> GetDevicePeriod(This,phnsDefaultDevicePeriod,phnsMinimumDevicePeriod) )
-#define _IMMDevice_Activate(This,iid,dwClsCtx,pActivationParams,ppv) ((This)->lpVtbl->Activate(This,&(iid),dwClsCtx,pActivationParams,ppv))
-#define _IMMDeviceEnumerator_EnumAudioEndpoints(This,dataFlow,dwStateMask,ppDevices) (This)->lpVtbl->EnumAudioEndpoints(This,dataFlow,dwStateMask,ppDevices)
-#define _IMMDeviceEnumerator_GetDefaultAudioEndpoint(This,dataFlow,role,ppEndpoint) (This)->lpVtbl->GetDefaultAudioEndpoint(This,dataFlow,role,ppEndpoint)
-#define _IMMDevice_OpenPropertyStore(This,stgmAccess,ppProperties) (This)->lpVtbl->OpenPropertyStore(This,stgmAccess,ppProperties)
-#define _IMMDevice_GetId(This,ppstrId) (This)->lpVtbl->GetId(This,ppstrId)
-#define _IPropertyStore_GetValue(This,key,pv) ( (This)->lpVtbl -> GetValue(This,&(key),pv) )
-#define _IMMDeviceCollection_GetCount(This,cProps) ( (This)->lpVtbl -> GetCount(This,cProps) )
-#endif
-
-#ifdef __cplusplus
-#define IFACE_RELEASE(iface) \
- if (iface) \
- { \
- iface->Release(); \
- iface = NULL; \
- }
-#else
-#define IFACE_RELEASE(iface) \
- if (iface) \
- { \
- iface->lpVtbl->Release(iface);\
- iface = NULL; \
- }
-#endif
-
typedef struct
{
bool exclusive;
@@ -921,147 +836,6 @@ static bool wasapi_use_float(void *wh)
return w->frame_size == 8;
}
-static void *wasapi_device_list_new(void *u)
-{
- HRESULT hr;
- UINT i;
- PROPVARIANT prop_var;
- int ir;
- union string_list_elem_attr attr;
- IMMDeviceEnumerator *enumerator = NULL;
- IMMDeviceCollection *collection = NULL;
- UINT dev_count = 0;
- IMMDevice *device = NULL;
- LPWSTR dev_id_wstr = NULL;
- IPropertyStore *prop_store = NULL;
- bool prop_var_init = false;
- bool br = false;
- char *dev_id_str = NULL;
- char *dev_name_str = NULL;
- struct string_list *sl = string_list_new();
-
- if (!sl)
- return NULL;
-
- attr.i = 0;
-#ifdef __cplusplus
- hr = CoCreateInstance(CLSID_MMDeviceEnumerator, NULL, CLSCTX_ALL,
- IID_IMMDeviceEnumerator, (void **)&enumerator);
-#else
- hr = CoCreateInstance(&CLSID_MMDeviceEnumerator, NULL, CLSCTX_ALL,
- &IID_IMMDeviceEnumerator, (void **)&enumerator);
-#endif
- if (FAILED(hr))
- goto error;
-
- hr = _IMMDeviceEnumerator_EnumAudioEndpoints(enumerator,
- eRender, DEVICE_STATE_ACTIVE, &collection);
- if (FAILED(hr))
- goto error;
-
- hr = _IMMDeviceCollection_GetCount(collection, &dev_count);
- if (FAILED(hr))
- goto error;
-
- for (i = 0; i < dev_count; ++i)
- {
- hr = _IMMDeviceCollection_Item(collection, i, &device);
- if (FAILED(hr))
- goto error;
-
- hr = _IMMDevice_GetId(device, &dev_id_wstr);
- if (FAILED(hr))
- goto error;
-
- ir = WideCharToMultiByte(CP_ACP, 0, dev_id_wstr, -1,
- NULL, 0, NULL, NULL);
- if (!ir)
- goto error;
-
- dev_id_str = (char *)malloc(ir);
- if (!dev_id_str)
- goto error;
-
- ir = WideCharToMultiByte(CP_ACP, 0, dev_id_wstr, -1,
- dev_id_str, ir, NULL, NULL);
- if (!ir)
- goto error;
-
- hr = _IMMDevice_OpenPropertyStore(device, STGM_READ, &prop_store);
- if (FAILED(hr))
- goto error;
-
- PropVariantInit(&prop_var);
- prop_var_init = true;
- hr = _IPropertyStore_GetValue(prop_store, PKEY_Device_FriendlyName,
- &prop_var);
- if (FAILED(hr))
- goto error;
-
- ir = WideCharToMultiByte(CP_ACP, 0, prop_var.pwszVal, -1,
- NULL, 0, NULL, NULL);
- if (!ir)
- goto error;
-
- dev_name_str = (char *)malloc(ir);
- if (!dev_name_str)
- goto error;
-
- ir = WideCharToMultiByte(CP_ACP, 0, prop_var.pwszVal, -1,
- dev_name_str, ir, NULL, NULL);
- if (!ir)
- goto error;
-
- RARCH_LOG("[WASAPI]: %s %s\n", dev_name_str, dev_id_str);
-
- br = string_list_append(sl, dev_id_str, attr);
- if (!br)
- goto error;
-
- PropVariantClear(&prop_var);
- prop_var_init = false;
- if (dev_id_wstr)
- CoTaskMemFree(dev_id_wstr);
- if (dev_id_str)
- free(dev_id_str);
- if (dev_name_str)
- free(dev_name_str);
- dev_id_str = NULL;
- dev_name_str = NULL;
- dev_id_wstr = NULL;
- IFACE_RELEASE(prop_store);
- IFACE_RELEASE(device);
- }
-
- IFACE_RELEASE(collection);
- IFACE_RELEASE(enumerator);
-
- return sl;
-
-error:
- if (dev_id_str)
- free(dev_id_str);
- if (dev_name_str)
- free(dev_name_str);
- dev_id_str = NULL;
- dev_name_str = NULL;
- if (prop_var_init)
- PropVariantClear(&prop_var);
- IFACE_RELEASE(prop_store);
- if (dev_id_wstr)
- CoTaskMemFree(dev_id_wstr);
- dev_id_wstr = NULL;
- IFACE_RELEASE(device);
- IFACE_RELEASE(collection);
- IFACE_RELEASE(enumerator);
- if (sl)
- string_list_free(sl);
-
- RARCH_ERR("[WASAPI]: Device enumeration failed.\n");
-
- return NULL;
-}
-
static void wasapi_device_list_free(void *u, void *slp)
{
struct string_list *sl = (struct string_list*)slp;
@@ -1106,7 +880,7 @@ audio_driver_t audio_wasapi = {
wasapi_free,
wasapi_use_float,
"wasapi",
- wasapi_device_list_new,
+ mmdevice_list_new,
wasapi_device_list_free,
wasapi_write_avail,
wasapi_buffer_size
diff --git a/core_info.c b/core_info.c
index 76a565d827..8a585c09ab 100644
--- a/core_info.c
+++ b/core_info.c
@@ -1069,12 +1069,12 @@ static bool core_info_compare_api_version(int sys_major, int sys_minor, int majo
bool core_info_hw_api_supported(core_info_t *info)
{
+ unsigned i;
enum gfx_ctx_api sys_api;
- gfx_ctx_flags_t sys_flags = {0};
- int i;
+ gfx_ctx_flags_t sys_flags = {0};
const char *sys_api_version_str = video_driver_get_gpu_api_version_string();
- int sys_api_version_major = 0;
- int sys_api_version_minor = 0;
+ int sys_api_version_major = 0;
+ int sys_api_version_minor = 0;
enum api_parse_state
{
@@ -1091,21 +1091,21 @@ bool core_info_hw_api_supported(core_info_t *info)
for (i = 0; i < info->required_hw_api_list->size; i++)
{
- char api_str[32] = {0};
- char version[16] = {0};
- char major_str[16] = {0};
- char minor_str[16] = {0};
- const char *cur_api = info->required_hw_api_list->elems[i].data;
- int api_pos = 0;
- int major_str_pos = 0;
- int minor_str_pos = 0;
- int cur_api_len = 0;
- int j = 0;
- int major = 0;
- int minor = 0;
- bool found_major = false;
- bool found_minor = false;
- enum compare_op op = COMPARE_OP_GREATER_EQUAL;
+ char api_str[32] = {0};
+ char version[16] = {0};
+ char major_str[16] = {0};
+ char minor_str[16] = {0};
+ const char *cur_api = info->required_hw_api_list->elems[i].data;
+ int api_pos = 0;
+ int major_str_pos = 0;
+ int minor_str_pos = 0;
+ int cur_api_len = 0;
+ int j = 0;
+ int major = 0;
+ int minor = 0;
+ bool found_major = false;
+ bool found_minor = false;
+ enum compare_op op = COMPARE_OP_GREATER_EQUAL;
enum api_parse_state state = STATE_API_NAME;
if (string_is_empty(cur_api))
@@ -1143,9 +1143,7 @@ bool core_info_hw_api_supported(core_info_t *info)
j++;
}
else if (cur_api[j] == '=')
- {
op = COMPARE_OP_EQUAL;
- }
else if (cur_api[j] == '!' && cur_api[j + 1] == '=')
{
op = COMPARE_OP_NOT_EQUAL;
@@ -1162,13 +1160,9 @@ bool core_info_hw_api_supported(core_info_t *info)
j++;
}
else if (cur_api[j] == '<')
- {
op = COMPARE_OP_LESS;
- }
else if (cur_api[j] == '>')
- {
op = COMPARE_OP_GREATER;
- }
}
state = STATE_API_VERSION;
@@ -1190,10 +1184,7 @@ bool core_info_hw_api_supported(core_info_t *info)
minor_str[minor_str_pos++] = cur_api[j];
}
else if (cur_api[j] == '.')
- {
found_minor = true;
- }
-
break;
}
default:
@@ -1216,11 +1207,9 @@ bool core_info_hw_api_supported(core_info_t *info)
(string_is_equal_noncase(api_str, "openglcompat") && sys_api == GFX_CTX_OPENGL_API) ||
(string_is_equal_noncase(api_str, "openglcompatibility") && sys_api == GFX_CTX_OPENGL_API))
{
- if (sys_flags.flags & (1 << GFX_CTX_FLAGS_GL_CORE_CONTEXT))
- {
- /* system is running a core context while compat is requested */
+ /* system is running a core context while compat is requested */
+ if (sys_flags.flags & (1 << GFX_CTX_FLAGS_GL_CORE_CONTEXT))
return false;
- }
sscanf(sys_api_version_str, "%d.%d", &sys_api_version_major, &sys_api_version_minor);
diff --git a/griffin/griffin.c b/griffin/griffin.c
index 1cc46adf9d..a35111a6ab 100644
--- a/griffin/griffin.c
+++ b/griffin/griffin.c
@@ -874,6 +874,10 @@ AUDIO
#include "../audio/drivers/nullaudio.c"
+#if defined(HAVE_WASAPI) || defined(HAVE_XAUDIO)
+#include "../audio/common/mmdevice_common.c"
+#endif
+
/*============================================================
MIDI
============================================================ */