mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-07-01 05:31:04 +08:00
shorten: do not modify samples pointer when interleaving
This commit is contained in:
@ -252,12 +252,13 @@ static int decode_wave_header(AVCodecContext *avctx, const uint8_t *header,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int16_t * interleave_buffer(int16_t *samples, int nchan, int blocksize, int32_t **buffer) {
|
static void interleave_buffer(int16_t *samples, int nchan, int blocksize,
|
||||||
|
int32_t **buffer)
|
||||||
|
{
|
||||||
int i, chan;
|
int i, chan;
|
||||||
for (i=0; i<blocksize; i++)
|
for (i=0; i<blocksize; i++)
|
||||||
for (chan=0; chan < nchan; chan++)
|
for (chan=0; chan < nchan; chan++)
|
||||||
*samples++ = av_clip_int16(buffer[chan][i]);
|
*samples++ = av_clip_int16(buffer[chan][i]);
|
||||||
return samples;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const int fixed_coeffs[3][3] = {
|
static const int fixed_coeffs[3][3] = {
|
||||||
@ -576,7 +577,7 @@ static int shorten_decode_frame(AVCodecContext *avctx,
|
|||||||
av_log(avctx, AV_LOG_ERROR, "Output buffer is too small\n");
|
av_log(avctx, AV_LOG_ERROR, "Output buffer is too small\n");
|
||||||
return AVERROR(EINVAL);
|
return AVERROR(EINVAL);
|
||||||
}
|
}
|
||||||
samples = interleave_buffer(samples, s->channels, s->blocksize, s->decoded);
|
interleave_buffer(samples, s->channels, s->blocksize, s->decoded);
|
||||||
*data_size = out_size;
|
*data_size = out_size;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user