diff --git a/3rdparty/portaudio/build/msvc/portaudio.vcproj b/3rdparty/portaudio/build/msvc/portaudio.vcproj
index 0922f51743..14bfa98153 100644
--- a/3rdparty/portaudio/build/msvc/portaudio.vcproj
+++ b/3rdparty/portaudio/build/msvc/portaudio.vcproj
@@ -2170,6 +2170,38 @@
Name="Header Files"
Filter="h;hpp;hxx;hm;inl"
>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/plugins/spu2-x/src/SndOut_Portaudio.cpp b/plugins/spu2-x/src/SndOut_Portaudio.cpp
index 43c7fd4b14..1768a79d38 100644
--- a/plugins/spu2-x/src/SndOut_Portaudio.cpp
+++ b/plugins/spu2-x/src/SndOut_Portaudio.cpp
@@ -32,7 +32,7 @@ private:
//////////////////////////////////////////////////////////////////////////////////////////
// Configuration Vars (unused still)
- wstring m_Api;
+ int m_ApiId;
wstring m_Device;
bool m_UseHardware;
@@ -76,11 +76,18 @@ private:
}
public:
+ Portaudio()
+ {
+ m_ApiId=-1;
+ }
+
s32 Init()
{
started=false;
stream=NULL;
+ ReadSettings();
+
PaError err = Pa_Initialize();
if( err != paNoError )
{
@@ -89,10 +96,78 @@ public:
}
started=true;
- err = Pa_OpenDefaultStream( &stream,
- 0, 2, paInt32, 48000,
- SndOutPacketSize,
- PaCallback, NULL );
+ int deviceIndex = -1;
+
+ fprintf(stderr," * SPU2: Enumerating PortAudio devices:");
+ for(int i=0;ihostApi);
+
+ fprintf(stderr," *** Device %d: '%s' (%s)", i, info->name, apiinfo->name);
+
+ if(apiinfo->type == m_ApiId)
+ {
+#ifdef __WIN32__
+ static wchar_t buffer [1000];
+ MultiByteToWideChar(CP_UTF8,0,info->name,strlen(info->name),buffer,999);
+ buffer[999]=0;
+#else
+# error TODO
+#endif
+
+ if(m_Device == buffer)
+ {
+ deviceIndex = i;
+ fprintf(stderr," (selected)");
+ }
+
+ }
+ fprintf(stderr,"\n");
+ }
+
+ if(deviceIndex<0 && m_ApiId>=0)
+ {
+ for(int i=0;itype == m_ApiId)
+ {
+ deviceIndex = apiinfo->defaultOutputDevice;
+ }
+ }
+ }
+
+ if(deviceIndex>=0)
+ {
+ PaStreamParameters outParams = {
+
+ // PaDeviceIndex device;
+ // int channelCount;
+ // PaSampleFormat sampleFormat;
+ // PaTime suggestedLatency;
+ // void *hostApiSpecificStreamInfo;
+ deviceIndex,
+ 2,
+ paInt32,
+ 0, //?
+ NULL
+
+ };
+
+ err = Pa_OpenStream(&stream,
+ NULL, &outParams, SampleRate,
+ SndOutPacketSize,
+ paNoFlag, PaCallback, NULL);
+ }
+ else
+ {
+ err = Pa_OpenDefaultStream( &stream,
+ 0, 2, paInt32, 48000,
+ SndOutPacketSize,
+ PaCallback, NULL );
+ }
if( err != paNoError )
{
fprintf(stderr," * SPU2: PortAudio error: %s\n", Pa_GetErrorText( err ) );
@@ -176,10 +251,53 @@ public:
void ReadSettings()
{
+ wstring api=L"EMPTYEMPTYEMPTY";
+ m_Device = L"EMPTYEMPTYEMPTY";
+ CfgReadStr( L"PORTAUDIO", L"HostApi", api, 254, L"Unknown" );
+ CfgReadStr( L"PORTAUDIO", L"Device", m_Device, 254, L"default" );
+
+ m_ApiId = -1;
+ if(api == L"InDevelopment") m_ApiId = paInDevelopment; /* use while developing support for a new host API */
+ if(api == L"DirectSound") m_ApiId = paDirectSound;
+ if(api == L"MME") m_ApiId = paMME;
+ if(api == L"ASIO") m_ApiId = paASIO;
+ if(api == L"SoundManager") m_ApiId = paSoundManager;
+ if(api == L"CoreAudio") m_ApiId = paCoreAudio;
+ if(api == L"OSS") m_ApiId = paOSS;
+ if(api == L"ALSA") m_ApiId = paALSA;
+ if(api == L"AL") m_ApiId = paAL;
+ if(api == L"BeOS") m_ApiId = paBeOS;
+ if(api == L"WDMKS") m_ApiId = paWDMKS;
+ if(api == L"JACK") m_ApiId = paJACK;
+ if(api == L"WASAPI") m_ApiId = paWASAPI;
+ if(api == L"AudioScienceHPI") m_ApiId = paAudioScienceHPI;
+
}
void WriteSettings() const
{
+ wstring api;
+ switch(m_ApiId)
+ {
+ case paInDevelopment: api = L"InDevelopment"; break; /* use while developing support for a new host API */
+ case paDirectSound: api = L"DirectSound"; break;
+ case paMME: api = L"MME"; break;
+ case paASIO: api = L"ASIO"; break;
+ case paSoundManager: api = L"SoundManager"; break;
+ case paCoreAudio: api = L"CoreAudio"; break;
+ case paOSS: api = L"OSS"; break;
+ case paALSA: api = L"ALSA"; break;
+ case paAL: api = L"AL"; break;
+ case paBeOS: api = L"BeOS"; break;
+ case paWDMKS: api = L"WDMKS"; break;
+ case paJACK: api = L"JACK"; break;
+ case paWASAPI: api = L"WASAPI"; break;
+ case paAudioScienceHPI: api = L"AudioScienceHPI"; break;
+ default: api = L"Unknown";
+ }
+
+ CfgWriteStr( L"PORTAUDIO", L"HostApi", api);
+ CfgWriteStr( L"PORTAUDIO", L"Device", m_Device);
}
} static PA;