mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
avcodec/pcm-dvd: discard buffer if block size changed
This prevents a potential crash Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
parent
789cd1de99
commit
7c1805869d
@ -31,6 +31,7 @@
|
|||||||
typedef struct PCMDVDContext {
|
typedef struct PCMDVDContext {
|
||||||
uint32_t last_header; // Cached header to see if parsing is needed
|
uint32_t last_header; // Cached header to see if parsing is needed
|
||||||
int block_size; // Size of a block of samples in bytes
|
int block_size; // Size of a block of samples in bytes
|
||||||
|
int last_block_size; // Size of the last block of samples in bytes
|
||||||
int samples_per_block; // Number of samples per channel per block
|
int samples_per_block; // Number of samples per channel per block
|
||||||
int groups_per_block; // Number of 20/24bit sample groups per block
|
int groups_per_block; // Number of 20/24bit sample groups per block
|
||||||
uint8_t *extra_samples; // Pointer to leftover samples from a frame
|
uint8_t *extra_samples; // Pointer to leftover samples from a frame
|
||||||
@ -223,6 +224,11 @@ static int pcm_dvd_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
|
|
||||||
if ((retval = pcm_dvd_parse_header(avctx, src)))
|
if ((retval = pcm_dvd_parse_header(avctx, src)))
|
||||||
return retval;
|
return retval;
|
||||||
|
if (s->last_block_size != s->block_size) {
|
||||||
|
av_log(avctx, AV_LOG_WARNING, "block_size has changed\n");
|
||||||
|
s->extra_sample_count = 0;
|
||||||
|
}
|
||||||
|
s->last_block_size = s->block_size;
|
||||||
src += 3;
|
src += 3;
|
||||||
buf_size -= 3;
|
buf_size -= 3;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user