Okay, re-add SNDDXThread. But newer system. Synchronous with main thread.
No more loopy playback while menus are opened. No more silent playback while the emu is paused. (when you open the menu, sound stutters for a quarter of second before stopping but that's acceptable)
This commit is contained in:
parent
1a4423e9c8
commit
d7e57c83bf
|
@ -1021,7 +1021,7 @@ void SPU_Emulate_core()
|
||||||
SPU_MixAudio<false>(SPU_core,spu_core_samples);
|
SPU_MixAudio<false>(SPU_core,spu_core_samples);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SPU_Emulate_user()
|
void SPU_Emulate_user(bool mix)
|
||||||
{
|
{
|
||||||
if(!SPU_user)
|
if(!SPU_user)
|
||||||
return;
|
return;
|
||||||
|
@ -1037,7 +1037,7 @@ void SPU_Emulate_user()
|
||||||
//printf("mix %i samples\n", audiosize);
|
//printf("mix %i samples\n", audiosize);
|
||||||
if (audiosize > SPU_user->bufsize)
|
if (audiosize > SPU_user->bufsize)
|
||||||
audiosize = SPU_user->bufsize;
|
audiosize = SPU_user->bufsize;
|
||||||
SPU_MixAudio<true>(SPU_user,audiosize);
|
if (mix) SPU_MixAudio<true>(SPU_user,audiosize);
|
||||||
SNDCore->UpdateAudio(SPU_user->outbuf, audiosize);
|
SNDCore->UpdateAudio(SPU_user->outbuf, audiosize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -140,7 +140,7 @@ void SPU_WriteByte(u32 addr, u8 val);
|
||||||
void SPU_WriteWord(u32 addr, u16 val);
|
void SPU_WriteWord(u32 addr, u16 val);
|
||||||
void SPU_WriteLong(u32 addr, u32 val);
|
void SPU_WriteLong(u32 addr, u32 val);
|
||||||
void SPU_Emulate_core(void);
|
void SPU_Emulate_core(void);
|
||||||
void SPU_Emulate_user(void);
|
void SPU_Emulate_user(bool mix = true);
|
||||||
|
|
||||||
extern SPU_struct *SPU_core, *SPU_user;
|
extern SPU_struct *SPU_core, *SPU_user;
|
||||||
extern int spu_core_samples;
|
extern int spu_core_samples;
|
||||||
|
|
|
@ -265,6 +265,7 @@ extern bool userTouchesScreen;
|
||||||
int sndcoretype=SNDCORE_DIRECTX;
|
int sndcoretype=SNDCORE_DIRECTX;
|
||||||
int sndbuffersize=735*4;
|
int sndbuffersize=735*4;
|
||||||
int sndvolume=100;
|
int sndvolume=100;
|
||||||
|
HANDLE hSoundThreadWakeup = INVALID_HANDLE_VALUE;
|
||||||
|
|
||||||
SoundInterface_struct *SNDCoreList[] = {
|
SoundInterface_struct *SNDCoreList[] = {
|
||||||
&SNDDummy,
|
&SNDDummy,
|
||||||
|
@ -1199,7 +1200,7 @@ static void StepRunLoop_Core()
|
||||||
Lock lock;
|
Lock lock;
|
||||||
NDS_exec<false>();
|
NDS_exec<false>();
|
||||||
win_sound_samplecounter = 735;
|
win_sound_samplecounter = 735;
|
||||||
SPU_Emulate_user();
|
SetEvent(hSoundThreadWakeup);
|
||||||
}
|
}
|
||||||
inFrameBoundary = true;
|
inFrameBoundary = true;
|
||||||
DRV_AviVideoUpdate((u16*)GPU_screen);
|
DRV_AviVideoUpdate((u16*)GPU_screen);
|
||||||
|
@ -1819,6 +1820,8 @@ int _main()
|
||||||
display_invoke_done_event = CreateEvent(NULL, FALSE, FALSE, NULL);
|
display_invoke_done_event = CreateEvent(NULL, FALSE, FALSE, NULL);
|
||||||
display_wakeup_event = CreateEvent(NULL, FALSE, FALSE, NULL);
|
display_wakeup_event = CreateEvent(NULL, FALSE, FALSE, NULL);
|
||||||
|
|
||||||
|
hSoundThreadWakeup = CreateEvent(NULL, FALSE, FALSE, NULL);
|
||||||
|
|
||||||
#ifdef GDB_STUB
|
#ifdef GDB_STUB
|
||||||
gdbstub_handle_t arm9_gdb_stub;
|
gdbstub_handle_t arm9_gdb_stub;
|
||||||
gdbstub_handle_t arm7_gdb_stub;
|
gdbstub_handle_t arm7_gdb_stub;
|
||||||
|
@ -2273,6 +2276,8 @@ int _main()
|
||||||
|
|
||||||
UnregWndClass("DeSmuME");
|
UnregWndClass("DeSmuME");
|
||||||
|
|
||||||
|
CloseHandle(hSoundThreadWakeup);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2990,8 +2995,6 @@ LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam, LPARAM
|
||||||
{
|
{
|
||||||
case WM_ENTERMENULOOP: //Update menu items that needs to be updated dynamically
|
case WM_ENTERMENULOOP: //Update menu items that needs to be updated dynamically
|
||||||
{
|
{
|
||||||
SPU_Pause(1);
|
|
||||||
|
|
||||||
UpdateHotkeyAssignments(); //Add current hotkey mappings to menu item names
|
UpdateHotkeyAssignments(); //Add current hotkey mappings to menu item names
|
||||||
|
|
||||||
MENUITEMINFO mii;
|
MENUITEMINFO mii;
|
||||||
|
@ -3127,11 +3130,6 @@ LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam, LPARAM
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
case WM_EXITMENULOOP:
|
|
||||||
{
|
|
||||||
SPU_Pause(0);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
case WM_CREATE:
|
case WM_CREATE:
|
||||||
{
|
{
|
||||||
|
|
|
@ -71,7 +71,37 @@ static int issoundmuted;
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
//extern volatile int win_sound_samplecounter;
|
//extern volatile int win_sound_samplecounter;
|
||||||
|
HANDLE hSNDDXThread = INVALID_HANDLE_VALUE;
|
||||||
|
extern HANDLE hSoundThreadWakeup;
|
||||||
|
bool bTerminateSoundThread = false;
|
||||||
|
bool bSilence = false;
|
||||||
|
|
||||||
|
DWORD WINAPI SNDDXThread( LPVOID )
|
||||||
|
{
|
||||||
|
for(;;)
|
||||||
|
{
|
||||||
|
if(bTerminateSoundThread) break;
|
||||||
|
|
||||||
|
if (bSilence)
|
||||||
|
{
|
||||||
|
if (WaitForSingleObject(hSoundThreadWakeup, 10) == WAIT_OBJECT_0)
|
||||||
|
bSilence = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// If the sound thread wakeup event is not signaled after a quarter second, output silence
|
||||||
|
if (WaitForSingleObject(hSoundThreadWakeup, 250) == WAIT_TIMEOUT)
|
||||||
|
bSilence = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
Lock lock;
|
||||||
|
SPU_Emulate_user(!bSilence);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int SNDDXInit(int buffersize)
|
int SNDDXInit(int buffersize)
|
||||||
{
|
{
|
||||||
|
@ -169,6 +199,10 @@ int SNDDXInit(int buffersize)
|
||||||
soundvolume = DSBVOLUME_MAX;
|
soundvolume = DSBVOLUME_MAX;
|
||||||
issoundmuted = 0;
|
issoundmuted = 0;
|
||||||
|
|
||||||
|
bSilence = false;
|
||||||
|
bTerminateSoundThread = false;
|
||||||
|
hSNDDXThread = CreateThread(0, 0, SNDDXThread, 0, 0, 0);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -178,6 +212,10 @@ void SNDDXDeInit()
|
||||||
{
|
{
|
||||||
DWORD status=0;
|
DWORD status=0;
|
||||||
|
|
||||||
|
bTerminateSoundThread = true;
|
||||||
|
SetEvent(hSoundThreadWakeup);
|
||||||
|
WaitForSingleObject(hSNDDXThread, INFINITE);
|
||||||
|
|
||||||
if (lpDSB2)
|
if (lpDSB2)
|
||||||
{
|
{
|
||||||
lpDSB2->GetStatus(&status);
|
lpDSB2->GetStatus(&status);
|
||||||
|
@ -200,6 +238,8 @@ void SNDDXDeInit()
|
||||||
lpDS8->Release();
|
lpDS8->Release();
|
||||||
lpDS8 = NULL;
|
lpDS8 = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
delete stereodata16;
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -211,14 +251,6 @@ void SNDDXUpdateAudio(s16 *buffer, u32 num_samples)
|
||||||
DWORD buffer1_size, buffer2_size;
|
DWORD buffer1_size, buffer2_size;
|
||||||
DWORD status;
|
DWORD status;
|
||||||
|
|
||||||
/* int samplecounter;
|
|
||||||
{
|
|
||||||
Lock lock;
|
|
||||||
samplecounter = win_sound_samplecounter -= num_samples;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool silence = (samplecounter<-44100*15/60); //behind by more than a quarter second -> silence
|
|
||||||
*/
|
|
||||||
lpDSB2->GetStatus(&status);
|
lpDSB2->GetStatus(&status);
|
||||||
|
|
||||||
if (status & DSBSTATUS_BUFFERLOST)
|
if (status & DSBSTATUS_BUFFERLOST)
|
||||||
|
@ -226,12 +258,13 @@ void SNDDXUpdateAudio(s16 *buffer, u32 num_samples)
|
||||||
|
|
||||||
lpDSB2->Lock(soundoffset, num_samples * sizeof(s16) * 2, &buffer1, &buffer1_size, &buffer2, &buffer2_size, 0);
|
lpDSB2->Lock(soundoffset, num_samples * sizeof(s16) * 2, &buffer1, &buffer1_size, &buffer2, &buffer2_size, 0);
|
||||||
|
|
||||||
/* if(silence) {
|
if(bSilence)
|
||||||
|
{
|
||||||
memset(buffer1, 0, buffer1_size);
|
memset(buffer1, 0, buffer1_size);
|
||||||
if(buffer2)
|
if(buffer2)
|
||||||
memset(buffer2, 0, buffer2_size);
|
memset(buffer2, 0, buffer2_size);
|
||||||
}
|
}
|
||||||
else*/
|
else
|
||||||
{
|
{
|
||||||
memcpy(buffer1, buffer, buffer1_size);
|
memcpy(buffer1, buffer, buffer1_size);
|
||||||
if (buffer2)
|
if (buffer2)
|
||||||
|
|
Loading…
Reference in New Issue