]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
Previous commit missed an initialization - this fixes FATE's test sample.
authorastrange <astrange@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Sun, 11 May 2008 23:39:55 +0000 (23:39 +0000)
committerastrange <astrange@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Sun, 11 May 2008 23:39:55 +0000 (23:39 +0000)
git-svn-id: file:///var/local/repositories/ffmpeg/trunk@13131 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

libavcodec/svq3.c

index ac16cd835478715f2272e6b0b35f352d6a4c9c0d..340ca120354d76ce59723a7458784ee22ec38614 100644 (file)
@@ -681,11 +681,9 @@ static int svq3_decode_mb (H264Context *h, unsigned int mb_type) {
 
 static int svq3_decode_slice_header (H264Context *h) {
   MpegEncContext *const s = (MpegEncContext *) h;
-  int mb_xy;
+  const int mb_xy = h->mb_xy;
   int i, header;
 
-  mb_xy = h->mb_xy = s->mb_x + s->mb_y*s->mb_stride;
-
   header = get_bits (&s->gb, 8);
 
   if (((header & 0x9F) != 1 && (header & 0x9F) != 2) || (header & 0x60) == 0) {
@@ -844,7 +842,7 @@ static int svq3_decode_frame (AVCodecContext *avctx,
 
   init_get_bits (&s->gb, buf, 8*buf_size);
 
-  s->mb_x = s->mb_y = 0;
+  s->mb_x = s->mb_y = h->mb_xy = 0;
 
   if (svq3_decode_slice_header (h))
     return -1;
@@ -917,6 +915,7 @@ static int svq3_decode_frame (AVCodecContext *avctx,
 
   for (s->mb_y=0; s->mb_y < s->mb_height; s->mb_y++) {
     for (s->mb_x=0; s->mb_x < s->mb_width; s->mb_x++) {
+      h->mb_xy = s->mb_x + s->mb_y*s->mb_stride;
 
       if ( (get_bits_count(&s->gb) + 7) >= s->gb.size_in_bits &&
           ((get_bits_count(&s->gb) & 7) == 0 || show_bits (&s->gb, (-get_bits_count(&s->gb) & 7)) == 0)) {