diff --git a/Source/Core/AudioCommon/WaveFile.cpp b/Source/Core/AudioCommon/WaveFile.cpp index dc689e74dd..2e67d86519 100644 --- a/Source/Core/AudioCommon/WaveFile.cpp +++ b/Source/Core/AudioCommon/WaveFile.cpp @@ -119,10 +119,16 @@ void WaveFileWriter::AddStereoSamplesBE(const short* sample_data, u32 count, u32 sample_rate_divisor, int l_volume, int r_volume) { if (!file) + { ERROR_LOG_FMT(AUDIO, "WaveFileWriter - file not open."); + return; + } - if (count > BUFFER_SIZE * 2) + if (count * 2 > BUFFER_SIZE) + { ERROR_LOG_FMT(AUDIO, "WaveFileWriter - buffer too small (count = {}).", count); + return; + } if (skip_silence) { diff --git a/Source/Core/Core/HW/DSP.cpp b/Source/Core/Core/HW/DSP.cpp index 3952133748..5ebe4a6680 100644 --- a/Source/Core/Core/HW/DSP.cpp +++ b/Source/Core/Core/HW/DSP.cpp @@ -418,7 +418,7 @@ void RegisterMMIO(MMIO::Mapping* mmio, u32 base) bool already_enabled = state.audio_dma.AudioDMAControl.Enable; state.audio_dma.AudioDMAControl.Hex = val; - // Only load new values if were not already doing a DMA transfer, + // Only load new values if we're not already doing a DMA transfer, // otherwise just let the new values be autoloaded in when the // current transfer ends. if (!already_enabled && state.audio_dma.AudioDMAControl.Enable) @@ -429,10 +429,6 @@ void RegisterMMIO(MMIO::Mapping* mmio, u32 base) INFO_LOG_FMT(AUDIO_INTERFACE, "Audio DMA configured: {} blocks from {:#010x}", state.audio_dma.AudioDMAControl.NumBlocks, state.audio_dma.SourceAddress); - // We make the samples ready as soon as possible - void* address = Memory::GetPointer(state.audio_dma.SourceAddress); - AudioCommon::SendAIBuffer((short*)address, state.audio_dma.AudioDMAControl.NumBlocks * 8); - // TODO: need hardware tests for the timing of this interrupt. // Sky Crawlers crashes at boot if this is scheduled less than 87 cycles in the future. // Other Namco games crash too, see issue 9509. For now we will just push it to 200 cycles @@ -524,6 +520,8 @@ void UpdateAudioDMA() // Read audio at g_audioDMA.current_source_address in RAM and push onto an // external audio fifo in the emulator, to be mixed with the disc // streaming output. + void* address = Memory::GetPointer(state.audio_dma.current_source_address); + AudioCommon::SendAIBuffer(reinterpret_cast(address), 8); if (state.audio_dma.remaining_blocks_count != 0) { @@ -536,12 +534,6 @@ void UpdateAudioDMA() state.audio_dma.current_source_address = state.audio_dma.SourceAddress; state.audio_dma.remaining_blocks_count = state.audio_dma.AudioDMAControl.NumBlocks; - if (state.audio_dma.remaining_blocks_count != 0) - { - // We make the samples ready as soon as possible - void* address = Memory::GetPointer(state.audio_dma.SourceAddress); - AudioCommon::SendAIBuffer((short*)address, state.audio_dma.AudioDMAControl.NumBlocks * 8); - } GenerateDSPInterrupt(DSP::INT_AID); } }