SPU: Ignore loop start flag when repeat address is explicitly set

Fixes dialog/softlock in Thousand Arms.
This commit is contained in:
Connor McLaughlin 2020-03-27 01:42:59 +10:00
parent 08ad5aad53
commit f23bcc0faa
3 changed files with 6 additions and 2 deletions

View file

@ -2,4 +2,4 @@
#include "types.h" #include "types.h"
static constexpr u32 SAVE_STATE_MAGIC = 0x43435544; static constexpr u32 SAVE_STATE_MAGIC = 0x43435544;
static constexpr u32 SAVE_STATE_VERSION = 14; static constexpr u32 SAVE_STATE_VERSION = 15;

View file

@ -130,6 +130,7 @@ bool SPU::DoState(StateWrapper& sw)
sw.Do(&v.adsr_phase); sw.Do(&v.adsr_phase);
sw.Do(&v.adsr_target); sw.Do(&v.adsr_target);
sw.Do(&v.has_samples); sw.Do(&v.has_samples);
sw.Do(&v.ignore_loop_address);
} }
sw.DoBytes(m_ram.data(), RAM_SIZE); sw.DoBytes(m_ram.data(), RAM_SIZE);
@ -584,6 +585,7 @@ void SPU::WriteVoiceRegister(u32 offset, u16 value)
{ {
Log_DebugPrintf("SPU voice %u ADPCM repeat address <- 0x%04X", voice_index, value); Log_DebugPrintf("SPU voice %u ADPCM repeat address <- 0x%04X", voice_index, value);
voice.regs.adpcm_repeat_address = value; voice.regs.adpcm_repeat_address = value;
voice.ignore_loop_address = true;
} }
break; break;
@ -873,6 +875,7 @@ void SPU::Voice::KeyOn()
current_address = regs.adpcm_start_address; current_address = regs.adpcm_start_address;
regs.adsr_volume = 0; regs.adsr_volume = 0;
has_samples = false; has_samples = false;
ignore_loop_address = false;
SetADSRPhase(ADSRPhase::Attack); SetADSRPhase(ADSRPhase::Attack);
} }
@ -1238,7 +1241,7 @@ std::tuple<s32, s32> SPU::SampleVoice(u32 voice_index)
voice.DecodeBlock(block); voice.DecodeBlock(block);
voice.has_samples = true; voice.has_samples = true;
if (voice.current_block_flags.loop_start) if (voice.current_block_flags.loop_start && !voice.ignore_loop_address)
{ {
Log_TracePrintf("Voice %u loop start @ 0x%08X", voice_index, ZeroExtend32(voice.current_address)); Log_TracePrintf("Voice %u loop start @ 0x%08X", voice_index, ZeroExtend32(voice.current_address));
voice.regs.adpcm_repeat_address = voice.current_address; voice.regs.adpcm_repeat_address = voice.current_address;

View file

@ -262,6 +262,7 @@ private:
ADSRPhase adsr_phase; ADSRPhase adsr_phase;
s16 adsr_target; s16 adsr_target;
bool has_samples; bool has_samples;
bool ignore_loop_address;
bool IsOn() const { return adsr_phase != ADSRPhase::Off; } bool IsOn() const { return adsr_phase != ADSRPhase::Off; }