ffmdec: reject zero-sized chunks

If size is zero, avio_get_str fails, leaving the buffer uninitialized.
This causes invalid reads in av_set_options_string.

Reviewed-by: Michael Niedermayer <michael@niedermayer.cc>
Signed-off-by: Andreas Cadhalpun <Andreas.Cadhalpun@googlemail.com>
pull/162/merge
Andreas Cadhalpun 9 years ago
parent 488e9a06f0
commit a611375db5
  1. 4
      libavformat/ffmdec.c

@ -423,7 +423,7 @@ static int ffm2_read_header(AVFormatContext *s)
}
break;
case MKBETAG('S', '2', 'V', 'I'):
if (f_stvi++) {
if (f_stvi++ || !size) {
ret = AVERROR(EINVAL);
goto fail;
}
@ -438,7 +438,7 @@ static int ffm2_read_header(AVFormatContext *s)
goto fail;
break;
case MKBETAG('S', '2', 'A', 'U'):
if (f_stau++) {
if (f_stau++ || !size) {
ret = AVERROR(EINVAL);
goto fail;
}

Loading…
Cancel
Save