mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2025-01-20 15:25:38 +00:00
AudioStream: Fix a couple of errors in ReadFrames() resampler
This commit is contained in:
parent
e40c022a0f
commit
a5a72cd7ec
|
@ -156,12 +156,12 @@ void AudioStream::ReadFrames(s16* samples, u32 num_frames)
|
||||||
// super basic resampler - spread the input samples evenly across the output samples. will sound like ass and have
|
// super basic resampler - spread the input samples evenly across the output samples. will sound like ass and have
|
||||||
// aliasing, but better than popping by inserting silence.
|
// aliasing, but better than popping by inserting silence.
|
||||||
const u32 increment =
|
const u32 increment =
|
||||||
static_cast<u32>(65536.0f * (static_cast<float>(frames_to_read / m_channels) / static_cast<float>(num_frames)));
|
static_cast<u32>(65536.0f * (static_cast<float>(frames_to_read) / static_cast<float>(num_frames)));
|
||||||
|
|
||||||
s16* resample_ptr = static_cast<s16*>(alloca(sizeof(s16) * frames_to_read));
|
SampleType* resample_ptr = static_cast<SampleType*>(alloca(frames_to_read * m_channels * sizeof(SampleType)));
|
||||||
std::memcpy(resample_ptr, samples, sizeof(s16) * frames_to_read);
|
std::memcpy(resample_ptr, samples, frames_to_read * m_channels * sizeof(SampleType));
|
||||||
|
|
||||||
s16* out_ptr = samples;
|
SampleType* out_ptr = samples;
|
||||||
const u32 copy_stride = sizeof(SampleType) * m_channels;
|
const u32 copy_stride = sizeof(SampleType) * m_channels;
|
||||||
u32 resample_subpos = 0;
|
u32 resample_subpos = 0;
|
||||||
for (u32 i = 0; i < num_frames; i++)
|
for (u32 i = 0; i < num_frames; i++)
|
||||||
|
@ -174,12 +174,12 @@ void AudioStream::ReadFrames(s16* samples, u32 num_frames)
|
||||||
resample_subpos %= 65536u;
|
resample_subpos %= 65536u;
|
||||||
}
|
}
|
||||||
|
|
||||||
Log_VerbosePrintf("Audio buffer underflow, resampled %u frames to %u", frames_to_read, num_frames);
|
Log_VerboseFmt("Audio buffer underflow, resampled {} frames to {}", frames_to_read, num_frames);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// no data, fall back to silence
|
// no data, fall back to silence
|
||||||
std::memset(samples + frames_to_read, 0, sizeof(s32) * silence_frames);
|
std::memset(samples + (frames_to_read * m_channels), 0, sizeof(s16) * m_channels * silence_frames);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue