Browse Source

vc1: explicitly zero interlaced mode coding variables for progressive mode

Both v->fcm and v->field_mode are used in common code, now they won't be
reset for progressive frame after interlaced one causing writing past the
frame end for example.

Signed-off-by: Ronald S. Bultje <rsbultje@gmail.com>
tags/n0.9
Kostya Shishkov Ronald S. Bultje 13 years ago
parent
commit
42feaf4070
1 changed files with 3 additions and 2 deletions
  1. +3
    -2
      libavcodec/vc1.c

+ 3
- 2
libavcodec/vc1.c View File

@@ -832,17 +832,18 @@ int vc1_parse_frame_header_adv(VC1Context *v, GetBitContext* gb)
goto parse_common_info;
}

v->field_mode = 0;
if (v->interlace) {
v->fcm = decode012(gb);
if (v->fcm) {
if (v->fcm == 2)
v->field_mode = 1;
else
v->field_mode = 0;
if (!v->warn_interlaced++)
av_log(v->s.avctx, AV_LOG_ERROR,
"Interlaced frames/fields support is incomplete\n");
}
} else {
v->fcm = 0;
}

if (v->field_mode) {


Loading…
Cancel
Save