mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-22 01:57:18 +01:00
audio: fixed arbitrary upsampling (thanks, Sylvain!).
This was a leftover of simplifying the resamplers down from autogenerated code; I forgot to make something that the generator hardcoded into something variable. Fixes Bugzilla #3507.
This commit is contained in:
parent
b515b34dbb
commit
f956df23bb
@ -222,8 +222,8 @@ SDL_Upsample_Arbitrary(SDL_AudioCVT *cvt, const int channels)
|
|||||||
const int srcsize = cvt->len_cvt - (64 * channels);
|
const int srcsize = cvt->len_cvt - (64 * channels);
|
||||||
const int dstsize = (int) (((double)(cvt->len_cvt/(channels*4))) * cvt->rate_incr) * (channels*4);
|
const int dstsize = (int) (((double)(cvt->len_cvt/(channels*4))) * cvt->rate_incr) * (channels*4);
|
||||||
register int eps = 0;
|
register int eps = 0;
|
||||||
float *dst = ((float *) (cvt->buf + dstsize)) - 8;
|
float *dst = ((float *) (cvt->buf + dstsize)) - channels;
|
||||||
const float *src = ((float *) (cvt->buf + cvt->len_cvt)) - 8;
|
const float *src = ((float *) (cvt->buf + cvt->len_cvt)) - channels;
|
||||||
const float *target = ((const float *) cvt->buf);
|
const float *target = ((const float *) cvt->buf);
|
||||||
const size_t cpy = sizeof (float) * channels;
|
const size_t cpy = sizeof (float) * channels;
|
||||||
float last_sample[8];
|
float last_sample[8];
|
||||||
@ -241,10 +241,10 @@ SDL_Upsample_Arbitrary(SDL_AudioCVT *cvt, const int channels)
|
|||||||
|
|
||||||
while (dst > target) {
|
while (dst > target) {
|
||||||
SDL_memcpy(dst, sample, cpy);
|
SDL_memcpy(dst, sample, cpy);
|
||||||
dst -= 8;
|
dst -= channels;
|
||||||
eps += srcsize;
|
eps += srcsize;
|
||||||
if ((eps << 1) >= dstsize) {
|
if ((eps << 1) >= dstsize) {
|
||||||
src -= 8;
|
src -= channels;
|
||||||
for (i = 0; i < channels; i++) {
|
for (i = 0; i < channels; i++) {
|
||||||
sample[i] = (float) ((((double) src[i]) + ((double) last_sample[i])) * 0.5);
|
sample[i] = (float) ((((double) src[i]) + ((double) last_sample[i])) * 0.5);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user