Adjusted the audio loop criteria, using >= on the Wii and == on GC. This fixes the audio static that occurred in Wii games after hours of play.
Fixes issue 5938. Fixes issue 6067.
This commit is contained in:
parent
b00201dcbd
commit
51290fd482
|
@ -21,6 +21,8 @@
|
||||||
#include "DSPHost.h"
|
#include "DSPHost.h"
|
||||||
#include "DSPHWInterface.h"
|
#include "DSPHWInterface.h"
|
||||||
#include "DSPInterpreter.h"
|
#include "DSPInterpreter.h"
|
||||||
|
#include "CoreTiming.h"
|
||||||
|
#include "Core.h"
|
||||||
|
|
||||||
// The hardware adpcm decoder :)
|
// The hardware adpcm decoder :)
|
||||||
static s16 ADPCM_Step(u32& _rSamplePos)
|
static s16 ADPCM_Step(u32& _rSamplePos)
|
||||||
|
@ -168,10 +170,12 @@ u16 dsp_read_accelerator()
|
||||||
if (Address >= EndAddress)
|
if (Address >= EndAddress)
|
||||||
{
|
{
|
||||||
// Set address back to start address.
|
// Set address back to start address.
|
||||||
if ((Address & ~0x1f) == (EndAddress & ~0x1f))
|
if (Core::g_CoreStartupParameter.bWii || Address == EndAddress)
|
||||||
|
{
|
||||||
Address = (g_dsp.ifx_regs[DSP_ACSAH] << 16) | g_dsp.ifx_regs[DSP_ACSAL];
|
Address = (g_dsp.ifx_regs[DSP_ACSAH] << 16) | g_dsp.ifx_regs[DSP_ACSAL];
|
||||||
DSPCore_SetException(EXP_ACCOV);
|
DSPCore_SetException(EXP_ACCOV);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
g_dsp.ifx_regs[DSP_ACCAH] = Address >> 16;
|
g_dsp.ifx_regs[DSP_ACCAH] = Address >> 16;
|
||||||
g_dsp.ifx_regs[DSP_ACCAL] = Address & 0xffff;
|
g_dsp.ifx_regs[DSP_ACCAL] = Address & 0xffff;
|
||||||
|
|
|
@ -29,6 +29,8 @@
|
||||||
#include "Common.h"
|
#include "Common.h"
|
||||||
#include "UCode_AX_Structs.h"
|
#include "UCode_AX_Structs.h"
|
||||||
#include "../../DSP.h"
|
#include "../../DSP.h"
|
||||||
|
#include "CoreTiming.h"
|
||||||
|
#include "Core.h"
|
||||||
|
|
||||||
#ifdef AX_GC
|
#ifdef AX_GC
|
||||||
# define PB_TYPE AXPB
|
# define PB_TYPE AXPB
|
||||||
|
@ -205,9 +207,8 @@ u16 AcceleratorGetSample()
|
||||||
// UCode. We simulate what this interrupt does here.
|
// UCode. We simulate what this interrupt does here.
|
||||||
if (*acc_cur_addr >= acc_end_addr)
|
if (*acc_cur_addr >= acc_end_addr)
|
||||||
{
|
{
|
||||||
// If we are really at the end (and we don't simply have cur_addr >
|
// loop back to loop_addr.
|
||||||
// end_addr all the time), loop back to loop_addr.
|
if (Core::g_CoreStartupParameter.bWii || *acc_cur_addr == acc_end_addr)
|
||||||
if ((*acc_cur_addr & ~0x1F) == (acc_end_addr & ~0x1F))
|
|
||||||
*acc_cur_addr = acc_loop_addr;
|
*acc_cur_addr = acc_loop_addr;
|
||||||
|
|
||||||
if (acc_pb->audio_addr.looping)
|
if (acc_pb->audio_addr.looping)
|
||||||
|
|
Loading…
Reference in New Issue