]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/blob - libavcodec/vp3.c
Fix compilation when Theora decoder is disabled, but VP3 is enabled.
[frescor/ffmpeg.git] / libavcodec / vp3.c
1 /*
2  * Copyright (C) 2003-2004 the ffmpeg project
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  *
20  */
21
22 /**
23  * @file vp3.c
24  * On2 VP3 Video Decoder
25  *
26  * VP3 Video Decoder by Mike Melanson (mike at multimedia.cx)
27  * For more information about the VP3 coding process, visit:
28  *   http://multimedia.cx/
29  *
30  * Theora decoder by Alex Beregszaszi
31  */
32
33 #include <stdio.h>
34 #include <stdlib.h>
35 #include <string.h>
36 #include <unistd.h>
37
38 #include "common.h"
39 #include "avcodec.h"
40 #include "dsputil.h"
41 #include "mpegvideo.h"
42
43 #include "vp3data.h"
44 #include "xiph.h"
45
46 #define FRAGMENT_PIXELS 8
47
48 /*
49  * Debugging Variables
50  *
51  * Define one or more of the following compile-time variables to 1 to obtain
52  * elaborate information about certain aspects of the decoding process.
53  *
54  * KEYFRAMES_ONLY: set this to 1 to only see keyframes (VP3 slideshow mode)
55  * DEBUG_VP3: high-level decoding flow
56  * DEBUG_INIT: initialization parameters
57  * DEBUG_DEQUANTIZERS: display how the dequanization tables are built
58  * DEBUG_BLOCK_CODING: unpacking the superblock/macroblock/fragment coding
59  * DEBUG_MODES: unpacking the coding modes for individual fragments
60  * DEBUG_VECTORS: display the motion vectors
61  * DEBUG_TOKEN: display exhaustive information about each DCT token
62  * DEBUG_VLC: display the VLCs as they are extracted from the stream
63  * DEBUG_DC_PRED: display the process of reversing DC prediction
64  * DEBUG_IDCT: show every detail of the IDCT process
65  */
66
67 #define KEYFRAMES_ONLY 0
68
69 #define DEBUG_VP3 0
70 #define DEBUG_INIT 0
71 #define DEBUG_DEQUANTIZERS 0
72 #define DEBUG_BLOCK_CODING 0
73 #define DEBUG_MODES 0
74 #define DEBUG_VECTORS 0
75 #define DEBUG_TOKEN 0
76 #define DEBUG_VLC 0
77 #define DEBUG_DC_PRED 0
78 #define DEBUG_IDCT 0
79
80 #if DEBUG_VP3
81 #define debug_vp3(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
82 #else
83 static inline void debug_vp3(const char *format, ...) { }
84 #endif
85
86 #if DEBUG_INIT
87 #define debug_init(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
88 #else
89 static inline void debug_init(const char *format, ...) { }
90 #endif
91
92 #if DEBUG_DEQUANTIZERS
93 #define debug_dequantizers(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
94 #else
95 static inline void debug_dequantizers(const char *format, ...) { }
96 #endif
97
98 #if DEBUG_BLOCK_CODING
99 #define debug_block_coding(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
100 #else
101 static inline void debug_block_coding(const char *format, ...) { }
102 #endif
103
104 #if DEBUG_MODES
105 #define debug_modes(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
106 #else
107 static inline void debug_modes(const char *format, ...) { }
108 #endif
109
110 #if DEBUG_VECTORS
111 #define debug_vectors(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
112 #else
113 static inline void debug_vectors(const char *format, ...) { }
114 #endif
115
116 #if DEBUG_TOKEN
117 #define debug_token(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
118 #else
119 static inline void debug_token(const char *format, ...) { }
120 #endif
121
122 #if DEBUG_VLC
123 #define debug_vlc(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
124 #else
125 static inline void debug_vlc(const char *format, ...) { }
126 #endif
127
128 #if DEBUG_DC_PRED
129 #define debug_dc_pred(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
130 #else
131 static inline void debug_dc_pred(const char *format, ...) { }
132 #endif
133
134 #if DEBUG_IDCT
135 #define debug_idct(args...) av_log(NULL, AV_LOG_DEBUG, ## args)
136 #else
137 static inline void debug_idct(const char *format, ...) { }
138 #endif
139
140 typedef struct Coeff {
141     struct Coeff *next;
142     DCTELEM coeff;
143     uint8_t index;
144 } Coeff;
145
146 //FIXME split things out into their own arrays
147 typedef struct Vp3Fragment {
148     Coeff *next_coeff;
149     /* address of first pixel taking into account which plane the fragment
150      * lives on as well as the plane stride */
151     int first_pixel;
152     /* this is the macroblock that the fragment belongs to */
153     uint16_t macroblock;
154     uint8_t coding_method;
155     uint8_t coeff_count;
156     int8_t motion_x;
157     int8_t motion_y;
158 } Vp3Fragment;
159
160 #define SB_NOT_CODED        0
161 #define SB_PARTIALLY_CODED  1
162 #define SB_FULLY_CODED      2
163
164 #define MODE_INTER_NO_MV      0
165 #define MODE_INTRA            1
166 #define MODE_INTER_PLUS_MV    2
167 #define MODE_INTER_LAST_MV    3
168 #define MODE_INTER_PRIOR_LAST 4
169 #define MODE_USING_GOLDEN     5
170 #define MODE_GOLDEN_MV        6
171 #define MODE_INTER_FOURMV     7
172 #define CODING_MODE_COUNT     8
173
174 /* special internal mode */
175 #define MODE_COPY             8
176
177 /* There are 6 preset schemes, plus a free-form scheme */
178 static int ModeAlphabet[7][CODING_MODE_COUNT] =
179 {
180     /* this is the custom scheme */
181     { 0, 0, 0, 0, 0, 0, 0, 0 },
182
183     /* scheme 1: Last motion vector dominates */
184     {    MODE_INTER_LAST_MV,    MODE_INTER_PRIOR_LAST,
185          MODE_INTER_PLUS_MV,    MODE_INTER_NO_MV,
186          MODE_INTRA,            MODE_USING_GOLDEN,
187          MODE_GOLDEN_MV,        MODE_INTER_FOURMV },
188
189     /* scheme 2 */
190     {    MODE_INTER_LAST_MV,    MODE_INTER_PRIOR_LAST,
191          MODE_INTER_NO_MV,      MODE_INTER_PLUS_MV,
192          MODE_INTRA,            MODE_USING_GOLDEN,
193          MODE_GOLDEN_MV,        MODE_INTER_FOURMV },
194
195     /* scheme 3 */
196     {    MODE_INTER_LAST_MV,    MODE_INTER_PLUS_MV,
197          MODE_INTER_PRIOR_LAST, MODE_INTER_NO_MV,
198          MODE_INTRA,            MODE_USING_GOLDEN,
199          MODE_GOLDEN_MV,        MODE_INTER_FOURMV },
200
201     /* scheme 4 */
202     {    MODE_INTER_LAST_MV,    MODE_INTER_PLUS_MV,
203          MODE_INTER_NO_MV,      MODE_INTER_PRIOR_LAST,
204          MODE_INTRA,            MODE_USING_GOLDEN,
205          MODE_GOLDEN_MV,        MODE_INTER_FOURMV },
206
207     /* scheme 5: No motion vector dominates */
208     {    MODE_INTER_NO_MV,      MODE_INTER_LAST_MV,
209          MODE_INTER_PRIOR_LAST, MODE_INTER_PLUS_MV,
210          MODE_INTRA,            MODE_USING_GOLDEN,
211          MODE_GOLDEN_MV,        MODE_INTER_FOURMV },
212
213     /* scheme 6 */
214     {    MODE_INTER_NO_MV,      MODE_USING_GOLDEN,
215          MODE_INTER_LAST_MV,    MODE_INTER_PRIOR_LAST,
216          MODE_INTER_PLUS_MV,    MODE_INTRA,
217          MODE_GOLDEN_MV,        MODE_INTER_FOURMV },
218
219 };
220
221 #define MIN_DEQUANT_VAL 2
222
223 typedef struct Vp3DecodeContext {
224     AVCodecContext *avctx;
225     int theora, theora_tables;
226     int version;
227     int width, height;
228     AVFrame golden_frame;
229     AVFrame last_frame;
230     AVFrame current_frame;
231     int keyframe;
232     DSPContext dsp;
233     int flipped_image;
234
235     int qis[3];
236     int nqis;
237     int quality_index;
238     int last_quality_index;
239
240     int superblock_count;
241     int superblock_width;
242     int superblock_height;
243     int y_superblock_width;
244     int y_superblock_height;
245     int c_superblock_width;
246     int c_superblock_height;
247     int u_superblock_start;
248     int v_superblock_start;
249     unsigned char *superblock_coding;
250
251     int macroblock_count;
252     int macroblock_width;
253     int macroblock_height;
254
255     int fragment_count;
256     int fragment_width;
257     int fragment_height;
258
259     Vp3Fragment *all_fragments;
260     Coeff *coeffs;
261     Coeff *next_coeff;
262     int fragment_start[3];
263
264     ScanTable scantable;
265
266     /* tables */
267     uint16_t coded_dc_scale_factor[64];
268     uint32_t coded_ac_scale_factor[64];
269     uint8_t base_matrix[384][64];
270     uint8_t qr_count[2][3];
271     uint8_t qr_size [2][3][64];
272     uint16_t qr_base[2][3][64];
273
274     /* this is a list of indices into the all_fragments array indicating
275      * which of the fragments are coded */
276     int *coded_fragment_list;
277     int coded_fragment_list_index;
278     int pixel_addresses_inited;
279
280     VLC dc_vlc[16];
281     VLC ac_vlc_1[16];
282     VLC ac_vlc_2[16];
283     VLC ac_vlc_3[16];
284     VLC ac_vlc_4[16];
285
286     VLC superblock_run_length_vlc;
287     VLC fragment_run_length_vlc;
288     VLC mode_code_vlc;
289     VLC motion_vector_vlc;
290
291     /* these arrays need to be on 16-byte boundaries since SSE2 operations
292      * index into them */
293     DECLARE_ALIGNED_16(int16_t, qmat[2][4][64]);        //<qmat[is_inter][plane]
294
295     /* This table contains superblock_count * 16 entries. Each set of 16
296      * numbers corresponds to the fragment indices 0..15 of the superblock.
297      * An entry will be -1 to indicate that no entry corresponds to that
298      * index. */
299     int *superblock_fragments;
300
301     /* This table contains superblock_count * 4 entries. Each set of 4
302      * numbers corresponds to the macroblock indices 0..3 of the superblock.
303      * An entry will be -1 to indicate that no entry corresponds to that
304      * index. */
305     int *superblock_macroblocks;
306
307     /* This table contains macroblock_count * 6 entries. Each set of 6
308      * numbers corresponds to the fragment indices 0..5 which comprise
309      * the macroblock (4 Y fragments and 2 C fragments). */
310     int *macroblock_fragments;
311     /* This is an array that indicates how a particular macroblock
312      * is coded. */
313     unsigned char *macroblock_coding;
314
315     int first_coded_y_fragment;
316     int first_coded_c_fragment;
317     int last_coded_y_fragment;
318     int last_coded_c_fragment;
319
320     uint8_t edge_emu_buffer[9*2048]; //FIXME dynamic alloc
321     int8_t qscale_table[2048]; //FIXME dynamic alloc (width+15)/16
322
323     /* Huffman decode */
324     int hti;
325     unsigned int hbits;
326     int entries;
327     int huff_code_size;
328     uint16_t huffman_table[80][32][2];
329
330     uint32_t filter_limit_values[64];
331     int bounding_values_array[256];
332 } Vp3DecodeContext;
333
334 static int theora_decode_tables(AVCodecContext *avctx, GetBitContext *gb);
335
336 /************************************************************************
337  * VP3 specific functions
338  ************************************************************************/
339
340 /*
341  * This function sets up all of the various blocks mappings:
342  * superblocks <-> fragments, macroblocks <-> fragments,
343  * superblocks <-> macroblocks
344  *
345  * Returns 0 is successful; returns 1 if *anything* went wrong.
346  */
347 static int init_block_mapping(Vp3DecodeContext *s)
348 {
349     int i, j;
350     signed int hilbert_walk_mb[4];
351
352     int current_fragment = 0;
353     int current_width = 0;
354     int current_height = 0;
355     int right_edge = 0;
356     int bottom_edge = 0;
357     int superblock_row_inc = 0;
358     int *hilbert = NULL;
359     int mapping_index = 0;
360
361     int current_macroblock;
362     int c_fragment;
363
364     signed char travel_width[16] = {
365          1,  1,  0, -1,
366          0,  0,  1,  0,
367          1,  0,  1,  0,
368          0, -1,  0,  1
369     };
370
371     signed char travel_height[16] = {
372          0,  0,  1,  0,
373          1,  1,  0, -1,
374          0,  1,  0, -1,
375         -1,  0, -1,  0
376     };
377
378     signed char travel_width_mb[4] = {
379          1,  0,  1,  0
380     };
381
382     signed char travel_height_mb[4] = {
383          0,  1,  0, -1
384     };
385
386     debug_vp3("  vp3: initialize block mapping tables\n");
387
388     hilbert_walk_mb[0] = 1;
389     hilbert_walk_mb[1] = s->macroblock_width;
390     hilbert_walk_mb[2] = 1;
391     hilbert_walk_mb[3] = -s->macroblock_width;
392
393     /* iterate through each superblock (all planes) and map the fragments */
394     for (i = 0; i < s->superblock_count; i++) {
395         debug_init("    superblock %d (u starts @ %d, v starts @ %d)\n",
396             i, s->u_superblock_start, s->v_superblock_start);
397
398         /* time to re-assign the limits? */
399         if (i == 0) {
400
401             /* start of Y superblocks */
402             right_edge = s->fragment_width;
403             bottom_edge = s->fragment_height;
404             current_width = -1;
405             current_height = 0;
406             superblock_row_inc = 3 * s->fragment_width -
407                 (s->y_superblock_width * 4 - s->fragment_width);
408
409             /* the first operation for this variable is to advance by 1 */
410             current_fragment = -1;
411
412         } else if (i == s->u_superblock_start) {
413
414             /* start of U superblocks */
415             right_edge = s->fragment_width / 2;
416             bottom_edge = s->fragment_height / 2;
417             current_width = -1;
418             current_height = 0;
419             superblock_row_inc = 3 * (s->fragment_width / 2) -
420                 (s->c_superblock_width * 4 - s->fragment_width / 2);
421
422             /* the first operation for this variable is to advance by 1 */
423             current_fragment = s->fragment_start[1] - 1;
424
425         } else if (i == s->v_superblock_start) {
426
427             /* start of V superblocks */
428             right_edge = s->fragment_width / 2;
429             bottom_edge = s->fragment_height / 2;
430             current_width = -1;
431             current_height = 0;
432             superblock_row_inc = 3 * (s->fragment_width / 2) -
433                 (s->c_superblock_width * 4 - s->fragment_width / 2);
434
435             /* the first operation for this variable is to advance by 1 */
436             current_fragment = s->fragment_start[2] - 1;
437
438         }
439
440         if (current_width >= right_edge - 1) {
441             /* reset width and move to next superblock row */
442             current_width = -1;
443             current_height += 4;
444
445             /* fragment is now at the start of a new superblock row */
446             current_fragment += superblock_row_inc;
447         }
448
449         /* iterate through all 16 fragments in a superblock */
450         for (j = 0; j < 16; j++) {
451             current_fragment += travel_width[j] + right_edge * travel_height[j];
452             current_width += travel_width[j];
453             current_height += travel_height[j];
454
455             /* check if the fragment is in bounds */
456             if ((current_width < right_edge) &&
457                 (current_height < bottom_edge)) {
458                 s->superblock_fragments[mapping_index] = current_fragment;
459                 debug_init("    mapping fragment %d to superblock %d, position %d (%d/%d x %d/%d)\n",
460                     s->superblock_fragments[mapping_index], i, j,
461                     current_width, right_edge, current_height, bottom_edge);
462             } else {
463                 s->superblock_fragments[mapping_index] = -1;
464                 debug_init("    superblock %d, position %d has no fragment (%d/%d x %d/%d)\n",
465                     i, j,
466                     current_width, right_edge, current_height, bottom_edge);
467             }
468
469             mapping_index++;
470         }
471     }
472
473     /* initialize the superblock <-> macroblock mapping; iterate through
474      * all of the Y plane superblocks to build this mapping */
475     right_edge = s->macroblock_width;
476     bottom_edge = s->macroblock_height;
477     current_width = -1;
478     current_height = 0;
479     superblock_row_inc = s->macroblock_width -
480         (s->y_superblock_width * 2 - s->macroblock_width);;
481     hilbert = hilbert_walk_mb;
482     mapping_index = 0;
483     current_macroblock = -1;
484     for (i = 0; i < s->u_superblock_start; i++) {
485
486         if (current_width >= right_edge - 1) {
487             /* reset width and move to next superblock row */
488             current_width = -1;
489             current_height += 2;
490
491             /* macroblock is now at the start of a new superblock row */
492             current_macroblock += superblock_row_inc;
493         }
494
495         /* iterate through each potential macroblock in the superblock */
496         for (j = 0; j < 4; j++) {
497             current_macroblock += hilbert_walk_mb[j];
498             current_width += travel_width_mb[j];
499             current_height += travel_height_mb[j];
500
501             /* check if the macroblock is in bounds */
502             if ((current_width < right_edge) &&
503                 (current_height < bottom_edge)) {
504                 s->superblock_macroblocks[mapping_index] = current_macroblock;
505                 debug_init("    mapping macroblock %d to superblock %d, position %d (%d/%d x %d/%d)\n",
506                     s->superblock_macroblocks[mapping_index], i, j,
507                     current_width, right_edge, current_height, bottom_edge);
508             } else {
509                 s->superblock_macroblocks[mapping_index] = -1;
510                 debug_init("    superblock %d, position %d has no macroblock (%d/%d x %d/%d)\n",
511                     i, j,
512                     current_width, right_edge, current_height, bottom_edge);
513             }
514
515             mapping_index++;
516         }
517     }
518
519     /* initialize the macroblock <-> fragment mapping */
520     current_fragment = 0;
521     current_macroblock = 0;
522     mapping_index = 0;
523     for (i = 0; i < s->fragment_height; i += 2) {
524
525         for (j = 0; j < s->fragment_width; j += 2) {
526
527             debug_init("    macroblock %d contains fragments: ", current_macroblock);
528             s->all_fragments[current_fragment].macroblock = current_macroblock;
529             s->macroblock_fragments[mapping_index++] = current_fragment;
530             debug_init("%d ", current_fragment);
531
532             if (j + 1 < s->fragment_width) {
533                 s->all_fragments[current_fragment + 1].macroblock = current_macroblock;
534                 s->macroblock_fragments[mapping_index++] = current_fragment + 1;
535                 debug_init("%d ", current_fragment + 1);
536             } else
537                 s->macroblock_fragments[mapping_index++] = -1;
538
539             if (i + 1 < s->fragment_height) {
540                 s->all_fragments[current_fragment + s->fragment_width].macroblock =
541                     current_macroblock;
542                 s->macroblock_fragments[mapping_index++] =
543                     current_fragment + s->fragment_width;
544                 debug_init("%d ", current_fragment + s->fragment_width);
545             } else
546                 s->macroblock_fragments[mapping_index++] = -1;
547
548             if ((j + 1 < s->fragment_width) && (i + 1 < s->fragment_height)) {
549                 s->all_fragments[current_fragment + s->fragment_width + 1].macroblock =
550                     current_macroblock;
551                 s->macroblock_fragments[mapping_index++] =
552                     current_fragment + s->fragment_width + 1;
553                 debug_init("%d ", current_fragment + s->fragment_width + 1);
554             } else
555                 s->macroblock_fragments[mapping_index++] = -1;
556
557             /* C planes */
558             c_fragment = s->fragment_start[1] +
559                 (i * s->fragment_width / 4) + (j / 2);
560             s->all_fragments[c_fragment].macroblock = s->macroblock_count;
561             s->macroblock_fragments[mapping_index++] = c_fragment;
562             debug_init("%d ", c_fragment);
563
564             c_fragment = s->fragment_start[2] +
565                 (i * s->fragment_width / 4) + (j / 2);
566             s->all_fragments[c_fragment].macroblock = s->macroblock_count;
567             s->macroblock_fragments[mapping_index++] = c_fragment;
568             debug_init("%d ", c_fragment);
569
570             debug_init("\n");
571
572             if (j + 2 <= s->fragment_width)
573                 current_fragment += 2;
574             else
575                 current_fragment++;
576             current_macroblock++;
577         }
578
579         current_fragment += s->fragment_width;
580     }
581
582     return 0;  /* successful path out */
583 }
584
585 /*
586  * This function wipes out all of the fragment data.
587  */
588 static void init_frame(Vp3DecodeContext *s, GetBitContext *gb)
589 {
590     int i;
591
592     /* zero out all of the fragment information */
593     s->coded_fragment_list_index = 0;
594     for (i = 0; i < s->fragment_count; i++) {
595         s->all_fragments[i].coeff_count = 0;
596         s->all_fragments[i].motion_x = 127;
597         s->all_fragments[i].motion_y = 127;
598         s->all_fragments[i].next_coeff= NULL;
599         s->coeffs[i].index=
600         s->coeffs[i].coeff=0;
601         s->coeffs[i].next= NULL;
602     }
603 }
604
605 /*
606  * This function sets up the dequantization tables used for a particular
607  * frame.
608  */
609 static void init_dequantizer(Vp3DecodeContext *s)
610 {
611     int ac_scale_factor = s->coded_ac_scale_factor[s->quality_index];
612     int dc_scale_factor = s->coded_dc_scale_factor[s->quality_index];
613     int i, plane, inter, qri, bmi, bmj, qistart;
614
615     debug_vp3("  vp3: initializing dequantization tables\n");
616
617     for(inter=0; inter<2; inter++){
618         for(plane=0; plane<3; plane++){
619             int sum=0;
620             for(qri=0; qri<s->qr_count[inter][plane]; qri++){
621                 sum+= s->qr_size[inter][plane][qri];
622                 if(s->quality_index <= sum)
623                     break;
624             }
625             qistart= sum - s->qr_size[inter][plane][qri];
626             bmi= s->qr_base[inter][plane][qri  ];
627             bmj= s->qr_base[inter][plane][qri+1];
628             for(i=0; i<64; i++){
629                 int coeff= (  2*(sum    -s->quality_index)*s->base_matrix[bmi][i]
630                             - 2*(qistart-s->quality_index)*s->base_matrix[bmj][i]
631                             + s->qr_size[inter][plane][qri])
632                            / (2*s->qr_size[inter][plane][qri]);
633
634                 int qmin= 8<<(inter + !i);
635                 int qscale= i ? ac_scale_factor : dc_scale_factor;
636
637                 s->qmat[inter][plane][i]= av_clip((qscale * coeff)/100 * 4, qmin, 4096);
638             }
639         }
640     }
641
642     memset(s->qscale_table, (FFMAX(s->qmat[0][0][1], s->qmat[0][1][1])+8)/16, 512); //FIXME finetune
643 }
644
645 /*
646  * This function initializes the loop filter boundary limits if the frame's
647  * quality index is different from the previous frame's.
648  */
649 static void init_loop_filter(Vp3DecodeContext *s)
650 {
651     int *bounding_values= s->bounding_values_array+127;
652     int filter_limit;
653     int x;
654
655     filter_limit = s->filter_limit_values[s->quality_index];
656
657     /* set up the bounding values */
658     memset(s->bounding_values_array, 0, 256 * sizeof(int));
659     for (x = 0; x < filter_limit; x++) {
660         bounding_values[-x - filter_limit] = -filter_limit + x;
661         bounding_values[-x] = -x;
662         bounding_values[x] = x;
663         bounding_values[x + filter_limit] = filter_limit - x;
664     }
665 }
666
667 /*
668  * This function unpacks all of the superblock/macroblock/fragment coding
669  * information from the bitstream.
670  */
671 static int unpack_superblocks(Vp3DecodeContext *s, GetBitContext *gb)
672 {
673     int bit = 0;
674     int current_superblock = 0;
675     int current_run = 0;
676     int decode_fully_flags = 0;
677     int decode_partial_blocks = 0;
678     int first_c_fragment_seen;
679
680     int i, j;
681     int current_fragment;
682
683     debug_vp3("  vp3: unpacking superblock coding\n");
684
685     if (s->keyframe) {
686
687         debug_vp3("    keyframe-- all superblocks are fully coded\n");
688         memset(s->superblock_coding, SB_FULLY_CODED, s->superblock_count);
689
690     } else {
691
692         /* unpack the list of partially-coded superblocks */
693         bit = get_bits(gb, 1);
694         /* toggle the bit because as soon as the first run length is
695          * fetched the bit will be toggled again */
696         bit ^= 1;
697         while (current_superblock < s->superblock_count) {
698             if (current_run-- == 0) {
699                 bit ^= 1;
700                 current_run = get_vlc2(gb,
701                     s->superblock_run_length_vlc.table, 6, 2);
702                 if (current_run == 33)
703                     current_run += get_bits(gb, 12);
704                 debug_block_coding("      setting superblocks %d..%d to %s\n",
705                     current_superblock,
706                     current_superblock + current_run - 1,
707                     (bit) ? "partially coded" : "not coded");
708
709                 /* if any of the superblocks are not partially coded, flag
710                  * a boolean to decode the list of fully-coded superblocks */
711                 if (bit == 0) {
712                     decode_fully_flags = 1;
713                 } else {
714
715                     /* make a note of the fact that there are partially coded
716                      * superblocks */
717                     decode_partial_blocks = 1;
718                 }
719             }
720             s->superblock_coding[current_superblock++] = bit;
721         }
722
723         /* unpack the list of fully coded superblocks if any of the blocks were
724          * not marked as partially coded in the previous step */
725         if (decode_fully_flags) {
726
727             current_superblock = 0;
728             current_run = 0;
729             bit = get_bits(gb, 1);
730             /* toggle the bit because as soon as the first run length is
731              * fetched the bit will be toggled again */
732             bit ^= 1;
733             while (current_superblock < s->superblock_count) {
734
735                 /* skip any superblocks already marked as partially coded */
736                 if (s->superblock_coding[current_superblock] == SB_NOT_CODED) {
737
738                     if (current_run-- == 0) {
739                         bit ^= 1;
740                         current_run = get_vlc2(gb,
741                             s->superblock_run_length_vlc.table, 6, 2);
742                         if (current_run == 33)
743                             current_run += get_bits(gb, 12);
744                     }
745
746                     debug_block_coding("      setting superblock %d to %s\n",
747                         current_superblock,
748                         (bit) ? "fully coded" : "not coded");
749                     s->superblock_coding[current_superblock] = 2*bit;
750                 }
751                 current_superblock++;
752             }
753         }
754
755         /* if there were partial blocks, initialize bitstream for
756          * unpacking fragment codings */
757         if (decode_partial_blocks) {
758
759             current_run = 0;
760             bit = get_bits(gb, 1);
761             /* toggle the bit because as soon as the first run length is
762              * fetched the bit will be toggled again */
763             bit ^= 1;
764         }
765     }
766
767     /* figure out which fragments are coded; iterate through each
768      * superblock (all planes) */
769     s->coded_fragment_list_index = 0;
770     s->next_coeff= s->coeffs + s->fragment_count;
771     s->first_coded_y_fragment = s->first_coded_c_fragment = 0;
772     s->last_coded_y_fragment = s->last_coded_c_fragment = -1;
773     first_c_fragment_seen = 0;
774     memset(s->macroblock_coding, MODE_COPY, s->macroblock_count);
775     for (i = 0; i < s->superblock_count; i++) {
776
777         /* iterate through all 16 fragments in a superblock */
778         for (j = 0; j < 16; j++) {
779
780             /* if the fragment is in bounds, check its coding status */
781             current_fragment = s->superblock_fragments[i * 16 + j];
782             if (current_fragment >= s->fragment_count) {
783                 av_log(s->avctx, AV_LOG_ERROR, "  vp3:unpack_superblocks(): bad fragment number (%d >= %d)\n",
784                     current_fragment, s->fragment_count);
785                 return 1;
786             }
787             if (current_fragment != -1) {
788                 if (s->superblock_coding[i] == SB_NOT_CODED) {
789
790                     /* copy all the fragments from the prior frame */
791                     s->all_fragments[current_fragment].coding_method =
792                         MODE_COPY;
793
794                 } else if (s->superblock_coding[i] == SB_PARTIALLY_CODED) {
795
796                     /* fragment may or may not be coded; this is the case
797                      * that cares about the fragment coding runs */
798                     if (current_run-- == 0) {
799                         bit ^= 1;
800                         current_run = get_vlc2(gb,
801                             s->fragment_run_length_vlc.table, 5, 2);
802                     }
803
804                     if (bit) {
805                         /* default mode; actual mode will be decoded in
806                          * the next phase */
807                         s->all_fragments[current_fragment].coding_method =
808                             MODE_INTER_NO_MV;
809                         s->all_fragments[current_fragment].next_coeff= s->coeffs + current_fragment;
810                         s->coded_fragment_list[s->coded_fragment_list_index] =
811                             current_fragment;
812                         if ((current_fragment >= s->fragment_start[1]) &&
813                             (s->last_coded_y_fragment == -1) &&
814                             (!first_c_fragment_seen)) {
815                             s->first_coded_c_fragment = s->coded_fragment_list_index;
816                             s->last_coded_y_fragment = s->first_coded_c_fragment - 1;
817                             first_c_fragment_seen = 1;
818                         }
819                         s->coded_fragment_list_index++;
820                         s->macroblock_coding[s->all_fragments[current_fragment].macroblock] = MODE_INTER_NO_MV;
821                         debug_block_coding("      superblock %d is partially coded, fragment %d is coded\n",
822                             i, current_fragment);
823                     } else {
824                         /* not coded; copy this fragment from the prior frame */
825                         s->all_fragments[current_fragment].coding_method =
826                             MODE_COPY;
827                         debug_block_coding("      superblock %d is partially coded, fragment %d is not coded\n",
828                             i, current_fragment);
829                     }
830
831                 } else {
832
833                     /* fragments are fully coded in this superblock; actual
834                      * coding will be determined in next step */
835                     s->all_fragments[current_fragment].coding_method =
836                         MODE_INTER_NO_MV;
837                     s->all_fragments[current_fragment].next_coeff= s->coeffs + current_fragment;
838                     s->coded_fragment_list[s->coded_fragment_list_index] =
839                         current_fragment;
840                     if ((current_fragment >= s->fragment_start[1]) &&
841                         (s->last_coded_y_fragment == -1) &&
842                         (!first_c_fragment_seen)) {
843                         s->first_coded_c_fragment = s->coded_fragment_list_index;
844                         s->last_coded_y_fragment = s->first_coded_c_fragment - 1;
845                         first_c_fragment_seen = 1;
846                     }
847                     s->coded_fragment_list_index++;
848                     s->macroblock_coding[s->all_fragments[current_fragment].macroblock] = MODE_INTER_NO_MV;
849                     debug_block_coding("      superblock %d is fully coded, fragment %d is coded\n",
850                         i, current_fragment);
851                 }
852             }
853         }
854     }
855
856     if (!first_c_fragment_seen)
857         /* only Y fragments coded in this frame */
858         s->last_coded_y_fragment = s->coded_fragment_list_index - 1;
859     else
860         /* end the list of coded C fragments */
861         s->last_coded_c_fragment = s->coded_fragment_list_index - 1;
862
863     debug_block_coding("    %d total coded fragments, y: %d -> %d, c: %d -> %d\n",
864         s->coded_fragment_list_index,
865         s->first_coded_y_fragment,
866         s->last_coded_y_fragment,
867         s->first_coded_c_fragment,
868         s->last_coded_c_fragment);
869
870     return 0;
871 }
872
873 /*
874  * This function unpacks all the coding mode data for individual macroblocks
875  * from the bitstream.
876  */
877 static int unpack_modes(Vp3DecodeContext *s, GetBitContext *gb)
878 {
879     int i, j, k;
880     int scheme;
881     int current_macroblock;
882     int current_fragment;
883     int coding_mode;
884
885     debug_vp3("  vp3: unpacking encoding modes\n");
886
887     if (s->keyframe) {
888         debug_vp3("    keyframe-- all blocks are coded as INTRA\n");
889
890         for (i = 0; i < s->fragment_count; i++)
891             s->all_fragments[i].coding_method = MODE_INTRA;
892
893     } else {
894
895         /* fetch the mode coding scheme for this frame */
896         scheme = get_bits(gb, 3);
897         debug_modes("    using mode alphabet %d\n", scheme);
898
899         /* is it a custom coding scheme? */
900         if (scheme == 0) {
901             debug_modes("    custom mode alphabet ahead:\n");
902             for (i = 0; i < 8; i++)
903                 ModeAlphabet[scheme][get_bits(gb, 3)] = i;
904         }
905
906         for (i = 0; i < 8; i++)
907             debug_modes("      mode[%d][%d] = %d\n", scheme, i,
908                 ModeAlphabet[scheme][i]);
909
910         /* iterate through all of the macroblocks that contain 1 or more
911          * coded fragments */
912         for (i = 0; i < s->u_superblock_start; i++) {
913
914             for (j = 0; j < 4; j++) {
915                 current_macroblock = s->superblock_macroblocks[i * 4 + j];
916                 if ((current_macroblock == -1) ||
917                     (s->macroblock_coding[current_macroblock] == MODE_COPY))
918                     continue;
919                 if (current_macroblock >= s->macroblock_count) {
920                     av_log(s->avctx, AV_LOG_ERROR, "  vp3:unpack_modes(): bad macroblock number (%d >= %d)\n",
921                         current_macroblock, s->macroblock_count);
922                     return 1;
923                 }
924
925                 /* mode 7 means get 3 bits for each coding mode */
926                 if (scheme == 7)
927                     coding_mode = get_bits(gb, 3);
928                 else
929                     coding_mode = ModeAlphabet[scheme]
930                         [get_vlc2(gb, s->mode_code_vlc.table, 3, 3)];
931
932                 s->macroblock_coding[current_macroblock] = coding_mode;
933                 for (k = 0; k < 6; k++) {
934                     current_fragment =
935                         s->macroblock_fragments[current_macroblock * 6 + k];
936                     if (current_fragment == -1)
937                         continue;
938                     if (current_fragment >= s->fragment_count) {
939                         av_log(s->avctx, AV_LOG_ERROR, "  vp3:unpack_modes(): bad fragment number (%d >= %d)\n",
940                             current_fragment, s->fragment_count);
941                         return 1;
942                     }
943                     if (s->all_fragments[current_fragment].coding_method !=
944                         MODE_COPY)
945                         s->all_fragments[current_fragment].coding_method =
946                             coding_mode;
947                 }
948
949                 debug_modes("    coding method for macroblock starting @ fragment %d = %d\n",
950                     s->macroblock_fragments[current_macroblock * 6], coding_mode);
951             }
952         }
953     }
954
955     return 0;
956 }
957
958 /*
959  * This function unpacks all the motion vectors for the individual
960  * macroblocks from the bitstream.
961  */
962 static int unpack_vectors(Vp3DecodeContext *s, GetBitContext *gb)
963 {
964     int i, j, k;
965     int coding_mode;
966     int motion_x[6];
967     int motion_y[6];
968     int last_motion_x = 0;
969     int last_motion_y = 0;
970     int prior_last_motion_x = 0;
971     int prior_last_motion_y = 0;
972     int current_macroblock;
973     int current_fragment;
974
975     debug_vp3("  vp3: unpacking motion vectors\n");
976     if (s->keyframe) {
977
978         debug_vp3("    keyframe-- there are no motion vectors\n");
979
980     } else {
981
982         memset(motion_x, 0, 6 * sizeof(int));
983         memset(motion_y, 0, 6 * sizeof(int));
984
985         /* coding mode 0 is the VLC scheme; 1 is the fixed code scheme */
986         coding_mode = get_bits(gb, 1);
987         debug_vectors("    using %s scheme for unpacking motion vectors\n",
988             (coding_mode == 0) ? "VLC" : "fixed-length");
989
990         /* iterate through all of the macroblocks that contain 1 or more
991          * coded fragments */
992         for (i = 0; i < s->u_superblock_start; i++) {
993
994             for (j = 0; j < 4; j++) {
995                 current_macroblock = s->superblock_macroblocks[i * 4 + j];
996                 if ((current_macroblock == -1) ||
997                     (s->macroblock_coding[current_macroblock] == MODE_COPY))
998                     continue;
999                 if (current_macroblock >= s->macroblock_count) {
1000                     av_log(s->avctx, AV_LOG_ERROR, "  vp3:unpack_vectors(): bad macroblock number (%d >= %d)\n",
1001                         current_macroblock, s->macroblock_count);
1002                     return 1;
1003                 }
1004
1005                 current_fragment = s->macroblock_fragments[current_macroblock * 6];
1006                 if (current_fragment >= s->fragment_count) {
1007                     av_log(s->avctx, AV_LOG_ERROR, "  vp3:unpack_vectors(): bad fragment number (%d >= %d\n",
1008                         current_fragment, s->fragment_count);
1009                     return 1;
1010                 }
1011                 switch (s->macroblock_coding[current_macroblock]) {
1012
1013                 case MODE_INTER_PLUS_MV:
1014                 case MODE_GOLDEN_MV:
1015                     /* all 6 fragments use the same motion vector */
1016                     if (coding_mode == 0) {
1017                         motion_x[0] = motion_vector_table[get_vlc2(gb, s->motion_vector_vlc.table, 6, 2)];
1018                         motion_y[0] = motion_vector_table[get_vlc2(gb, s->motion_vector_vlc.table, 6, 2)];
1019                     } else {
1020                         motion_x[0] = fixed_motion_vector_table[get_bits(gb, 6)];
1021                         motion_y[0] = fixed_motion_vector_table[get_bits(gb, 6)];
1022                     }
1023
1024                     for (k = 1; k < 6; k++) {
1025                         motion_x[k] = motion_x[0];
1026                         motion_y[k] = motion_y[0];
1027                     }
1028
1029                     /* vector maintenance, only on MODE_INTER_PLUS_MV */
1030                     if (s->macroblock_coding[current_macroblock] ==
1031                         MODE_INTER_PLUS_MV) {
1032                         prior_last_motion_x = last_motion_x;
1033                         prior_last_motion_y = last_motion_y;
1034                         last_motion_x = motion_x[0];
1035                         last_motion_y = motion_y[0];
1036                     }
1037                     break;
1038
1039                 case MODE_INTER_FOURMV:
1040                     /* fetch 4 vectors from the bitstream, one for each
1041                      * Y fragment, then average for the C fragment vectors */
1042                     motion_x[4] = motion_y[4] = 0;
1043                     for (k = 0; k < 4; k++) {
1044                         if (coding_mode == 0) {
1045                             motion_x[k] = motion_vector_table[get_vlc2(gb, s->motion_vector_vlc.table, 6, 2)];
1046                             motion_y[k] = motion_vector_table[get_vlc2(gb, s->motion_vector_vlc.table, 6, 2)];
1047                         } else {
1048                             motion_x[k] = fixed_motion_vector_table[get_bits(gb, 6)];
1049                             motion_y[k] = fixed_motion_vector_table[get_bits(gb, 6)];
1050                         }
1051                         motion_x[4] += motion_x[k];
1052                         motion_y[4] += motion_y[k];
1053                     }
1054
1055                     motion_x[5]=
1056                     motion_x[4]= RSHIFT(motion_x[4], 2);
1057                     motion_y[5]=
1058                     motion_y[4]= RSHIFT(motion_y[4], 2);
1059
1060                     /* vector maintenance; vector[3] is treated as the
1061                      * last vector in this case */
1062                     prior_last_motion_x = last_motion_x;
1063                     prior_last_motion_y = last_motion_y;
1064                     last_motion_x = motion_x[3];
1065                     last_motion_y = motion_y[3];
1066                     break;
1067
1068                 case MODE_INTER_LAST_MV:
1069                     /* all 6 fragments use the last motion vector */
1070                     motion_x[0] = last_motion_x;
1071                     motion_y[0] = last_motion_y;
1072                     for (k = 1; k < 6; k++) {
1073                         motion_x[k] = motion_x[0];
1074                         motion_y[k] = motion_y[0];
1075                     }
1076
1077                     /* no vector maintenance (last vector remains the
1078                      * last vector) */
1079                     break;
1080
1081                 case MODE_INTER_PRIOR_LAST:
1082                     /* all 6 fragments use the motion vector prior to the
1083                      * last motion vector */
1084                     motion_x[0] = prior_last_motion_x;
1085                     motion_y[0] = prior_last_motion_y;
1086                     for (k = 1; k < 6; k++) {
1087                         motion_x[k] = motion_x[0];
1088                         motion_y[k] = motion_y[0];
1089                     }
1090
1091                     /* vector maintenance */
1092                     prior_last_motion_x = last_motion_x;
1093                     prior_last_motion_y = last_motion_y;
1094                     last_motion_x = motion_x[0];
1095                     last_motion_y = motion_y[0];
1096                     break;
1097
1098                 default:
1099                     /* covers intra, inter without MV, golden without MV */
1100                     memset(motion_x, 0, 6 * sizeof(int));
1101                     memset(motion_y, 0, 6 * sizeof(int));
1102
1103                     /* no vector maintenance */
1104                     break;
1105                 }
1106
1107                 /* assign the motion vectors to the correct fragments */
1108                 debug_vectors("    vectors for macroblock starting @ fragment %d (coding method %d):\n",
1109                     current_fragment,
1110                     s->macroblock_coding[current_macroblock]);
1111                 for (k = 0; k < 6; k++) {
1112                     current_fragment =
1113                         s->macroblock_fragments[current_macroblock * 6 + k];
1114                     if (current_fragment == -1)
1115                         continue;
1116                     if (current_fragment >= s->fragment_count) {
1117                         av_log(s->avctx, AV_LOG_ERROR, "  vp3:unpack_vectors(): bad fragment number (%d >= %d)\n",
1118                             current_fragment, s->fragment_count);
1119                         return 1;
1120                     }
1121                     s->all_fragments[current_fragment].motion_x = motion_x[k];
1122                     s->all_fragments[current_fragment].motion_y = motion_y[k];
1123                     debug_vectors("    vector %d: fragment %d = (%d, %d)\n",
1124                         k, current_fragment, motion_x[k], motion_y[k]);
1125                 }
1126             }
1127         }
1128     }
1129
1130     return 0;
1131 }
1132
1133 /*
1134  * This function is called by unpack_dct_coeffs() to extract the VLCs from
1135  * the bitstream. The VLCs encode tokens which are used to unpack DCT
1136  * data. This function unpacks all the VLCs for either the Y plane or both
1137  * C planes, and is called for DC coefficients or different AC coefficient
1138  * levels (since different coefficient types require different VLC tables.
1139  *
1140  * This function returns a residual eob run. E.g, if a particular token gave
1141  * instructions to EOB the next 5 fragments and there were only 2 fragments
1142  * left in the current fragment range, 3 would be returned so that it could
1143  * be passed into the next call to this same function.
1144  */
1145 static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb,
1146                         VLC *table, int coeff_index,
1147                         int first_fragment, int last_fragment,
1148                         int eob_run)
1149 {
1150     int i;
1151     int token;
1152     int zero_run = 0;
1153     DCTELEM coeff = 0;
1154     Vp3Fragment *fragment;
1155     uint8_t *perm= s->scantable.permutated;
1156     int bits_to_get;
1157
1158     if ((first_fragment >= s->fragment_count) ||
1159         (last_fragment >= s->fragment_count)) {
1160
1161         av_log(s->avctx, AV_LOG_ERROR, "  vp3:unpack_vlcs(): bad fragment number (%d -> %d ?)\n",
1162             first_fragment, last_fragment);
1163         return 0;
1164     }
1165
1166     for (i = first_fragment; i <= last_fragment; i++) {
1167
1168         fragment = &s->all_fragments[s->coded_fragment_list[i]];
1169         if (fragment->coeff_count > coeff_index)
1170             continue;
1171
1172         if (!eob_run) {
1173             /* decode a VLC into a token */
1174             token = get_vlc2(gb, table->table, 5, 3);
1175             debug_vlc(" token = %2d, ", token);
1176             /* use the token to get a zero run, a coefficient, and an eob run */
1177             if (token <= 6) {
1178                 eob_run = eob_run_base[token];
1179                 if (eob_run_get_bits[token])
1180                     eob_run += get_bits(gb, eob_run_get_bits[token]);
1181                 coeff = zero_run = 0;
1182             } else {
1183                 bits_to_get = coeff_get_bits[token];
1184                 if (!bits_to_get)
1185                     coeff = coeff_tables[token][0];
1186                 else
1187                     coeff = coeff_tables[token][get_bits(gb, bits_to_get)];
1188
1189                 zero_run = zero_run_base[token];
1190                 if (zero_run_get_bits[token])
1191                     zero_run += get_bits(gb, zero_run_get_bits[token]);
1192             }
1193         }
1194
1195         if (!eob_run) {
1196             fragment->coeff_count += zero_run;
1197             if (fragment->coeff_count < 64){
1198                 fragment->next_coeff->coeff= coeff;
1199                 fragment->next_coeff->index= perm[fragment->coeff_count++]; //FIXME perm here already?
1200                 fragment->next_coeff->next= s->next_coeff;
1201                 s->next_coeff->next=NULL;
1202                 fragment->next_coeff= s->next_coeff++;
1203             }
1204             debug_vlc(" fragment %d coeff = %d\n",
1205                 s->coded_fragment_list[i], fragment->next_coeff[coeff_index]);
1206         } else {
1207             fragment->coeff_count |= 128;
1208             debug_vlc(" fragment %d eob with %d coefficients\n",
1209                 s->coded_fragment_list[i], fragment->coeff_count&127);
1210             eob_run--;
1211         }
1212     }
1213
1214     return eob_run;
1215 }
1216
1217 /*
1218  * This function unpacks all of the DCT coefficient data from the
1219  * bitstream.
1220  */
1221 static int unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb)
1222 {
1223     int i;
1224     int dc_y_table;
1225     int dc_c_table;
1226     int ac_y_table;
1227     int ac_c_table;
1228     int residual_eob_run = 0;
1229
1230     /* fetch the DC table indices */
1231     dc_y_table = get_bits(gb, 4);
1232     dc_c_table = get_bits(gb, 4);
1233
1234     /* unpack the Y plane DC coefficients */
1235     debug_vp3("  vp3: unpacking Y plane DC coefficients using table %d\n",
1236         dc_y_table);
1237     residual_eob_run = unpack_vlcs(s, gb, &s->dc_vlc[dc_y_table], 0,
1238         s->first_coded_y_fragment, s->last_coded_y_fragment, residual_eob_run);
1239
1240     /* unpack the C plane DC coefficients */
1241     debug_vp3("  vp3: unpacking C plane DC coefficients using table %d\n",
1242         dc_c_table);
1243     residual_eob_run = unpack_vlcs(s, gb, &s->dc_vlc[dc_c_table], 0,
1244         s->first_coded_c_fragment, s->last_coded_c_fragment, residual_eob_run);
1245
1246     /* fetch the AC table indices */
1247     ac_y_table = get_bits(gb, 4);
1248     ac_c_table = get_bits(gb, 4);
1249
1250     /* unpack the group 1 AC coefficients (coeffs 1-5) */
1251     for (i = 1; i <= 5; i++) {
1252
1253         debug_vp3("  vp3: unpacking level %d Y plane AC coefficients using table %d\n",
1254             i, ac_y_table);
1255         residual_eob_run = unpack_vlcs(s, gb, &s->ac_vlc_1[ac_y_table], i,
1256             s->first_coded_y_fragment, s->last_coded_y_fragment, residual_eob_run);
1257
1258         debug_vp3("  vp3: unpacking level %d C plane AC coefficients using table %d\n",
1259             i, ac_c_table);
1260         residual_eob_run = unpack_vlcs(s, gb, &s->ac_vlc_1[ac_c_table], i,
1261             s->first_coded_c_fragment, s->last_coded_c_fragment, residual_eob_run);
1262     }
1263
1264     /* unpack the group 2 AC coefficients (coeffs 6-14) */
1265     for (i = 6; i <= 14; i++) {
1266
1267         debug_vp3("  vp3: unpacking level %d Y plane AC coefficients using table %d\n",
1268             i, ac_y_table);
1269         residual_eob_run = unpack_vlcs(s, gb, &s->ac_vlc_2[ac_y_table], i,
1270             s->first_coded_y_fragment, s->last_coded_y_fragment, residual_eob_run);
1271
1272         debug_vp3("  vp3: unpacking level %d C plane AC coefficients using table %d\n",
1273             i, ac_c_table);
1274         residual_eob_run = unpack_vlcs(s, gb, &s->ac_vlc_2[ac_c_table], i,
1275             s->first_coded_c_fragment, s->last_coded_c_fragment, residual_eob_run);
1276     }
1277
1278     /* unpack the group 3 AC coefficients (coeffs 15-27) */
1279     for (i = 15; i <= 27; i++) {
1280
1281         debug_vp3("  vp3: unpacking level %d Y plane AC coefficients using table %d\n",
1282             i, ac_y_table);
1283         residual_eob_run = unpack_vlcs(s, gb, &s->ac_vlc_3[ac_y_table], i,
1284             s->first_coded_y_fragment, s->last_coded_y_fragment, residual_eob_run);
1285
1286         debug_vp3("  vp3: unpacking level %d C plane AC coefficients using table %d\n",
1287             i, ac_c_table);
1288         residual_eob_run = unpack_vlcs(s, gb, &s->ac_vlc_3[ac_c_table], i,
1289             s->first_coded_c_fragment, s->last_coded_c_fragment, residual_eob_run);
1290     }
1291
1292     /* unpack the group 4 AC coefficients (coeffs 28-63) */
1293     for (i = 28; i <= 63; i++) {
1294
1295         debug_vp3("  vp3: unpacking level %d Y plane AC coefficients using table %d\n",
1296             i, ac_y_table);
1297         residual_eob_run = unpack_vlcs(s, gb, &s->ac_vlc_4[ac_y_table], i,
1298             s->first_coded_y_fragment, s->last_coded_y_fragment, residual_eob_run);
1299
1300         debug_vp3("  vp3: unpacking level %d C plane AC coefficients using table %d\n",
1301             i, ac_c_table);
1302         residual_eob_run = unpack_vlcs(s, gb, &s->ac_vlc_4[ac_c_table], i,
1303             s->first_coded_c_fragment, s->last_coded_c_fragment, residual_eob_run);
1304     }
1305
1306     return 0;
1307 }
1308
1309 /*
1310  * This function reverses the DC prediction for each coded fragment in
1311  * the frame. Much of this function is adapted directly from the original
1312  * VP3 source code.
1313  */
1314 #define COMPATIBLE_FRAME(x) \
1315   (compatible_frame[s->all_fragments[x].coding_method] == current_frame_type)
1316 #define FRAME_CODED(x) (s->all_fragments[x].coding_method != MODE_COPY)
1317 #define DC_COEFF(u) (s->coeffs[u].index ? 0 : s->coeffs[u].coeff) //FIXME do somethin to simplify this
1318
1319 static void reverse_dc_prediction(Vp3DecodeContext *s,
1320                                   int first_fragment,
1321                                   int fragment_width,
1322                                   int fragment_height)
1323 {
1324
1325 #define PUL 8
1326 #define PU 4
1327 #define PUR 2
1328 #define PL 1
1329
1330     int x, y;
1331     int i = first_fragment;
1332
1333     int predicted_dc;
1334
1335     /* DC values for the left, up-left, up, and up-right fragments */
1336     int vl, vul, vu, vur;
1337
1338     /* indices for the left, up-left, up, and up-right fragments */
1339     int l, ul, u, ur;
1340
1341     /*
1342      * The 6 fields mean:
1343      *   0: up-left multiplier
1344      *   1: up multiplier
1345      *   2: up-right multiplier
1346      *   3: left multiplier
1347      */
1348     int predictor_transform[16][4] = {
1349         {  0,  0,  0,  0},
1350         {  0,  0,  0,128},        // PL
1351         {  0,  0,128,  0},        // PUR
1352         {  0,  0, 53, 75},        // PUR|PL
1353         {  0,128,  0,  0},        // PU
1354         {  0, 64,  0, 64},        // PU|PL
1355         {  0,128,  0,  0},        // PU|PUR
1356         {  0,  0, 53, 75},        // PU|PUR|PL
1357         {128,  0,  0,  0},        // PUL
1358         {  0,  0,  0,128},        // PUL|PL
1359         { 64,  0, 64,  0},        // PUL|PUR
1360         {  0,  0, 53, 75},        // PUL|PUR|PL
1361         {  0,128,  0,  0},        // PUL|PU
1362        {-104,116,  0,116},        // PUL|PU|PL
1363         { 24, 80, 24,  0},        // PUL|PU|PUR
1364        {-104,116,  0,116}         // PUL|PU|PUR|PL
1365     };
1366
1367     /* This table shows which types of blocks can use other blocks for
1368      * prediction. For example, INTRA is the only mode in this table to
1369      * have a frame number of 0. That means INTRA blocks can only predict
1370      * from other INTRA blocks. There are 2 golden frame coding types;
1371      * blocks encoding in these modes can only predict from other blocks
1372      * that were encoded with these 1 of these 2 modes. */
1373     unsigned char compatible_frame[8] = {
1374         1,    /* MODE_INTER_NO_MV */
1375         0,    /* MODE_INTRA */
1376         1,    /* MODE_INTER_PLUS_MV */
1377         1,    /* MODE_INTER_LAST_MV */
1378         1,    /* MODE_INTER_PRIOR_MV */
1379         2,    /* MODE_USING_GOLDEN */
1380         2,    /* MODE_GOLDEN_MV */
1381         1     /* MODE_INTER_FOUR_MV */
1382     };
1383     int current_frame_type;
1384
1385     /* there is a last DC predictor for each of the 3 frame types */
1386     short last_dc[3];
1387
1388     int transform = 0;
1389
1390     debug_vp3("  vp3: reversing DC prediction\n");
1391
1392     vul = vu = vur = vl = 0;
1393     last_dc[0] = last_dc[1] = last_dc[2] = 0;
1394
1395     /* for each fragment row... */
1396     for (y = 0; y < fragment_height; y++) {
1397
1398         /* for each fragment in a row... */
1399         for (x = 0; x < fragment_width; x++, i++) {
1400
1401             /* reverse prediction if this block was coded */
1402             if (s->all_fragments[i].coding_method != MODE_COPY) {
1403
1404                 current_frame_type =
1405                     compatible_frame[s->all_fragments[i].coding_method];
1406                 debug_dc_pred(" frag %d: orig DC = %d, ",
1407                     i, DC_COEFF(i));
1408
1409                 transform= 0;
1410                 if(x){
1411                     l= i-1;
1412                     vl = DC_COEFF(l);
1413                     if(FRAME_CODED(l) && COMPATIBLE_FRAME(l))
1414                         transform |= PL;
1415                 }
1416                 if(y){
1417                     u= i-fragment_width;
1418                     vu = DC_COEFF(u);
1419                     if(FRAME_CODED(u) && COMPATIBLE_FRAME(u))
1420                         transform |= PU;
1421                     if(x){
1422                         ul= i-fragment_width-1;
1423                         vul = DC_COEFF(ul);
1424                         if(FRAME_CODED(ul) && COMPATIBLE_FRAME(ul))
1425                             transform |= PUL;
1426                     }
1427                     if(x + 1 < fragment_width){
1428                         ur= i-fragment_width+1;
1429                         vur = DC_COEFF(ur);
1430                         if(FRAME_CODED(ur) && COMPATIBLE_FRAME(ur))
1431                             transform |= PUR;
1432                     }
1433                 }
1434
1435                 debug_dc_pred("transform = %d, ", transform);
1436
1437                 if (transform == 0) {
1438
1439                     /* if there were no fragments to predict from, use last
1440                      * DC saved */
1441                     predicted_dc = last_dc[current_frame_type];
1442                     debug_dc_pred("from last DC (%d) = %d\n",
1443                         current_frame_type, DC_COEFF(i));
1444
1445                 } else {
1446
1447                     /* apply the appropriate predictor transform */
1448                     predicted_dc =
1449                         (predictor_transform[transform][0] * vul) +
1450                         (predictor_transform[transform][1] * vu) +
1451                         (predictor_transform[transform][2] * vur) +
1452                         (predictor_transform[transform][3] * vl);
1453
1454                     predicted_dc /= 128;
1455
1456                     /* check for outranging on the [ul u l] and
1457                      * [ul u ur l] predictors */
1458                     if ((transform == 13) || (transform == 15)) {
1459                         if (FFABS(predicted_dc - vu) > 128)
1460                             predicted_dc = vu;
1461                         else if (FFABS(predicted_dc - vl) > 128)
1462                             predicted_dc = vl;
1463                         else if (FFABS(predicted_dc - vul) > 128)
1464                             predicted_dc = vul;
1465                     }
1466
1467                     debug_dc_pred("from pred DC = %d\n",
1468                     DC_COEFF(i));
1469                 }
1470
1471                 /* at long last, apply the predictor */
1472                 if(s->coeffs[i].index){
1473                     *s->next_coeff= s->coeffs[i];
1474                     s->coeffs[i].index=0;
1475                     s->coeffs[i].coeff=0;
1476                     s->coeffs[i].next= s->next_coeff++;
1477                 }
1478                 s->coeffs[i].coeff += predicted_dc;
1479                 /* save the DC */
1480                 last_dc[current_frame_type] = DC_COEFF(i);
1481                 if(DC_COEFF(i) && !(s->all_fragments[i].coeff_count&127)){
1482                     s->all_fragments[i].coeff_count= 129;
1483 //                    s->all_fragments[i].next_coeff= s->next_coeff;
1484                     s->coeffs[i].next= s->next_coeff;
1485                     (s->next_coeff++)->next=NULL;
1486                 }
1487             }
1488         }
1489     }
1490 }
1491
1492
1493 static void horizontal_filter(unsigned char *first_pixel, int stride,
1494     int *bounding_values);
1495 static void vertical_filter(unsigned char *first_pixel, int stride,
1496     int *bounding_values);
1497
1498 /*
1499  * Perform the final rendering for a particular slice of data.
1500  * The slice number ranges from 0..(macroblock_height - 1).
1501  */
1502 static void render_slice(Vp3DecodeContext *s, int slice)
1503 {
1504     int x;
1505     int m, n;
1506     int16_t *dequantizer;
1507     DECLARE_ALIGNED_16(DCTELEM, block[64]);
1508     int motion_x = 0xdeadbeef, motion_y = 0xdeadbeef;
1509     int motion_halfpel_index;
1510     uint8_t *motion_source;
1511     int plane;
1512     int current_macroblock_entry = slice * s->macroblock_width * 6;
1513
1514     if (slice >= s->macroblock_height)
1515         return;
1516
1517     for (plane = 0; plane < 3; plane++) {
1518         uint8_t *output_plane = s->current_frame.data    [plane];
1519         uint8_t *  last_plane = s->   last_frame.data    [plane];
1520         uint8_t *golden_plane = s-> golden_frame.data    [plane];
1521         int stride            = s->current_frame.linesize[plane];
1522         int plane_width       = s->width  >> !!plane;
1523         int plane_height      = s->height >> !!plane;
1524         int y =        slice *  FRAGMENT_PIXELS << !plane ;
1525         int slice_height = y + (FRAGMENT_PIXELS << !plane);
1526         int i = s->macroblock_fragments[current_macroblock_entry + plane + 3*!!plane];
1527
1528         if (!s->flipped_image) stride = -stride;
1529
1530
1531         if(FFABS(stride) > 2048)
1532             return; //various tables are fixed size
1533
1534         /* for each fragment row in the slice (both of them)... */
1535         for (; y < slice_height; y += 8) {
1536
1537             /* for each fragment in a row... */
1538             for (x = 0; x < plane_width; x += 8, i++) {
1539
1540                 if ((i < 0) || (i >= s->fragment_count)) {
1541                     av_log(s->avctx, AV_LOG_ERROR, "  vp3:render_slice(): bad fragment number (%d)\n", i);
1542                     return;
1543                 }
1544
1545                 /* transform if this block was coded */
1546                 if ((s->all_fragments[i].coding_method != MODE_COPY) &&
1547                     !((s->avctx->flags & CODEC_FLAG_GRAY) && plane)) {
1548
1549                     if ((s->all_fragments[i].coding_method == MODE_USING_GOLDEN) ||
1550                         (s->all_fragments[i].coding_method == MODE_GOLDEN_MV))
1551                         motion_source= golden_plane;
1552                     else
1553                         motion_source= last_plane;
1554
1555                     motion_source += s->all_fragments[i].first_pixel;
1556                     motion_halfpel_index = 0;
1557
1558                     /* sort out the motion vector if this fragment is coded
1559                      * using a motion vector method */
1560                     if ((s->all_fragments[i].coding_method > MODE_INTRA) &&
1561                         (s->all_fragments[i].coding_method != MODE_USING_GOLDEN)) {
1562                         int src_x, src_y;
1563                         motion_x = s->all_fragments[i].motion_x;
1564                         motion_y = s->all_fragments[i].motion_y;
1565                         if(plane){
1566                             motion_x= (motion_x>>1) | (motion_x&1);
1567                             motion_y= (motion_y>>1) | (motion_y&1);
1568                         }
1569
1570                         src_x= (motion_x>>1) + x;
1571                         src_y= (motion_y>>1) + y;
1572                         if ((motion_x == 127) || (motion_y == 127))
1573                             av_log(s->avctx, AV_LOG_ERROR, " help! got invalid motion vector! (%X, %X)\n", motion_x, motion_y);
1574
1575                         motion_halfpel_index = motion_x & 0x01;
1576                         motion_source += (motion_x >> 1);
1577
1578                         motion_halfpel_index |= (motion_y & 0x01) << 1;
1579                         motion_source += ((motion_y >> 1) * stride);
1580
1581                         if(src_x<0 || src_y<0 || src_x + 9 >= plane_width || src_y + 9 >= plane_height){
1582                             uint8_t *temp= s->edge_emu_buffer;
1583                             if(stride<0) temp -= 9*stride;
1584                             else temp += 9*stride;
1585
1586                             ff_emulated_edge_mc(temp, motion_source, stride, 9, 9, src_x, src_y, plane_width, plane_height);
1587                             motion_source= temp;
1588                         }
1589                     }
1590
1591
1592                     /* first, take care of copying a block from either the
1593                      * previous or the golden frame */
1594                     if (s->all_fragments[i].coding_method != MODE_INTRA) {
1595                         /* Note, it is possible to implement all MC cases with
1596                            put_no_rnd_pixels_l2 which would look more like the
1597                            VP3 source but this would be slower as
1598                            put_no_rnd_pixels_tab is better optimzed */
1599                         if(motion_halfpel_index != 3){
1600                             s->dsp.put_no_rnd_pixels_tab[1][motion_halfpel_index](
1601                                 output_plane + s->all_fragments[i].first_pixel,
1602                                 motion_source, stride, 8);
1603                         }else{
1604                             int d= (motion_x ^ motion_y)>>31; // d is 0 if motion_x and _y have the same sign, else -1
1605                             s->dsp.put_no_rnd_pixels_l2[1](
1606                                 output_plane + s->all_fragments[i].first_pixel,
1607                                 motion_source - d,
1608                                 motion_source + stride + 1 + d,
1609                                 stride, 8);
1610                         }
1611                         dequantizer = s->qmat[1][plane];
1612                     }else{
1613                         dequantizer = s->qmat[0][plane];
1614                     }
1615
1616                     /* dequantize the DCT coefficients */
1617                     debug_idct("fragment %d, coding mode %d, DC = %d, dequant = %d:\n",
1618                         i, s->all_fragments[i].coding_method,
1619                         DC_COEFF(i), dequantizer[0]);
1620
1621                     if(s->avctx->idct_algo==FF_IDCT_VP3){
1622                         Coeff *coeff= s->coeffs + i;
1623                         memset(block, 0, sizeof(block));
1624                         while(coeff->next){
1625                             block[coeff->index]= coeff->coeff * dequantizer[coeff->index];
1626                             coeff= coeff->next;
1627                         }
1628                     }else{
1629                         Coeff *coeff= s->coeffs + i;
1630                         memset(block, 0, sizeof(block));
1631                         while(coeff->next){
1632                             block[coeff->index]= (coeff->coeff * dequantizer[coeff->index] + 2)>>2;
1633                             coeff= coeff->next;
1634                         }
1635                     }
1636
1637                     /* invert DCT and place (or add) in final output */
1638
1639                     if (s->all_fragments[i].coding_method == MODE_INTRA) {
1640                         if(s->avctx->idct_algo!=FF_IDCT_VP3)
1641                             block[0] += 128<<3;
1642                         s->dsp.idct_put(
1643                             output_plane + s->all_fragments[i].first_pixel,
1644                             stride,
1645                             block);
1646                     } else {
1647                         s->dsp.idct_add(
1648                             output_plane + s->all_fragments[i].first_pixel,
1649                             stride,
1650                             block);
1651                     }
1652
1653                     debug_idct("block after idct_%s():\n",
1654                         (s->all_fragments[i].coding_method == MODE_INTRA)?
1655                         "put" : "add");
1656                     for (m = 0; m < 8; m++) {
1657                         for (n = 0; n < 8; n++) {
1658                             debug_idct(" %3d", *(output_plane +
1659                                 s->all_fragments[i].first_pixel + (m * stride + n)));
1660                         }
1661                         debug_idct("\n");
1662                     }
1663                     debug_idct("\n");
1664
1665                 } else {
1666
1667                     /* copy directly from the previous frame */
1668                     s->dsp.put_pixels_tab[1][0](
1669                         output_plane + s->all_fragments[i].first_pixel,
1670                         last_plane + s->all_fragments[i].first_pixel,
1671                         stride, 8);
1672
1673                 }
1674 #if 0
1675                 /* perform the left edge filter if:
1676                  *   - the fragment is not on the left column
1677                  *   - the fragment is coded in this frame
1678                  *   - the fragment is not coded in this frame but the left
1679                  *     fragment is coded in this frame (this is done instead
1680                  *     of a right edge filter when rendering the left fragment
1681                  *     since this fragment is not available yet) */
1682                 if ((x > 0) &&
1683                     ((s->all_fragments[i].coding_method != MODE_COPY) ||
1684                      ((s->all_fragments[i].coding_method == MODE_COPY) &&
1685                       (s->all_fragments[i - 1].coding_method != MODE_COPY)) )) {
1686                     horizontal_filter(
1687                         output_plane + s->all_fragments[i].first_pixel + 7*stride,
1688                         -stride, s->bounding_values_array + 127);
1689                 }
1690
1691                 /* perform the top edge filter if:
1692                  *   - the fragment is not on the top row
1693                  *   - the fragment is coded in this frame
1694                  *   - the fragment is not coded in this frame but the above
1695                  *     fragment is coded in this frame (this is done instead
1696                  *     of a bottom edge filter when rendering the above
1697                  *     fragment since this fragment is not available yet) */
1698                 if ((y > 0) &&
1699                     ((s->all_fragments[i].coding_method != MODE_COPY) ||
1700                      ((s->all_fragments[i].coding_method == MODE_COPY) &&
1701                       (s->all_fragments[i - fragment_width].coding_method != MODE_COPY)) )) {
1702                     vertical_filter(
1703                         output_plane + s->all_fragments[i].first_pixel - stride,
1704                         -stride, s->bounding_values_array + 127);
1705                 }
1706 #endif
1707             }
1708         }
1709     }
1710
1711      /* this looks like a good place for slice dispatch... */
1712      /* algorithm:
1713       *   if (slice == s->macroblock_height - 1)
1714       *     dispatch (both last slice & 2nd-to-last slice);
1715       *   else if (slice > 0)
1716       *     dispatch (slice - 1);
1717       */
1718
1719     emms_c();
1720 }
1721
1722 static void horizontal_filter(unsigned char *first_pixel, int stride,
1723     int *bounding_values)
1724 {
1725     unsigned char *end;
1726     int filter_value;
1727
1728     for (end= first_pixel + 8*stride; first_pixel != end; first_pixel += stride) {
1729         filter_value =
1730             (first_pixel[-2] - first_pixel[ 1])
1731          +3*(first_pixel[ 0] - first_pixel[-1]);
1732         filter_value = bounding_values[(filter_value + 4) >> 3];
1733         first_pixel[-1] = av_clip_uint8(first_pixel[-1] + filter_value);
1734         first_pixel[ 0] = av_clip_uint8(first_pixel[ 0] - filter_value);
1735     }
1736 }
1737
1738 static void vertical_filter(unsigned char *first_pixel, int stride,
1739     int *bounding_values)
1740 {
1741     unsigned char *end;
1742     int filter_value;
1743     const int nstride= -stride;
1744
1745     for (end= first_pixel + 8; first_pixel < end; first_pixel++) {
1746         filter_value =
1747             (first_pixel[2 * nstride] - first_pixel[ stride])
1748          +3*(first_pixel[0          ] - first_pixel[nstride]);
1749         filter_value = bounding_values[(filter_value + 4) >> 3];
1750         first_pixel[nstride] = av_clip_uint8(first_pixel[nstride] + filter_value);
1751         first_pixel[0] = av_clip_uint8(first_pixel[0] - filter_value);
1752     }
1753 }
1754
1755 static void apply_loop_filter(Vp3DecodeContext *s)
1756 {
1757     int plane;
1758     int x, y;
1759     int *bounding_values= s->bounding_values_array+127;
1760
1761 #if 0
1762     int bounding_values_array[256];
1763     int filter_limit;
1764
1765     /* find the right loop limit value */
1766     for (x = 63; x >= 0; x--) {
1767         if (vp31_ac_scale_factor[x] >= s->quality_index)
1768             break;
1769     }
1770     filter_limit = vp31_filter_limit_values[s->quality_index];
1771
1772     /* set up the bounding values */
1773     memset(bounding_values_array, 0, 256 * sizeof(int));
1774     for (x = 0; x < filter_limit; x++) {
1775         bounding_values[-x - filter_limit] = -filter_limit + x;
1776         bounding_values[-x] = -x;
1777         bounding_values[x] = x;
1778         bounding_values[x + filter_limit] = filter_limit - x;
1779     }
1780 #endif
1781
1782     for (plane = 0; plane < 3; plane++) {
1783         int width           = s->fragment_width  >> !!plane;
1784         int height          = s->fragment_height >> !!plane;
1785         int fragment        = s->fragment_start        [plane];
1786         int stride          = s->current_frame.linesize[plane];
1787         uint8_t *plane_data = s->current_frame.data    [plane];
1788         if (!s->flipped_image) stride = -stride;
1789
1790         for (y = 0; y < height; y++) {
1791
1792             for (x = 0; x < width; x++) {
1793 START_TIMER
1794                 /* do not perform left edge filter for left columns frags */
1795                 if ((x > 0) &&
1796                     (s->all_fragments[fragment].coding_method != MODE_COPY)) {
1797                     horizontal_filter(
1798                         plane_data + s->all_fragments[fragment].first_pixel,
1799                         stride, bounding_values);
1800                 }
1801
1802                 /* do not perform top edge filter for top row fragments */
1803                 if ((y > 0) &&
1804                     (s->all_fragments[fragment].coding_method != MODE_COPY)) {
1805                     vertical_filter(
1806                         plane_data + s->all_fragments[fragment].first_pixel,
1807                         stride, bounding_values);
1808                 }
1809
1810                 /* do not perform right edge filter for right column
1811                  * fragments or if right fragment neighbor is also coded
1812                  * in this frame (it will be filtered in next iteration) */
1813                 if ((x < width - 1) &&
1814                     (s->all_fragments[fragment].coding_method != MODE_COPY) &&
1815                     (s->all_fragments[fragment + 1].coding_method == MODE_COPY)) {
1816                     horizontal_filter(
1817                         plane_data + s->all_fragments[fragment + 1].first_pixel,
1818                         stride, bounding_values);
1819                 }
1820
1821                 /* do not perform bottom edge filter for bottom row
1822                  * fragments or if bottom fragment neighbor is also coded
1823                  * in this frame (it will be filtered in the next row) */
1824                 if ((y < height - 1) &&
1825                     (s->all_fragments[fragment].coding_method != MODE_COPY) &&
1826                     (s->all_fragments[fragment + width].coding_method == MODE_COPY)) {
1827                     vertical_filter(
1828                         plane_data + s->all_fragments[fragment + width].first_pixel,
1829                         stride, bounding_values);
1830                 }
1831
1832                 fragment++;
1833 STOP_TIMER("loop filter")
1834             }
1835         }
1836     }
1837 }
1838
1839 /*
1840  * This function computes the first pixel addresses for each fragment.
1841  * This function needs to be invoked after the first frame is allocated
1842  * so that it has access to the plane strides.
1843  */
1844 static void vp3_calculate_pixel_addresses(Vp3DecodeContext *s)
1845 {
1846
1847     int i, x, y;
1848
1849     /* figure out the first pixel addresses for each of the fragments */
1850     /* Y plane */
1851     i = 0;
1852     for (y = s->fragment_height; y > 0; y--) {
1853         for (x = 0; x < s->fragment_width; x++) {
1854             s->all_fragments[i++].first_pixel =
1855                 s->golden_frame.linesize[0] * y * FRAGMENT_PIXELS -
1856                     s->golden_frame.linesize[0] +
1857                     x * FRAGMENT_PIXELS;
1858             debug_init("  fragment %d, first pixel @ %d\n",
1859                 i-1, s->all_fragments[i-1].first_pixel);
1860         }
1861     }
1862
1863     /* U plane */
1864     i = s->fragment_start[1];
1865     for (y = s->fragment_height / 2; y > 0; y--) {
1866         for (x = 0; x < s->fragment_width / 2; x++) {
1867             s->all_fragments[i++].first_pixel =
1868                 s->golden_frame.linesize[1] * y * FRAGMENT_PIXELS -
1869                     s->golden_frame.linesize[1] +
1870                     x * FRAGMENT_PIXELS;
1871             debug_init("  fragment %d, first pixel @ %d\n",
1872                 i-1, s->all_fragments[i-1].first_pixel);
1873         }
1874     }
1875
1876     /* V plane */
1877     i = s->fragment_start[2];
1878     for (y = s->fragment_height / 2; y > 0; y--) {
1879         for (x = 0; x < s->fragment_width / 2; x++) {
1880             s->all_fragments[i++].first_pixel =
1881                 s->golden_frame.linesize[2] * y * FRAGMENT_PIXELS -
1882                     s->golden_frame.linesize[2] +
1883                     x * FRAGMENT_PIXELS;
1884             debug_init("  fragment %d, first pixel @ %d\n",
1885                 i-1, s->all_fragments[i-1].first_pixel);
1886         }
1887     }
1888 }
1889
1890 /* FIXME: this should be merged with the above! */
1891 static void theora_calculate_pixel_addresses(Vp3DecodeContext *s)
1892 {
1893
1894     int i, x, y;
1895
1896     /* figure out the first pixel addresses for each of the fragments */
1897     /* Y plane */
1898     i = 0;
1899     for (y = 1; y <= s->fragment_height; y++) {
1900         for (x = 0; x < s->fragment_width; x++) {
1901             s->all_fragments[i++].first_pixel =
1902                 s->golden_frame.linesize[0] * y * FRAGMENT_PIXELS -
1903                     s->golden_frame.linesize[0] +
1904                     x * FRAGMENT_PIXELS;
1905             debug_init("  fragment %d, first pixel @ %d\n",
1906                 i-1, s->all_fragments[i-1].first_pixel);
1907         }
1908     }
1909
1910     /* U plane */
1911     i = s->fragment_start[1];
1912     for (y = 1; y <= s->fragment_height / 2; y++) {
1913         for (x = 0; x < s->fragment_width / 2; x++) {
1914             s->all_fragments[i++].first_pixel =
1915                 s->golden_frame.linesize[1] * y * FRAGMENT_PIXELS -
1916                     s->golden_frame.linesize[1] +
1917                     x * FRAGMENT_PIXELS;
1918             debug_init("  fragment %d, first pixel @ %d\n",
1919                 i-1, s->all_fragments[i-1].first_pixel);
1920         }
1921     }
1922
1923     /* V plane */
1924     i = s->fragment_start[2];
1925     for (y = 1; y <= s->fragment_height / 2; y++) {
1926         for (x = 0; x < s->fragment_width / 2; x++) {
1927             s->all_fragments[i++].first_pixel =
1928                 s->golden_frame.linesize[2] * y * FRAGMENT_PIXELS -
1929                     s->golden_frame.linesize[2] +
1930                     x * FRAGMENT_PIXELS;
1931             debug_init("  fragment %d, first pixel @ %d\n",
1932                 i-1, s->all_fragments[i-1].first_pixel);
1933         }
1934     }
1935 }
1936
1937 /*
1938  * This is the ffmpeg/libavcodec API init function.
1939  */
1940 static int vp3_decode_init(AVCodecContext *avctx)
1941 {
1942     Vp3DecodeContext *s = avctx->priv_data;
1943     int i, inter, plane;
1944     int c_width;
1945     int c_height;
1946     int y_superblock_count;
1947     int c_superblock_count;
1948
1949     if (avctx->codec_tag == MKTAG('V','P','3','0'))
1950         s->version = 0;
1951     else
1952         s->version = 1;
1953
1954     s->avctx = avctx;
1955     s->width = (avctx->width + 15) & 0xFFFFFFF0;
1956     s->height = (avctx->height + 15) & 0xFFFFFFF0;
1957     avctx->pix_fmt = PIX_FMT_YUV420P;
1958     if(avctx->idct_algo==FF_IDCT_AUTO)
1959         avctx->idct_algo=FF_IDCT_VP3;
1960     dsputil_init(&s->dsp, avctx);
1961
1962     ff_init_scantable(s->dsp.idct_permutation, &s->scantable, ff_zigzag_direct);
1963
1964     /* initialize to an impossible value which will force a recalculation
1965      * in the first frame decode */
1966     s->quality_index = -1;
1967
1968     s->y_superblock_width = (s->width + 31) / 32;
1969     s->y_superblock_height = (s->height + 31) / 32;
1970     y_superblock_count = s->y_superblock_width * s->y_superblock_height;
1971
1972     /* work out the dimensions for the C planes */
1973     c_width = s->width / 2;
1974     c_height = s->height / 2;
1975     s->c_superblock_width = (c_width + 31) / 32;
1976     s->c_superblock_height = (c_height + 31) / 32;
1977     c_superblock_count = s->c_superblock_width * s->c_superblock_height;
1978
1979     s->superblock_count = y_superblock_count + (c_superblock_count * 2);
1980     s->u_superblock_start = y_superblock_count;
1981     s->v_superblock_start = s->u_superblock_start + c_superblock_count;
1982     s->superblock_coding = av_malloc(s->superblock_count);
1983
1984     s->macroblock_width = (s->width + 15) / 16;
1985     s->macroblock_height = (s->height + 15) / 16;
1986     s->macroblock_count = s->macroblock_width * s->macroblock_height;
1987
1988     s->fragment_width = s->width / FRAGMENT_PIXELS;
1989     s->fragment_height = s->height / FRAGMENT_PIXELS;
1990
1991     /* fragment count covers all 8x8 blocks for all 3 planes */
1992     s->fragment_count = s->fragment_width * s->fragment_height * 3 / 2;
1993     s->fragment_start[1] = s->fragment_width * s->fragment_height;
1994     s->fragment_start[2] = s->fragment_width * s->fragment_height * 5 / 4;
1995
1996     debug_init("  Y plane: %d x %d\n", s->width, s->height);
1997     debug_init("  C plane: %d x %d\n", c_width, c_height);
1998     debug_init("  Y superblocks: %d x %d, %d total\n",
1999         s->y_superblock_width, s->y_superblock_height, y_superblock_count);
2000     debug_init("  C superblocks: %d x %d, %d total\n",
2001         s->c_superblock_width, s->c_superblock_height, c_superblock_count);
2002     debug_init("  total superblocks = %d, U starts @ %d, V starts @ %d\n",
2003         s->superblock_count, s->u_superblock_start, s->v_superblock_start);
2004     debug_init("  macroblocks: %d x %d, %d total\n",
2005         s->macroblock_width, s->macroblock_height, s->macroblock_count);
2006     debug_init("  %d fragments, %d x %d, u starts @ %d, v starts @ %d\n",
2007         s->fragment_count,
2008         s->fragment_width,
2009         s->fragment_height,
2010         s->fragment_start[1],
2011         s->fragment_start[2]);
2012
2013     s->all_fragments = av_malloc(s->fragment_count * sizeof(Vp3Fragment));
2014     s->coeffs = av_malloc(s->fragment_count * sizeof(Coeff) * 65);
2015     s->coded_fragment_list = av_malloc(s->fragment_count * sizeof(int));
2016     s->pixel_addresses_inited = 0;
2017
2018     if (!s->theora_tables)
2019     {
2020         for (i = 0; i < 64; i++) {
2021             s->coded_dc_scale_factor[i] = vp31_dc_scale_factor[i];
2022             s->coded_ac_scale_factor[i] = vp31_ac_scale_factor[i];
2023             s->base_matrix[0][i] = vp31_intra_y_dequant[i];
2024             s->base_matrix[1][i] = vp31_intra_c_dequant[i];
2025             s->base_matrix[2][i] = vp31_inter_dequant[i];
2026             s->filter_limit_values[i] = vp31_filter_limit_values[i];
2027         }
2028
2029         for(inter=0; inter<2; inter++){
2030             for(plane=0; plane<3; plane++){
2031                 s->qr_count[inter][plane]= 1;
2032                 s->qr_size [inter][plane][0]= 63;
2033                 s->qr_base [inter][plane][0]=
2034                 s->qr_base [inter][plane][1]= 2*inter + (!!plane)*!inter;
2035             }
2036         }
2037
2038         /* init VLC tables */
2039         for (i = 0; i < 16; i++) {
2040
2041             /* DC histograms */
2042             init_vlc(&s->dc_vlc[i], 5, 32,
2043                 &dc_bias[i][0][1], 4, 2,
2044                 &dc_bias[i][0][0], 4, 2, 0);
2045
2046             /* group 1 AC histograms */
2047             init_vlc(&s->ac_vlc_1[i], 5, 32,
2048                 &ac_bias_0[i][0][1], 4, 2,
2049                 &ac_bias_0[i][0][0], 4, 2, 0);
2050
2051             /* group 2 AC histograms */
2052             init_vlc(&s->ac_vlc_2[i], 5, 32,
2053                 &ac_bias_1[i][0][1], 4, 2,
2054                 &ac_bias_1[i][0][0], 4, 2, 0);
2055
2056             /* group 3 AC histograms */
2057             init_vlc(&s->ac_vlc_3[i], 5, 32,
2058                 &ac_bias_2[i][0][1], 4, 2,
2059                 &ac_bias_2[i][0][0], 4, 2, 0);
2060
2061             /* group 4 AC histograms */
2062             init_vlc(&s->ac_vlc_4[i], 5, 32,
2063                 &ac_bias_3[i][0][1], 4, 2,
2064                 &ac_bias_3[i][0][0], 4, 2, 0);
2065         }
2066     } else {
2067         for (i = 0; i < 16; i++) {
2068
2069             /* DC histograms */
2070             init_vlc(&s->dc_vlc[i], 5, 32,
2071                 &s->huffman_table[i][0][1], 4, 2,
2072                 &s->huffman_table[i][0][0], 4, 2, 0);
2073
2074             /* group 1 AC histograms */
2075             init_vlc(&s->ac_vlc_1[i], 5, 32,
2076                 &s->huffman_table[i+16][0][1], 4, 2,
2077                 &s->huffman_table[i+16][0][0], 4, 2, 0);
2078
2079             /* group 2 AC histograms */
2080             init_vlc(&s->ac_vlc_2[i], 5, 32,
2081                 &s->huffman_table[i+16*2][0][1], 4, 2,
2082                 &s->huffman_table[i+16*2][0][0], 4, 2, 0);
2083
2084             /* group 3 AC histograms */
2085             init_vlc(&s->ac_vlc_3[i], 5, 32,
2086                 &s->huffman_table[i+16*3][0][1], 4, 2,
2087                 &s->huffman_table[i+16*3][0][0], 4, 2, 0);
2088
2089             /* group 4 AC histograms */
2090             init_vlc(&s->ac_vlc_4[i], 5, 32,
2091                 &s->huffman_table[i+16*4][0][1], 4, 2,
2092                 &s->huffman_table[i+16*4][0][0], 4, 2, 0);
2093         }
2094     }
2095
2096     init_vlc(&s->superblock_run_length_vlc, 6, 34,
2097         &superblock_run_length_vlc_table[0][1], 4, 2,
2098         &superblock_run_length_vlc_table[0][0], 4, 2, 0);
2099
2100     init_vlc(&s->fragment_run_length_vlc, 5, 30,
2101         &fragment_run_length_vlc_table[0][1], 4, 2,
2102         &fragment_run_length_vlc_table[0][0], 4, 2, 0);
2103
2104     init_vlc(&s->mode_code_vlc, 3, 8,
2105         &mode_code_vlc_table[0][1], 2, 1,
2106         &mode_code_vlc_table[0][0], 2, 1, 0);
2107
2108     init_vlc(&s->motion_vector_vlc, 6, 63,
2109         &motion_vector_vlc_table[0][1], 2, 1,
2110         &motion_vector_vlc_table[0][0], 2, 1, 0);
2111
2112     /* work out the block mapping tables */
2113     s->superblock_fragments = av_malloc(s->superblock_count * 16 * sizeof(int));
2114     s->superblock_macroblocks = av_malloc(s->superblock_count * 4 * sizeof(int));
2115     s->macroblock_fragments = av_malloc(s->macroblock_count * 6 * sizeof(int));
2116     s->macroblock_coding = av_malloc(s->macroblock_count + 1);
2117     init_block_mapping(s);
2118
2119     for (i = 0; i < 3; i++) {
2120         s->current_frame.data[i] = NULL;
2121         s->last_frame.data[i] = NULL;
2122         s->golden_frame.data[i] = NULL;
2123     }
2124
2125     return 0;
2126 }
2127
2128 /*
2129  * This is the ffmpeg/libavcodec API frame decode function.
2130  */
2131 static int vp3_decode_frame(AVCodecContext *avctx,
2132                             void *data, int *data_size,
2133                             uint8_t *buf, int buf_size)
2134 {
2135     Vp3DecodeContext *s = avctx->priv_data;
2136     GetBitContext gb;
2137     static int counter = 0;
2138     int i;
2139
2140     init_get_bits(&gb, buf, buf_size * 8);
2141
2142     if (s->theora && get_bits1(&gb))
2143     {
2144 #if 1
2145         av_log(avctx, AV_LOG_ERROR, "Header packet passed to frame decoder, skipping\n");
2146         return -1;
2147 #else
2148         int ptype = get_bits(&gb, 7);
2149
2150         skip_bits(&gb, 6*8); /* "theora" */
2151
2152         switch(ptype)
2153         {
2154             case 1:
2155                 theora_decode_comments(avctx, &gb);
2156                 break;
2157             case 2:
2158                 theora_decode_tables(avctx, &gb);
2159                     init_dequantizer(s);
2160                 break;
2161             default:
2162                 av_log(avctx, AV_LOG_ERROR, "Unknown Theora config packet: %d\n", ptype);
2163         }
2164         return buf_size;
2165 #endif
2166     }
2167
2168     s->keyframe = !get_bits1(&gb);
2169     if (!s->theora)
2170         skip_bits(&gb, 1);
2171     s->last_quality_index = s->quality_index;
2172
2173     s->nqis=0;
2174     do{
2175         s->qis[s->nqis++]= get_bits(&gb, 6);
2176     } while(s->theora >= 0x030200 && s->nqis<3 && get_bits1(&gb));
2177
2178     s->quality_index= s->qis[0];
2179
2180     if (s->avctx->debug & FF_DEBUG_PICT_INFO)
2181         av_log(s->avctx, AV_LOG_INFO, " VP3 %sframe #%d: Q index = %d\n",
2182             s->keyframe?"key":"", counter, s->quality_index);
2183     counter++;
2184
2185     if (s->quality_index != s->last_quality_index) {
2186         init_dequantizer(s);
2187         init_loop_filter(s);
2188     }
2189
2190     if (s->keyframe) {
2191         if (!s->theora)
2192         {
2193             skip_bits(&gb, 4); /* width code */
2194             skip_bits(&gb, 4); /* height code */
2195             if (s->version)
2196             {
2197                 s->version = get_bits(&gb, 5);
2198                 if (counter == 1)
2199                     av_log(s->avctx, AV_LOG_DEBUG, "VP version: %d\n", s->version);
2200             }
2201         }
2202         if (s->version || s->theora)
2203         {
2204                 if (get_bits1(&gb))
2205                     av_log(s->avctx, AV_LOG_ERROR, "Warning, unsupported keyframe coding type?!\n");
2206             skip_bits(&gb, 2); /* reserved? */
2207         }
2208
2209         if (s->last_frame.data[0] == s->golden_frame.data[0]) {
2210             if (s->golden_frame.data[0])
2211                 avctx->release_buffer(avctx, &s->golden_frame);
2212             s->last_frame= s->golden_frame; /* ensure that we catch any access to this released frame */
2213         } else {
2214             if (s->golden_frame.data[0])
2215                 avctx->release_buffer(avctx, &s->golden_frame);
2216             if (s->last_frame.data[0])
2217                 avctx->release_buffer(avctx, &s->last_frame);
2218         }
2219
2220         s->golden_frame.reference = 3;
2221         if(avctx->get_buffer(avctx, &s->golden_frame) < 0) {
2222             av_log(s->avctx, AV_LOG_ERROR, "vp3: get_buffer() failed\n");
2223             return -1;
2224         }
2225
2226         /* golden frame is also the current frame */
2227         s->current_frame= s->golden_frame;
2228
2229         /* time to figure out pixel addresses? */
2230         if (!s->pixel_addresses_inited)
2231         {
2232             if (!s->flipped_image)
2233                 vp3_calculate_pixel_addresses(s);
2234             else
2235                 theora_calculate_pixel_addresses(s);
2236             s->pixel_addresses_inited = 1;
2237         }
2238     } else {
2239         /* allocate a new current frame */
2240         s->current_frame.reference = 3;
2241         if (!s->pixel_addresses_inited) {
2242             av_log(s->avctx, AV_LOG_ERROR, "vp3: first frame not a keyframe\n");
2243             return -1;
2244         }
2245         if(avctx->get_buffer(avctx, &s->current_frame) < 0) {
2246             av_log(s->avctx, AV_LOG_ERROR, "vp3: get_buffer() failed\n");
2247             return -1;
2248         }
2249     }
2250
2251     s->current_frame.qscale_table= s->qscale_table; //FIXME allocate individual tables per AVFrame
2252     s->current_frame.qstride= 0;
2253
2254     {START_TIMER
2255     init_frame(s, &gb);
2256     STOP_TIMER("init_frame")}
2257
2258 #if KEYFRAMES_ONLY
2259 if (!s->keyframe) {
2260
2261     memcpy(s->current_frame.data[0], s->golden_frame.data[0],
2262         s->current_frame.linesize[0] * s->height);
2263     memcpy(s->current_frame.data[1], s->golden_frame.data[1],
2264         s->current_frame.linesize[1] * s->height / 2);
2265     memcpy(s->current_frame.data[2], s->golden_frame.data[2],
2266         s->current_frame.linesize[2] * s->height / 2);
2267
2268 } else {
2269 #endif
2270
2271     {START_TIMER
2272     if (unpack_superblocks(s, &gb)){
2273         av_log(s->avctx, AV_LOG_ERROR, "error in unpack_superblocks\n");
2274         return -1;
2275     }
2276     STOP_TIMER("unpack_superblocks")}
2277     {START_TIMER
2278     if (unpack_modes(s, &gb)){
2279         av_log(s->avctx, AV_LOG_ERROR, "error in unpack_modes\n");
2280         return -1;
2281     }
2282     STOP_TIMER("unpack_modes")}
2283     {START_TIMER
2284     if (unpack_vectors(s, &gb)){
2285         av_log(s->avctx, AV_LOG_ERROR, "error in unpack_vectors\n");
2286         return -1;
2287     }
2288     STOP_TIMER("unpack_vectors")}
2289     {START_TIMER
2290     if (unpack_dct_coeffs(s, &gb)){
2291         av_log(s->avctx, AV_LOG_ERROR, "error in unpack_dct_coeffs\n");
2292         return -1;
2293     }
2294     STOP_TIMER("unpack_dct_coeffs")}
2295     {START_TIMER
2296
2297     reverse_dc_prediction(s, 0, s->fragment_width, s->fragment_height);
2298     if ((avctx->flags & CODEC_FLAG_GRAY) == 0) {
2299         reverse_dc_prediction(s, s->fragment_start[1],
2300             s->fragment_width / 2, s->fragment_height / 2);
2301         reverse_dc_prediction(s, s->fragment_start[2],
2302             s->fragment_width / 2, s->fragment_height / 2);
2303     }
2304     STOP_TIMER("reverse_dc_prediction")}
2305     {START_TIMER
2306
2307     for (i = 0; i < s->macroblock_height; i++)
2308         render_slice(s, i);
2309     STOP_TIMER("render_fragments")}
2310
2311     {START_TIMER
2312     apply_loop_filter(s);
2313     STOP_TIMER("apply_loop_filter")}
2314 #if KEYFRAMES_ONLY
2315 }
2316 #endif
2317
2318     *data_size=sizeof(AVFrame);
2319     *(AVFrame*)data= s->current_frame;
2320
2321     /* release the last frame, if it is allocated and if it is not the
2322      * golden frame */
2323     if ((s->last_frame.data[0]) &&
2324         (s->last_frame.data[0] != s->golden_frame.data[0]))
2325         avctx->release_buffer(avctx, &s->last_frame);
2326
2327     /* shuffle frames (last = current) */
2328     s->last_frame= s->current_frame;
2329     s->current_frame.data[0]= NULL; /* ensure that we catch any access to this released frame */
2330
2331     return buf_size;
2332 }
2333
2334 /*
2335  * This is the ffmpeg/libavcodec API module cleanup function.
2336  */
2337 static int vp3_decode_end(AVCodecContext *avctx)
2338 {
2339     Vp3DecodeContext *s = avctx->priv_data;
2340
2341     av_free(s->all_fragments);
2342     av_free(s->coeffs);
2343     av_free(s->coded_fragment_list);
2344     av_free(s->superblock_fragments);
2345     av_free(s->superblock_macroblocks);
2346     av_free(s->macroblock_fragments);
2347     av_free(s->macroblock_coding);
2348
2349     /* release all frames */
2350     if (s->golden_frame.data[0] && s->golden_frame.data[0] != s->last_frame.data[0])
2351         avctx->release_buffer(avctx, &s->golden_frame);
2352     if (s->last_frame.data[0])
2353         avctx->release_buffer(avctx, &s->last_frame);
2354     /* no need to release the current_frame since it will always be pointing
2355      * to the same frame as either the golden or last frame */
2356
2357     return 0;
2358 }
2359
2360 static int read_huffman_tree(AVCodecContext *avctx, GetBitContext *gb)
2361 {
2362     Vp3DecodeContext *s = avctx->priv_data;
2363
2364     if (get_bits(gb, 1)) {
2365         int token;
2366         if (s->entries >= 32) { /* overflow */
2367             av_log(avctx, AV_LOG_ERROR, "huffman tree overflow\n");
2368             return -1;
2369         }
2370         token = get_bits(gb, 5);
2371         //av_log(avctx, AV_LOG_DEBUG, "hti %d hbits %x token %d entry : %d size %d\n", s->hti, s->hbits, token, s->entries, s->huff_code_size);
2372         s->huffman_table[s->hti][token][0] = s->hbits;
2373         s->huffman_table[s->hti][token][1] = s->huff_code_size;
2374         s->entries++;
2375     }
2376     else {
2377         if (s->huff_code_size >= 32) {/* overflow */
2378             av_log(avctx, AV_LOG_ERROR, "huffman tree overflow\n");
2379             return -1;
2380         }
2381         s->huff_code_size++;
2382         s->hbits <<= 1;
2383         read_huffman_tree(avctx, gb);
2384         s->hbits |= 1;
2385         read_huffman_tree(avctx, gb);
2386         s->hbits >>= 1;
2387         s->huff_code_size--;
2388     }
2389     return 0;
2390 }
2391
2392 static int theora_decode_header(AVCodecContext *avctx, GetBitContext *gb)
2393 {
2394     Vp3DecodeContext *s = avctx->priv_data;
2395
2396     s->theora = get_bits_long(gb, 24);
2397     av_log(avctx, AV_LOG_INFO, "Theora bitstream version %X\n", s->theora);
2398
2399     /* 3.2.0 aka alpha3 has the same frame orientation as original vp3 */
2400     /* but previous versions have the image flipped relative to vp3 */
2401     if (s->theora < 0x030200)
2402     {
2403         s->flipped_image = 1;
2404         av_log(avctx, AV_LOG_DEBUG, "Old (<alpha3) Theora bitstream, flipped image\n");
2405     }
2406
2407     s->width = get_bits(gb, 16) << 4;
2408     s->height = get_bits(gb, 16) << 4;
2409
2410     if(avcodec_check_dimensions(avctx, s->width, s->height)){
2411         av_log(avctx, AV_LOG_ERROR, "Invalid dimensions (%dx%d)\n", s->width, s->height);
2412         s->width= s->height= 0;
2413         return -1;
2414     }
2415
2416     if (s->theora >= 0x030400)
2417     {
2418         skip_bits(gb, 32); /* total number of superblocks in a frame */
2419         // fixme, the next field is 36bits long
2420         skip_bits(gb, 32); /* total number of blocks in a frame */
2421         skip_bits(gb, 4); /* total number of blocks in a frame */
2422         skip_bits(gb, 32); /* total number of macroblocks in a frame */
2423
2424         skip_bits(gb, 24); /* frame width */
2425         skip_bits(gb, 24); /* frame height */
2426     }
2427     else
2428     {
2429         skip_bits(gb, 24); /* frame width */
2430         skip_bits(gb, 24); /* frame height */
2431     }
2432
2433   if (s->theora >= 0x030200) {
2434     skip_bits(gb, 8); /* offset x */
2435     skip_bits(gb, 8); /* offset y */
2436   }
2437
2438     skip_bits(gb, 32); /* fps numerator */
2439     skip_bits(gb, 32); /* fps denumerator */
2440     skip_bits(gb, 24); /* aspect numerator */
2441     skip_bits(gb, 24); /* aspect denumerator */
2442
2443     if (s->theora < 0x030200)
2444         skip_bits(gb, 5); /* keyframe frequency force */
2445     skip_bits(gb, 8); /* colorspace */
2446     if (s->theora >= 0x030400)
2447         skip_bits(gb, 2); /* pixel format: 420,res,422,444 */
2448     skip_bits(gb, 24); /* bitrate */
2449
2450     skip_bits(gb, 6); /* quality hint */
2451
2452     if (s->theora >= 0x030200)
2453     {
2454         skip_bits(gb, 5); /* keyframe frequency force */
2455
2456         if (s->theora < 0x030400)
2457             skip_bits(gb, 5); /* spare bits */
2458     }
2459
2460 //    align_get_bits(gb);
2461
2462     avctx->width = s->width;
2463     avctx->height = s->height;
2464
2465     return 0;
2466 }
2467
2468 static int theora_decode_tables(AVCodecContext *avctx, GetBitContext *gb)
2469 {
2470     Vp3DecodeContext *s = avctx->priv_data;
2471     int i, n, matrices, inter, plane;
2472
2473     if (s->theora >= 0x030200) {
2474         n = get_bits(gb, 3);
2475         /* loop filter limit values table */
2476         for (i = 0; i < 64; i++)
2477             s->filter_limit_values[i] = get_bits(gb, n);
2478     }
2479
2480     if (s->theora >= 0x030200)
2481         n = get_bits(gb, 4) + 1;
2482     else
2483         n = 16;
2484     /* quality threshold table */
2485     for (i = 0; i < 64; i++)
2486         s->coded_ac_scale_factor[i] = get_bits(gb, n);
2487
2488     if (s->theora >= 0x030200)
2489         n = get_bits(gb, 4) + 1;
2490     else
2491         n = 16;
2492     /* dc scale factor table */
2493     for (i = 0; i < 64; i++)
2494         s->coded_dc_scale_factor[i] = get_bits(gb, n);
2495
2496     if (s->theora >= 0x030200)
2497         matrices = get_bits(gb, 9) + 1;
2498     else
2499         matrices = 3;
2500
2501     if(matrices > 384){
2502         av_log(avctx, AV_LOG_ERROR, "invalid number of base matrixes\n");
2503         return -1;
2504     }
2505
2506     for(n=0; n<matrices; n++){
2507         for (i = 0; i < 64; i++)
2508             s->base_matrix[n][i]= get_bits(gb, 8);
2509     }
2510
2511     for (inter = 0; inter <= 1; inter++) {
2512         for (plane = 0; plane <= 2; plane++) {
2513             int newqr= 1;
2514             if (inter || plane > 0)
2515                 newqr = get_bits(gb, 1);
2516             if (!newqr) {
2517                 int qtj, plj;
2518                 if(inter && get_bits(gb, 1)){
2519                     qtj = 0;
2520                     plj = plane;
2521                 }else{
2522                     qtj= (3*inter + plane - 1) / 3;
2523                     plj= (plane + 2) % 3;
2524                 }
2525                 s->qr_count[inter][plane]= s->qr_count[qtj][plj];
2526                 memcpy(s->qr_size[inter][plane], s->qr_size[qtj][plj], sizeof(s->qr_size[0][0]));
2527                 memcpy(s->qr_base[inter][plane], s->qr_base[qtj][plj], sizeof(s->qr_base[0][0]));
2528             } else {
2529                 int qri= 0;
2530                 int qi = 0;
2531
2532                 for(;;){
2533                     i= get_bits(gb, av_log2(matrices-1)+1);
2534                     if(i>= matrices){
2535                         av_log(avctx, AV_LOG_ERROR, "invalid base matrix index\n");
2536                         return -1;
2537                     }
2538                     s->qr_base[inter][plane][qri]= i;
2539                     if(qi >= 63)
2540                         break;
2541                     i = get_bits(gb, av_log2(63-qi)+1) + 1;
2542                     s->qr_size[inter][plane][qri++]= i;
2543                     qi += i;
2544                 }
2545
2546                 if (qi > 63) {
2547                     av_log(avctx, AV_LOG_ERROR, "invalid qi %d > 63\n", qi);
2548                     return -1;
2549                 }
2550                 s->qr_count[inter][plane]= qri;
2551             }
2552         }
2553     }
2554
2555     /* Huffman tables */
2556     for (s->hti = 0; s->hti < 80; s->hti++) {
2557         s->entries = 0;
2558         s->huff_code_size = 1;
2559         if (!get_bits(gb, 1)) {
2560             s->hbits = 0;
2561             read_huffman_tree(avctx, gb);
2562             s->hbits = 1;
2563             read_huffman_tree(avctx, gb);
2564         }
2565     }
2566
2567     s->theora_tables = 1;
2568
2569     return 0;
2570 }
2571
2572 static int theora_decode_init(AVCodecContext *avctx)
2573 {
2574     Vp3DecodeContext *s = avctx->priv_data;
2575     GetBitContext gb;
2576     int ptype;
2577     uint8_t *header_start[3];
2578     int header_len[3];
2579     int i;
2580
2581     s->theora = 1;
2582
2583     if (!avctx->extradata_size)
2584     {
2585         av_log(avctx, AV_LOG_ERROR, "Missing extradata!\n");
2586         return -1;
2587     }
2588
2589     if (ff_split_xiph_headers(avctx->extradata, avctx->extradata_size,
2590                               42, header_start, header_len) < 0) {
2591         av_log(avctx, AV_LOG_ERROR, "Corrupt extradata\n");
2592         return -1;
2593     }
2594
2595   for(i=0;i<3;i++) {
2596     init_get_bits(&gb, header_start[i], header_len[i]);
2597
2598     ptype = get_bits(&gb, 8);
2599     debug_vp3("Theora headerpacket type: %x\n", ptype);
2600
2601      if (!(ptype & 0x80))
2602      {
2603         av_log(avctx, AV_LOG_ERROR, "Invalid extradata!\n");
2604 //        return -1;
2605      }
2606
2607     // FIXME: Check for this as well.
2608     skip_bits(&gb, 6*8); /* "theora" */
2609
2610     switch(ptype)
2611     {
2612         case 0x80:
2613             theora_decode_header(avctx, &gb);
2614                 break;
2615         case 0x81:
2616 // FIXME: is this needed? it breaks sometimes
2617 //            theora_decode_comments(avctx, gb);
2618             break;
2619         case 0x82:
2620             theora_decode_tables(avctx, &gb);
2621             break;
2622         default:
2623             av_log(avctx, AV_LOG_ERROR, "Unknown Theora config packet: %d\n", ptype&~0x80);
2624             break;
2625     }
2626     if(8*header_len[i] != get_bits_count(&gb))
2627         av_log(avctx, AV_LOG_ERROR, "%d bits left in packet %X\n", 8*header_len[i] - get_bits_count(&gb), ptype);
2628     if (s->theora < 0x030200)
2629         break;
2630   }
2631
2632     vp3_decode_init(avctx);
2633     return 0;
2634 }
2635
2636 AVCodec vp3_decoder = {
2637     "vp3",
2638     CODEC_TYPE_VIDEO,
2639     CODEC_ID_VP3,
2640     sizeof(Vp3DecodeContext),
2641     vp3_decode_init,
2642     NULL,
2643     vp3_decode_end,
2644     vp3_decode_frame,
2645     0,
2646     NULL
2647 };
2648
2649 #ifdef CONFIG_THEORA_DECODER
2650 AVCodec theora_decoder = {
2651     "theora",
2652     CODEC_TYPE_VIDEO,
2653     CODEC_ID_THEORA,
2654     sizeof(Vp3DecodeContext),
2655     theora_decode_init,
2656     NULL,
2657     vp3_decode_end,
2658     vp3_decode_frame,
2659     0,
2660     NULL
2661 };
2662 #endif