From 79bf02f5e3938e4bbe5af244342c9b4445022ffe Mon Sep 17 00:00:00 2001 From: Thomas Jentzsch Date: Fri, 16 Sep 2022 15:18:24 +0200 Subject: [PATCH] eliminated frequent memory allocation while playing WAV files --- src/common/SoundSDL2.cxx | 23 ++++++++++++++++++----- src/common/SoundSDL2.hxx | 2 ++ 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/src/common/SoundSDL2.cxx b/src/common/SoundSDL2.cxx index 03045a3f7..f00c5b4b5 100644 --- a/src/common/SoundSDL2.cxx +++ b/src/common/SoundSDL2.cxx @@ -474,6 +474,12 @@ void SoundSDL2::stopWav() SDL_FreeWAV(myWavBuffer); myWavBuffer = nullptr; } + if(myWavCvtBuffer) + { + SDL_free(myWavCvtBuffer); + myWavCvtBuffer = nullptr; + myWavCvtBufferSize = 0; + } } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -492,7 +498,6 @@ void SoundSDL2::wavCallback(void* udata, uInt8* stream, int len) if(myWavSpeed != 1.0) { const int origLen = len; - len = std::round(len / myWavSpeed); const int newFreq = std::round(static_cast(myWavSpec.freq) * origLen / len); @@ -504,16 +509,22 @@ void SoundSDL2::wavCallback(void* udata, uInt8* stream, int len) myWavSpec.format, myWavSpec.channels, newFreq); SDL_assert(cvt.needed); // Obviously, this one is always needed. cvt.len = len * myWavSpec.channels; // Mono 8 bit sample frames - cvt.buf = static_cast(SDL_malloc(cvt.len * cvt.len_mult)); + + if(!myWavCvtBuffer || myWavCvtBufferSize < static_cast(cvt.len * cvt.len_mult)) + { + if(myWavCvtBuffer) + SDL_free(myWavCvtBuffer); + myWavCvtBufferSize = cvt.len * cvt.len_mult; + myWavCvtBuffer = static_cast(SDL_malloc(myWavCvtBufferSize)); + } + //cvt.buf = static_cast(SDL_malloc(cvt.len * cvt.len_mult)); + cvt.buf = myWavCvtBuffer; // Read original data into conversion buffer SDL_memcpy(cvt.buf, myWavPos, cvt.len); SDL_ConvertAudio(&cvt); // Mix volume adjusted WAV data into silent buffer SDL_MixAudioFormat(stream, cvt.buf, myWavSpec.format, cvt.len_cvt, SDL_MIX_MAXVOLUME * myWavVolumeFactor); - SDL_free(cvt.buf); - - cerr << cvt.len_cvt << " "; } else #endif @@ -537,6 +548,8 @@ uInt8* SoundSDL2::myWavPos = nullptr; // pointer to the audio buffer to be playe uInt32 SoundSDL2::myWavLen = 0; // remaining length of the sample we have to play #ifdef RESAMPLE_WAV double SoundSDL2::myWavSpeed = 1.0; +uInt8* SoundSDL2::myWavCvtBuffer = nullptr; +uInt32 SoundSDL2::myWavCvtBufferSize = 0; #endif #endif // SOUND_SUPPORT diff --git a/src/common/SoundSDL2.hxx b/src/common/SoundSDL2.hxx index bc2270f7c..affcb889d 100644 --- a/src/common/SoundSDL2.hxx +++ b/src/common/SoundSDL2.hxx @@ -196,6 +196,8 @@ class SoundSDL2 : public Sound uInt8* myWavBuffer{nullptr}; #ifdef RESAMPLE_WAV static double myWavSpeed; + static uInt8* myWavCvtBuffer; + static uInt32 myWavCvtBufferSize; #endif static float myWavVolumeFactor;