Merge pull request #88658 from akien-mga/fix-audio-effect-pitch-shift-Wstring-overflow-take-2
AudioEffectPitchShift: Actually fix `-Wstringop-overflow warning`
This commit is contained in:
commit
a735c51c3c
2 changed files with 21 additions and 46 deletions
|
@ -87,10 +87,8 @@ void SMBPitchShift::PitchShift(float pitchShift, long numSampsToProcess, long ff
|
||||||
double magn, phase, tmp, window, real, imag;
|
double magn, phase, tmp, window, real, imag;
|
||||||
double freqPerBin, expct;
|
double freqPerBin, expct;
|
||||||
long i,k, qpd, index, inFifoLatency, stepSize, fftFrameSize2;
|
long i,k, qpd, index, inFifoLatency, stepSize, fftFrameSize2;
|
||||||
unsigned long fftFrameBufferSize;
|
|
||||||
|
|
||||||
/* set up some handy variables */
|
/* set up some handy variables */
|
||||||
fftFrameBufferSize = (unsigned long)fftFrameSize*sizeof(float);
|
|
||||||
fftFrameSize2 = fftFrameSize/2;
|
fftFrameSize2 = fftFrameSize/2;
|
||||||
stepSize = fftFrameSize/osamp;
|
stepSize = fftFrameSize/osamp;
|
||||||
freqPerBin = sampleRate/(double)fftFrameSize;
|
freqPerBin = sampleRate/(double)fftFrameSize;
|
||||||
|
@ -162,8 +160,8 @@ void SMBPitchShift::PitchShift(float pitchShift, long numSampsToProcess, long ff
|
||||||
|
|
||||||
/* ***************** PROCESSING ******************* */
|
/* ***************** PROCESSING ******************* */
|
||||||
/* this does the actual pitch shifting */
|
/* this does the actual pitch shifting */
|
||||||
memset(gSynMagn, 0, fftFrameBufferSize);
|
memset(gSynMagn, 0, fftFrameSize*sizeof(float));
|
||||||
memset(gSynFreq, 0, fftFrameBufferSize);
|
memset(gSynFreq, 0, fftFrameSize*sizeof(float));
|
||||||
for (k = 0; k <= fftFrameSize2; k++) {
|
for (k = 0; k <= fftFrameSize2; k++) {
|
||||||
index = k*pitchShift;
|
index = k*pitchShift;
|
||||||
if (index <= fftFrameSize2) {
|
if (index <= fftFrameSize2) {
|
||||||
|
@ -216,7 +214,7 @@ void SMBPitchShift::PitchShift(float pitchShift, long numSampsToProcess, long ff
|
||||||
}
|
}
|
||||||
|
|
||||||
/* shift accumulator */
|
/* shift accumulator */
|
||||||
memmove(gOutputAccum, gOutputAccum+stepSize, fftFrameBufferSize);
|
memmove(gOutputAccum, gOutputAccum+stepSize, fftFrameSize*sizeof(float));
|
||||||
|
|
||||||
/* move input FIFO */
|
/* move input FIFO */
|
||||||
for (k = 0; k < inFifoLatency; k++) { gInFIFO[k] = gInFIFO[k+stepSize];
|
for (k = 0; k < inFifoLatency; k++) { gInFIFO[k] = gInFIFO[k+stepSize];
|
||||||
|
@ -358,12 +356,3 @@ void AudioEffectPitchShift::_bind_methods() {
|
||||||
BIND_ENUM_CONSTANT(FFT_SIZE_4096);
|
BIND_ENUM_CONSTANT(FFT_SIZE_4096);
|
||||||
BIND_ENUM_CONSTANT(FFT_SIZE_MAX);
|
BIND_ENUM_CONSTANT(FFT_SIZE_MAX);
|
||||||
}
|
}
|
||||||
|
|
||||||
AudioEffectPitchShift::AudioEffectPitchShift() {
|
|
||||||
pitch_scale = 1.0;
|
|
||||||
oversampling = 4;
|
|
||||||
fft_size = FFT_SIZE_2048;
|
|
||||||
wet = 0.0;
|
|
||||||
dry = 0.0;
|
|
||||||
filter = false;
|
|
||||||
}
|
|
||||||
|
|
|
@ -38,34 +38,22 @@ class SMBPitchShift {
|
||||||
MAX_FRAME_LENGTH = 8192
|
MAX_FRAME_LENGTH = 8192
|
||||||
};
|
};
|
||||||
|
|
||||||
float gInFIFO[MAX_FRAME_LENGTH];
|
float gInFIFO[MAX_FRAME_LENGTH] = {};
|
||||||
float gOutFIFO[MAX_FRAME_LENGTH];
|
float gOutFIFO[MAX_FRAME_LENGTH] = {};
|
||||||
float gFFTworksp[2 * MAX_FRAME_LENGTH];
|
float gFFTworksp[2 * MAX_FRAME_LENGTH] = {};
|
||||||
float gLastPhase[MAX_FRAME_LENGTH / 2 + 1];
|
float gLastPhase[MAX_FRAME_LENGTH / 2 + 1] = {};
|
||||||
float gSumPhase[MAX_FRAME_LENGTH / 2 + 1];
|
float gSumPhase[MAX_FRAME_LENGTH / 2 + 1] = {};
|
||||||
float gOutputAccum[2 * MAX_FRAME_LENGTH];
|
float gOutputAccum[2 * MAX_FRAME_LENGTH] = {};
|
||||||
float gAnaFreq[MAX_FRAME_LENGTH];
|
float gAnaFreq[MAX_FRAME_LENGTH] = {};
|
||||||
float gAnaMagn[MAX_FRAME_LENGTH];
|
float gAnaMagn[MAX_FRAME_LENGTH] = {};
|
||||||
float gSynFreq[MAX_FRAME_LENGTH];
|
float gSynFreq[MAX_FRAME_LENGTH] = {};
|
||||||
float gSynMagn[MAX_FRAME_LENGTH];
|
float gSynMagn[MAX_FRAME_LENGTH] = {};
|
||||||
long gRover;
|
long gRover = 0;
|
||||||
|
|
||||||
void smbFft(float *fftBuffer, long fftFrameSize, long sign);
|
void smbFft(float *fftBuffer, long fftFrameSize, long sign);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void PitchShift(float pitchShift, long numSampsToProcess, long fftFrameSize, long osamp, float sampleRate, float *indata, float *outdata, int stride);
|
void PitchShift(float pitchShift, long numSampsToProcess, long fftFrameSize, long osamp, float sampleRate, float *indata, float *outdata, int stride);
|
||||||
|
|
||||||
SMBPitchShift() {
|
|
||||||
gRover = 0;
|
|
||||||
memset(gInFIFO, 0, MAX_FRAME_LENGTH * sizeof(float));
|
|
||||||
memset(gOutFIFO, 0, MAX_FRAME_LENGTH * sizeof(float));
|
|
||||||
memset(gFFTworksp, 0, 2 * MAX_FRAME_LENGTH * sizeof(float));
|
|
||||||
memset(gLastPhase, 0, (MAX_FRAME_LENGTH / 2 + 1) * sizeof(float));
|
|
||||||
memset(gSumPhase, 0, (MAX_FRAME_LENGTH / 2 + 1) * sizeof(float));
|
|
||||||
memset(gOutputAccum, 0, 2 * MAX_FRAME_LENGTH * sizeof(float));
|
|
||||||
memset(gAnaFreq, 0, MAX_FRAME_LENGTH * sizeof(float));
|
|
||||||
memset(gAnaMagn, 0, MAX_FRAME_LENGTH * sizeof(float));
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class AudioEffectPitchShift;
|
class AudioEffectPitchShift;
|
||||||
|
@ -75,7 +63,7 @@ class AudioEffectPitchShiftInstance : public AudioEffectInstance {
|
||||||
friend class AudioEffectPitchShift;
|
friend class AudioEffectPitchShift;
|
||||||
Ref<AudioEffectPitchShift> base;
|
Ref<AudioEffectPitchShift> base;
|
||||||
|
|
||||||
int fft_size;
|
int fft_size = 0;
|
||||||
SMBPitchShift shift_l;
|
SMBPitchShift shift_l;
|
||||||
SMBPitchShift shift_r;
|
SMBPitchShift shift_r;
|
||||||
|
|
||||||
|
@ -98,12 +86,12 @@ public:
|
||||||
FFT_SIZE_MAX
|
FFT_SIZE_MAX
|
||||||
};
|
};
|
||||||
|
|
||||||
float pitch_scale;
|
float pitch_scale = 1.0;
|
||||||
int oversampling;
|
int oversampling = 4;
|
||||||
FFTSize fft_size;
|
FFTSize fft_size = FFT_SIZE_2048;
|
||||||
float wet;
|
float wet = 0.0;
|
||||||
float dry;
|
float dry = 0.0;
|
||||||
bool filter;
|
bool filter = false;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
@ -119,8 +107,6 @@ public:
|
||||||
|
|
||||||
void set_fft_size(FFTSize);
|
void set_fft_size(FFTSize);
|
||||||
FFTSize get_fft_size() const;
|
FFTSize get_fft_size() const;
|
||||||
|
|
||||||
AudioEffectPitchShift();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
VARIANT_ENUM_CAST(AudioEffectPitchShift::FFTSize);
|
VARIANT_ENUM_CAST(AudioEffectPitchShift::FFTSize);
|
||||||
|
|
Loading…
Reference in a new issue