summaryrefslogtreecommitdiff
path: root/libavcodec/h261dec.c
diff options
context:
space:
mode:
authorJohn Stebbins <stebbins@jetheaddev.com>2014-08-08 08:55:48 -0700
committerJohn Stebbins <stebbins@jetheaddev.com>2014-08-14 07:58:50 -0700
commit552bc42df48784ae3ce0d499ece5b33f3cc7576a (patch)
treede8da4e241f34b617ca2ac26ddaf0497eca97856 /libavcodec/h261dec.c
parentb869eea7ea8f5d8331fcd6355f848bb6a6e06b14 (diff)
h261dec: Fix order of initialization
ff_MPV_common_init requires the frame dimensions which get parsed in h261_decode_picture_header.
Diffstat (limited to 'libavcodec/h261dec.c')
-rw-r--r--libavcodec/h261dec.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/libavcodec/h261dec.c b/libavcodec/h261dec.c
index 88ca63ddc6..6b358a6d5c 100644
--- a/libavcodec/h261dec.c
+++ b/libavcodec/h261dec.c
@@ -581,12 +581,9 @@ static int h261_decode_frame(AVCodecContext *avctx, void *data,
retry:
init_get_bits(&s->gb, buf, buf_size * 8);
- if (!s->context_initialized) {
+ if (!s->context_initialized)
// we need the IDCT permutaton for reading a custom matrix
ff_mpv_idct_init(s);
- if (ff_MPV_common_init(s) < 0)
- return -1;
- }
ret = h261_decode_picture_header(h);
@@ -602,6 +599,11 @@ retry:
ff_MPV_common_end(s);
s->parse_context = pc;
}
+
+ if (!s->context_initialized)
+ if ((ret = ff_MPV_common_init(s)) < 0)
+ return ret;
+
if (!s->context_initialized) {
ret = ff_set_dimensions(avctx, s->width, s->height);
if (ret < 0)