summaryrefslogtreecommitdiff
path: root/libavcodec/vc1_block.c (plain)
blob: f9f26f7e4290d8c800a36d8fd8699c2ef1dea46e
1/*
2 * VC-1 and WMV3 decoder
3 * Copyright (c) 2011 Mashiat Sarker Shakkhar
4 * Copyright (c) 2006-2007 Konstantin Shishkov
5 * Partly based on vc9.c (c) 2005 Anonymous, Alex Beregszaszi, Michael Niedermayer
6 *
7 * This file is part of FFmpeg.
8 *
9 * FFmpeg is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Lesser General Public
11 * License as published by the Free Software Foundation; either
12 * version 2.1 of the License, or (at your option) any later version.
13 *
14 * FFmpeg is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * Lesser General Public License for more details.
18 *
19 * You should have received a copy of the GNU Lesser General Public
20 * License along with FFmpeg; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 */
23
24/**
25 * @file
26 * VC-1 and WMV3 block decoding routines
27 */
28
29#include "avcodec.h"
30#include "mpegutils.h"
31#include "mpegvideo.h"
32#include "msmpeg4data.h"
33#include "unary.h"
34#include "vc1.h"
35#include "vc1_pred.h"
36#include "vc1acdata.h"
37#include "vc1data.h"
38
39#define MB_INTRA_VLC_BITS 9
40#define DC_VLC_BITS 9
41
42// offset tables for interlaced picture MVDATA decoding
43static const uint8_t offset_table[2][9] = {
44 { 0, 1, 2, 4, 8, 16, 32, 64, 128 },
45 { 0, 1, 3, 7, 15, 31, 63, 127, 255 },
46};
47
48/***********************************************************************/
49/**
50 * @name VC-1 Bitplane decoding
51 * @see 8.7, p56
52 * @{
53 */
54
55
56static inline void init_block_index(VC1Context *v)
57{
58 MpegEncContext *s = &v->s;
59 ff_init_block_index(s);
60 if (v->field_mode && !(v->second_field ^ v->tff)) {
61 s->dest[0] += s->current_picture_ptr->f->linesize[0];
62 s->dest[1] += s->current_picture_ptr->f->linesize[1];
63 s->dest[2] += s->current_picture_ptr->f->linesize[2];
64 }
65}
66
67/** @} */ //Bitplane group
68
69static void vc1_put_signed_blocks_clamped(VC1Context *v)
70{
71 MpegEncContext *s = &v->s;
72 int topleft_mb_pos, top_mb_pos;
73 int stride_y, fieldtx = 0;
74 int v_dist;
75
76 /* The put pixels loop is always one MB row behind the decoding loop,
77 * because we can only put pixels when overlap filtering is done, and
78 * for filtering of the bottom edge of a MB, we need the next MB row
79 * present as well.
80 * Within the row, the put pixels loop is also one MB col behind the
81 * decoding loop. The reason for this is again, because for filtering
82 * of the right MB edge, we need the next MB present. */
83 if (!s->first_slice_line) {
84 if (s->mb_x) {
85 topleft_mb_pos = (s->mb_y - 1) * s->mb_stride + s->mb_x - 1;
86 if (v->fcm == ILACE_FRAME)
87 fieldtx = v->fieldtx_plane[topleft_mb_pos];
88 stride_y = s->linesize << fieldtx;
89 v_dist = (16 - fieldtx) >> (fieldtx == 0);
90 s->idsp.put_signed_pixels_clamped(v->block[v->topleft_blk_idx][0],
91 s->dest[0] - 16 * s->linesize - 16,
92 stride_y);
93 s->idsp.put_signed_pixels_clamped(v->block[v->topleft_blk_idx][1],
94 s->dest[0] - 16 * s->linesize - 8,
95 stride_y);
96 s->idsp.put_signed_pixels_clamped(v->block[v->topleft_blk_idx][2],
97 s->dest[0] - v_dist * s->linesize - 16,
98 stride_y);
99 s->idsp.put_signed_pixels_clamped(v->block[v->topleft_blk_idx][3],
100 s->dest[0] - v_dist * s->linesize - 8,
101 stride_y);
102 if (!CONFIG_GRAY || !(s->avctx->flags & AV_CODEC_FLAG_GRAY)) {
103 s->idsp.put_signed_pixels_clamped(v->block[v->topleft_blk_idx][4],
104 s->dest[1] - 8 * s->uvlinesize - 8,
105 s->uvlinesize);
106 s->idsp.put_signed_pixels_clamped(v->block[v->topleft_blk_idx][5],
107 s->dest[2] - 8 * s->uvlinesize - 8,
108 s->uvlinesize);
109 }
110 }
111 if (s->mb_x == s->mb_width - 1) {
112 top_mb_pos = (s->mb_y - 1) * s->mb_stride + s->mb_x;
113 if (v->fcm == ILACE_FRAME)
114 fieldtx = v->fieldtx_plane[top_mb_pos];
115 stride_y = s->linesize << fieldtx;
116 v_dist = fieldtx ? 15 : 8;
117 s->idsp.put_signed_pixels_clamped(v->block[v->top_blk_idx][0],
118 s->dest[0] - 16 * s->linesize,
119 stride_y);
120 s->idsp.put_signed_pixels_clamped(v->block[v->top_blk_idx][1],
121 s->dest[0] - 16 * s->linesize + 8,
122 stride_y);
123 s->idsp.put_signed_pixels_clamped(v->block[v->top_blk_idx][2],
124 s->dest[0] - v_dist * s->linesize,
125 stride_y);
126 s->idsp.put_signed_pixels_clamped(v->block[v->top_blk_idx][3],
127 s->dest[0] - v_dist * s->linesize + 8,
128 stride_y);
129 if (!CONFIG_GRAY || !(s->avctx->flags & AV_CODEC_FLAG_GRAY)) {
130 s->idsp.put_signed_pixels_clamped(v->block[v->top_blk_idx][4],
131 s->dest[1] - 8 * s->uvlinesize,
132 s->uvlinesize);
133 s->idsp.put_signed_pixels_clamped(v->block[v->top_blk_idx][5],
134 s->dest[2] - 8 * s->uvlinesize,
135 s->uvlinesize);
136 }
137 }
138 }
139
140#define inc_blk_idx(idx) do { \
141 idx++; \
142 if (idx >= v->n_allocated_blks) \
143 idx = 0; \
144 } while (0)
145
146 inc_blk_idx(v->topleft_blk_idx);
147 inc_blk_idx(v->top_blk_idx);
148 inc_blk_idx(v->left_blk_idx);
149 inc_blk_idx(v->cur_blk_idx);
150}
151
152/***********************************************************************/
153/**
154 * @name VC-1 Block-level functions
155 * @see 7.1.4, p91 and 8.1.1.7, p(1)04
156 * @{
157 */
158
159/**
160 * @def GET_MQUANT
161 * @brief Get macroblock-level quantizer scale
162 */
163#define GET_MQUANT() \
164 if (v->dquantfrm) { \
165 int edges = 0; \
166 if (v->dqprofile == DQPROFILE_ALL_MBS) { \
167 if (v->dqbilevel) { \
168 mquant = (get_bits1(gb)) ? v->altpq : v->pq; \
169 } else { \
170 mqdiff = get_bits(gb, 3); \
171 if (mqdiff != 7) \
172 mquant = v->pq + mqdiff; \
173 else \
174 mquant = get_bits(gb, 5); \
175 } \
176 } \
177 if (v->dqprofile == DQPROFILE_SINGLE_EDGE) \
178 edges = 1 << v->dqsbedge; \
179 else if (v->dqprofile == DQPROFILE_DOUBLE_EDGES) \
180 edges = (3 << v->dqsbedge) % 15; \
181 else if (v->dqprofile == DQPROFILE_FOUR_EDGES) \
182 edges = 15; \
183 if ((edges&1) && !s->mb_x) \
184 mquant = v->altpq; \
185 if ((edges&2) && s->first_slice_line) \
186 mquant = v->altpq; \
187 if ((edges&4) && s->mb_x == (s->mb_width - 1)) \
188 mquant = v->altpq; \
189 if ((edges&8) && s->mb_y == (s->mb_height - 1)) \
190 mquant = v->altpq; \
191 if (!mquant || mquant > 31) { \
192 av_log(v->s.avctx, AV_LOG_ERROR, \
193 "Overriding invalid mquant %d\n", mquant); \
194 mquant = 1; \
195 } \
196 }
197
198/**
199 * @def GET_MVDATA(_dmv_x, _dmv_y)
200 * @brief Get MV differentials
201 * @see MVDATA decoding from 8.3.5.2, p(1)20
202 * @param _dmv_x Horizontal differential for decoded MV
203 * @param _dmv_y Vertical differential for decoded MV
204 */
205#define GET_MVDATA(_dmv_x, _dmv_y) \
206 index = 1 + get_vlc2(gb, ff_vc1_mv_diff_vlc[s->mv_table_index].table, \
207 VC1_MV_DIFF_VLC_BITS, 2); \
208 if (index > 36) { \
209 mb_has_coeffs = 1; \
210 index -= 37; \
211 } else \
212 mb_has_coeffs = 0; \
213 s->mb_intra = 0; \
214 if (!index) { \
215 _dmv_x = _dmv_y = 0; \
216 } else if (index == 35) { \
217 _dmv_x = get_bits(gb, v->k_x - 1 + s->quarter_sample); \
218 _dmv_y = get_bits(gb, v->k_y - 1 + s->quarter_sample); \
219 } else if (index == 36) { \
220 _dmv_x = 0; \
221 _dmv_y = 0; \
222 s->mb_intra = 1; \
223 } else { \
224 index1 = index % 6; \
225 _dmv_x = offset_table[1][index1]; \
226 val = size_table[index1] - (!s->quarter_sample && index1 == 5); \
227 if (val > 0) { \
228 val = get_bits(gb, val); \
229 sign = 0 - (val & 1); \
230 _dmv_x = (sign ^ ((val >> 1) + _dmv_x)) - sign; \
231 } \
232 \
233 index1 = index / 6; \
234 _dmv_y = offset_table[1][index1]; \
235 val = size_table[index1] - (!s->quarter_sample && index1 == 5); \
236 if (val > 0) { \
237 val = get_bits(gb, val); \
238 sign = 0 - (val & 1); \
239 _dmv_y = (sign ^ ((val >> 1) + _dmv_y)) - sign; \
240 } \
241 }
242
243static av_always_inline void get_mvdata_interlaced(VC1Context *v, int *dmv_x,
244 int *dmv_y, int *pred_flag)
245{
246 int index, index1;
247 int extend_x, extend_y;
248 GetBitContext *gb = &v->s.gb;
249 int bits, esc;
250 int val, sign;
251
252 if (v->numref) {
253 bits = VC1_2REF_MVDATA_VLC_BITS;
254 esc = 125;
255 } else {
256 bits = VC1_1REF_MVDATA_VLC_BITS;
257 esc = 71;
258 }
259 extend_x = v->dmvrange & 1;
260 extend_y = (v->dmvrange >> 1) & 1;
261 index = get_vlc2(gb, v->imv_vlc->table, bits, 3);
262 if (index == esc) {
263 *dmv_x = get_bits(gb, v->k_x);
264 *dmv_y = get_bits(gb, v->k_y);
265 if (v->numref) {
266 if (pred_flag)
267 *pred_flag = *dmv_y & 1;
268 *dmv_y = (*dmv_y + (*dmv_y & 1)) >> 1;
269 }
270 }
271 else {
272 av_assert0(index < esc);
273 index1 = (index + 1) % 9;
274 if (index1 != 0) {
275 val = get_bits(gb, index1 + extend_x);
276 sign = 0 - (val & 1);
277 *dmv_x = (sign ^ ((val >> 1) + offset_table[extend_x][index1])) - sign;
278 } else
279 *dmv_x = 0;
280 index1 = (index + 1) / 9;
281 if (index1 > v->numref) {
282 val = get_bits(gb, (index1 >> v->numref) + extend_y);
283 sign = 0 - (val & 1);
284 *dmv_y = (sign ^ ((val >> 1) + offset_table[extend_y][index1 >> v->numref])) - sign;
285 } else
286 *dmv_y = 0;
287 if (v->numref && pred_flag)
288 *pred_flag = index1 & 1;
289 }
290}
291
292/** Reconstruct motion vector for B-frame and do motion compensation
293 */
294static inline void vc1_b_mc(VC1Context *v, int dmv_x[2], int dmv_y[2],
295 int direct, int mode)
296{
297 if (direct) {
298 ff_vc1_mc_1mv(v, 0);
299 ff_vc1_interp_mc(v);
300 return;
301 }
302 if (mode == BMV_TYPE_INTERPOLATED) {
303 ff_vc1_mc_1mv(v, 0);
304 ff_vc1_interp_mc(v);
305 return;
306 }
307
308 ff_vc1_mc_1mv(v, (mode == BMV_TYPE_BACKWARD));
309}
310
311/** Get predicted DC value for I-frames only
312 * prediction dir: left=0, top=1
313 * @param s MpegEncContext
314 * @param overlap flag indicating that overlap filtering is used
315 * @param pq integer part of picture quantizer
316 * @param[in] n block index in the current MB
317 * @param dc_val_ptr Pointer to DC predictor
318 * @param dir_ptr Prediction direction for use in AC prediction
319 */
320static inline int vc1_i_pred_dc(MpegEncContext *s, int overlap, int pq, int n,
321 int16_t **dc_val_ptr, int *dir_ptr)
322{
323 int a, b, c, wrap, pred, scale;
324 int16_t *dc_val;
325 static const uint16_t dcpred[32] = {
326 -1, 1024, 512, 341, 256, 205, 171, 146, 128,
327 114, 102, 93, 85, 79, 73, 68, 64,
328 60, 57, 54, 51, 49, 47, 45, 43,
329 41, 39, 38, 37, 35, 34, 33
330 };
331
332 /* find prediction - wmv3_dc_scale always used here in fact */
333 if (n < 4) scale = s->y_dc_scale;
334 else scale = s->c_dc_scale;
335
336 wrap = s->block_wrap[n];
337 dc_val = s->dc_val[0] + s->block_index[n];
338
339 /* B A
340 * C X
341 */
342 c = dc_val[ - 1];
343 b = dc_val[ - 1 - wrap];
344 a = dc_val[ - wrap];
345
346 if (pq < 9 || !overlap) {
347 /* Set outer values */
348 if (s->first_slice_line && (n != 2 && n != 3))
349 b = a = dcpred[scale];
350 if (s->mb_x == 0 && (n != 1 && n != 3))
351 b = c = dcpred[scale];
352 } else {
353 /* Set outer values */
354 if (s->first_slice_line && (n != 2 && n != 3))
355 b = a = 0;
356 if (s->mb_x == 0 && (n != 1 && n != 3))
357 b = c = 0;
358 }
359
360 if (abs(a - b) <= abs(b - c)) {
361 pred = c;
362 *dir_ptr = 1; // left
363 } else {
364 pred = a;
365 *dir_ptr = 0; // top
366 }
367
368 /* update predictor */
369 *dc_val_ptr = &dc_val[0];
370 return pred;
371}
372
373
374/** Get predicted DC value
375 * prediction dir: left=0, top=1
376 * @param s MpegEncContext
377 * @param overlap flag indicating that overlap filtering is used
378 * @param pq integer part of picture quantizer
379 * @param[in] n block index in the current MB
380 * @param a_avail flag indicating top block availability
381 * @param c_avail flag indicating left block availability
382 * @param dc_val_ptr Pointer to DC predictor
383 * @param dir_ptr Prediction direction for use in AC prediction
384 */
385static inline int ff_vc1_pred_dc(MpegEncContext *s, int overlap, int pq, int n,
386 int a_avail, int c_avail,
387 int16_t **dc_val_ptr, int *dir_ptr)
388{
389 int a, b, c, wrap, pred;
390 int16_t *dc_val;
391 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
392 int q1, q2 = 0;
393 int dqscale_index;
394
395 /* scale predictors if needed */
396 q1 = s->current_picture.qscale_table[mb_pos];
397 dqscale_index = s->y_dc_scale_table[q1] - 1;
398 if (dqscale_index < 0)
399 return 0;
400
401 wrap = s->block_wrap[n];
402 dc_val = s->dc_val[0] + s->block_index[n];
403
404 /* B A
405 * C X
406 */
407 c = dc_val[ - 1];
408 b = dc_val[ - 1 - wrap];
409 a = dc_val[ - wrap];
410
411 if (c_avail && (n != 1 && n != 3)) {
412 q2 = s->current_picture.qscale_table[mb_pos - 1];
413 if (q2 && q2 != q1)
414 c = (c * s->y_dc_scale_table[q2] * ff_vc1_dqscale[dqscale_index] + 0x20000) >> 18;
415 }
416 if (a_avail && (n != 2 && n != 3)) {
417 q2 = s->current_picture.qscale_table[mb_pos - s->mb_stride];
418 if (q2 && q2 != q1)
419 a = (a * s->y_dc_scale_table[q2] * ff_vc1_dqscale[dqscale_index] + 0x20000) >> 18;
420 }
421 if (a_avail && c_avail && (n != 3)) {
422 int off = mb_pos;
423 if (n != 1)
424 off--;
425 if (n != 2)
426 off -= s->mb_stride;
427 q2 = s->current_picture.qscale_table[off];
428 if (q2 && q2 != q1)
429 b = (b * s->y_dc_scale_table[q2] * ff_vc1_dqscale[dqscale_index] + 0x20000) >> 18;
430 }
431
432 if (c_avail && (!a_avail || abs(a - b) <= abs(b - c))) {
433 pred = c;
434 *dir_ptr = 1; // left
435 } else if (a_avail) {
436 pred = a;
437 *dir_ptr = 0; // top
438 } else {
439 pred = 0;
440 *dir_ptr = 1; // left
441 }
442
443 /* update predictor */
444 *dc_val_ptr = &dc_val[0];
445 return pred;
446}
447
448/** @} */ // Block group
449
450/**
451 * @name VC1 Macroblock-level functions in Simple/Main Profiles
452 * @see 7.1.4, p91 and 8.1.1.7, p(1)04
453 * @{
454 */
455
456static inline int vc1_coded_block_pred(MpegEncContext * s, int n,
457 uint8_t **coded_block_ptr)
458{
459 int xy, wrap, pred, a, b, c;
460
461 xy = s->block_index[n];
462 wrap = s->b8_stride;
463
464 /* B C
465 * A X
466 */
467 a = s->coded_block[xy - 1 ];
468 b = s->coded_block[xy - 1 - wrap];
469 c = s->coded_block[xy - wrap];
470
471 if (b == c) {
472 pred = a;
473 } else {
474 pred = c;
475 }
476
477 /* store value */
478 *coded_block_ptr = &s->coded_block[xy];
479
480 return pred;
481}
482
483/**
484 * Decode one AC coefficient
485 * @param v The VC1 context
486 * @param last Last coefficient
487 * @param skip How much zero coefficients to skip
488 * @param value Decoded AC coefficient value
489 * @param codingset set of VLC to decode data
490 * @see 8.1.3.4
491 */
492static void vc1_decode_ac_coeff(VC1Context *v, int *last, int *skip,
493 int *value, int codingset)
494{
495 GetBitContext *gb = &v->s.gb;
496 int index, run, level, lst, sign;
497
498 index = get_vlc2(gb, ff_vc1_ac_coeff_table[codingset].table, AC_VLC_BITS, 3);
499 if (index != ff_vc1_ac_sizes[codingset] - 1) {
500 run = vc1_index_decode_table[codingset][index][0];
501 level = vc1_index_decode_table[codingset][index][1];
502 lst = index >= vc1_last_decode_table[codingset] || get_bits_left(gb) < 0;
503 sign = get_bits1(gb);
504 } else {
505 int escape = decode210(gb);
506 if (escape != 2) {
507 index = get_vlc2(gb, ff_vc1_ac_coeff_table[codingset].table, AC_VLC_BITS, 3);
508 run = vc1_index_decode_table[codingset][index][0];
509 level = vc1_index_decode_table[codingset][index][1];
510 lst = index >= vc1_last_decode_table[codingset];
511 if (escape == 0) {
512 if (lst)
513 level += vc1_last_delta_level_table[codingset][run];
514 else
515 level += vc1_delta_level_table[codingset][run];
516 } else {
517 if (lst)
518 run += vc1_last_delta_run_table[codingset][level] + 1;
519 else
520 run += vc1_delta_run_table[codingset][level] + 1;
521 }
522 sign = get_bits1(gb);
523 } else {
524 lst = get_bits1(gb);
525 if (v->s.esc3_level_length == 0) {
526 if (v->pq < 8 || v->dquantfrm) { // table 59
527 v->s.esc3_level_length = get_bits(gb, 3);
528 if (!v->s.esc3_level_length)
529 v->s.esc3_level_length = get_bits(gb, 2) + 8;
530 } else { // table 60
531 v->s.esc3_level_length = get_unary(gb, 1, 6) + 2;
532 }
533 v->s.esc3_run_length = 3 + get_bits(gb, 2);
534 }
535 run = get_bits(gb, v->s.esc3_run_length);
536 sign = get_bits1(gb);
537 level = get_bits(gb, v->s.esc3_level_length);
538 }
539 }
540
541 *last = lst;
542 *skip = run;
543 *value = (level ^ -sign) + sign;
544}
545
546/** Decode intra block in intra frames - should be faster than decode_intra_block
547 * @param v VC1Context
548 * @param block block to decode
549 * @param[in] n subblock index
550 * @param coded are AC coeffs present or not
551 * @param codingset set of VLC to decode data
552 */
553static int vc1_decode_i_block(VC1Context *v, int16_t block[64], int n,
554 int coded, int codingset)
555{
556 GetBitContext *gb = &v->s.gb;
557 MpegEncContext *s = &v->s;
558 int dc_pred_dir = 0; /* Direction of the DC prediction used */
559 int i;
560 int16_t *dc_val;
561 int16_t *ac_val, *ac_val2;
562 int dcdiff, scale;
563
564 /* Get DC differential */
565 if (n < 4) {
566 dcdiff = get_vlc2(&s->gb, ff_msmp4_dc_luma_vlc[s->dc_table_index].table, DC_VLC_BITS, 3);
567 } else {
568 dcdiff = get_vlc2(&s->gb, ff_msmp4_dc_chroma_vlc[s->dc_table_index].table, DC_VLC_BITS, 3);
569 }
570 if (dcdiff < 0) {
571 av_log(s->avctx, AV_LOG_ERROR, "Illegal DC VLC\n");
572 return -1;
573 }
574 if (dcdiff) {
575 const int m = (v->pq == 1 || v->pq == 2) ? 3 - v->pq : 0;
576 if (dcdiff == 119 /* ESC index value */) {
577 dcdiff = get_bits(gb, 8 + m);
578 } else {
579 if (m)
580 dcdiff = (dcdiff << m) + get_bits(gb, m) - ((1 << m) - 1);
581 }
582 if (get_bits1(gb))
583 dcdiff = -dcdiff;
584 }
585
586 /* Prediction */
587 dcdiff += vc1_i_pred_dc(&v->s, v->overlap, v->pq, n, &dc_val, &dc_pred_dir);
588 *dc_val = dcdiff;
589
590 /* Store the quantized DC coeff, used for prediction */
591 if (n < 4)
592 scale = s->y_dc_scale;
593 else
594 scale = s->c_dc_scale;
595 block[0] = dcdiff * scale;
596
597 ac_val = s->ac_val[0][0] + s->block_index[n] * 16;
598 ac_val2 = ac_val;
599 if (dc_pred_dir) // left
600 ac_val -= 16;
601 else // top
602 ac_val -= 16 * s->block_wrap[n];
603
604 scale = v->pq * 2 + v->halfpq;
605
606 //AC Decoding
607 i = !!coded;
608
609 if (coded) {
610 int last = 0, skip, value;
611 const uint8_t *zz_table;
612 int k;
613
614 if (v->s.ac_pred) {
615 if (!dc_pred_dir)
616 zz_table = v->zz_8x8[2];
617 else
618 zz_table = v->zz_8x8[3];
619 } else
620 zz_table = v->zz_8x8[1];
621
622 while (!last) {
623 vc1_decode_ac_coeff(v, &last, &skip, &value, codingset);
624 i += skip;
625 if (i > 63)
626 break;
627 block[zz_table[i++]] = value;
628 }
629
630 /* apply AC prediction if needed */
631 if (s->ac_pred) {
632 int sh;
633 if (dc_pred_dir) { // left
634 sh = v->left_blk_sh;
635 } else { // top
636 sh = v->top_blk_sh;
637 ac_val += 8;
638 }
639 for (k = 1; k < 8; k++)
640 block[k << sh] += ac_val[k];
641 }
642 /* save AC coeffs for further prediction */
643 for (k = 1; k < 8; k++) {
644 ac_val2[k] = block[k << v->left_blk_sh];
645 ac_val2[k + 8] = block[k << v->top_blk_sh];
646 }
647
648 /* scale AC coeffs */
649 for (k = 1; k < 64; k++)
650 if (block[k]) {
651 block[k] *= scale;
652 if (!v->pquantizer)
653 block[k] += (block[k] < 0) ? -v->pq : v->pq;
654 }
655
656 } else {
657 int k;
658
659 memset(ac_val2, 0, 16 * 2);
660
661 /* apply AC prediction if needed */
662 if (s->ac_pred) {
663 int sh;
664 if (dc_pred_dir) { //left
665 sh = v->left_blk_sh;
666 } else { // top
667 sh = v->top_blk_sh;
668 ac_val += 8;
669 ac_val2 += 8;
670 }
671 memcpy(ac_val2, ac_val, 8 * 2);
672 for (k = 1; k < 8; k++) {
673 block[k << sh] = ac_val[k] * scale;
674 if (!v->pquantizer && block[k << sh])
675 block[k << sh] += (block[k << sh] < 0) ? -v->pq : v->pq;
676 }
677 }
678 }
679 if (s->ac_pred) i = 63;
680 s->block_last_index[n] = i;
681
682 return 0;
683}
684
685/** Decode intra block in intra frames - should be faster than decode_intra_block
686 * @param v VC1Context
687 * @param block block to decode
688 * @param[in] n subblock number
689 * @param coded are AC coeffs present or not
690 * @param codingset set of VLC to decode data
691 * @param mquant quantizer value for this macroblock
692 */
693static int vc1_decode_i_block_adv(VC1Context *v, int16_t block[64], int n,
694 int coded, int codingset, int mquant)
695{
696 GetBitContext *gb = &v->s.gb;
697 MpegEncContext *s = &v->s;
698 int dc_pred_dir = 0; /* Direction of the DC prediction used */
699 int i;
700 int16_t *dc_val = NULL;
701 int16_t *ac_val, *ac_val2;
702 int dcdiff;
703 int a_avail = v->a_avail, c_avail = v->c_avail;
704 int use_pred = s->ac_pred;
705 int scale;
706 int q1, q2 = 0;
707 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
708
709 /* Get DC differential */
710 if (n < 4) {
711 dcdiff = get_vlc2(&s->gb, ff_msmp4_dc_luma_vlc[s->dc_table_index].table, DC_VLC_BITS, 3);
712 } else {
713 dcdiff = get_vlc2(&s->gb, ff_msmp4_dc_chroma_vlc[s->dc_table_index].table, DC_VLC_BITS, 3);
714 }
715 if (dcdiff < 0) {
716 av_log(s->avctx, AV_LOG_ERROR, "Illegal DC VLC\n");
717 return -1;
718 }
719 if (dcdiff) {
720 const int m = (mquant == 1 || mquant == 2) ? 3 - mquant : 0;
721 if (dcdiff == 119 /* ESC index value */) {
722 dcdiff = get_bits(gb, 8 + m);
723 } else {
724 if (m)
725 dcdiff = (dcdiff << m) + get_bits(gb, m) - ((1 << m) - 1);
726 }
727 if (get_bits1(gb))
728 dcdiff = -dcdiff;
729 }
730
731 /* Prediction */
732 dcdiff += ff_vc1_pred_dc(&v->s, v->overlap, mquant, n, v->a_avail, v->c_avail, &dc_val, &dc_pred_dir);
733 *dc_val = dcdiff;
734
735 /* Store the quantized DC coeff, used for prediction */
736 if (n < 4)
737 scale = s->y_dc_scale;
738 else
739 scale = s->c_dc_scale;
740 block[0] = dcdiff * scale;
741
742 /* check if AC is needed at all */
743 if (!a_avail && !c_avail)
744 use_pred = 0;
745
746 scale = mquant * 2 + ((mquant == v->pq) ? v->halfpq : 0);
747
748 ac_val = s->ac_val[0][0] + s->block_index[n] * 16;
749 ac_val2 = ac_val;
750 if (dc_pred_dir) // left
751 ac_val -= 16;
752 else // top
753 ac_val -= 16 * s->block_wrap[n];
754
755 q1 = s->current_picture.qscale_table[mb_pos];
756 if (n == 3)
757 q2 = q1;
758 else if (dc_pred_dir) {
759 if (n == 1)
760 q2 = q1;
761 else if (c_avail && mb_pos)
762 q2 = s->current_picture.qscale_table[mb_pos - 1];
763 } else {
764 if (n == 2)
765 q2 = q1;
766 else if (a_avail && mb_pos >= s->mb_stride)
767 q2 = s->current_picture.qscale_table[mb_pos - s->mb_stride];
768 }
769
770 //AC Decoding
771 i = 1;
772
773 if (coded) {
774 int last = 0, skip, value;
775 const uint8_t *zz_table;
776 int k;
777
778 if (v->s.ac_pred) {
779 if (!use_pred && v->fcm == ILACE_FRAME) {
780 zz_table = v->zzi_8x8;
781 } else {
782 if (!dc_pred_dir) // top
783 zz_table = v->zz_8x8[2];
784 else // left
785 zz_table = v->zz_8x8[3];
786 }
787 } else {
788 if (v->fcm != ILACE_FRAME)
789 zz_table = v->zz_8x8[1];
790 else
791 zz_table = v->zzi_8x8;
792 }
793
794 while (!last) {
795 vc1_decode_ac_coeff(v, &last, &skip, &value, codingset);
796 i += skip;
797 if (i > 63)
798 break;
799 block[zz_table[i++]] = value;
800 }
801
802 /* apply AC prediction if needed */
803 if (use_pred) {
804 int sh;
805 if (dc_pred_dir) { // left
806 sh = v->left_blk_sh;
807 } else { // top
808 sh = v->top_blk_sh;
809 ac_val += 8;
810 }
811 /* scale predictors if needed*/
812 if (q2 && q1 != q2) {
813 q1 = q1 * 2 + ((q1 == v->pq) ? v->halfpq : 0) - 1;
814 if (q1 < 1)
815 return AVERROR_INVALIDDATA;
816 q2 = q2 * 2 + ((q2 == v->pq) ? v->halfpq : 0) - 1;
817 for (k = 1; k < 8; k++)
818 block[k << sh] += (ac_val[k] * q2 * ff_vc1_dqscale[q1 - 1] + 0x20000) >> 18;
819 } else {
820 for (k = 1; k < 8; k++)
821 block[k << sh] += ac_val[k];
822 }
823 }
824 /* save AC coeffs for further prediction */
825 for (k = 1; k < 8; k++) {
826 ac_val2[k ] = block[k << v->left_blk_sh];
827 ac_val2[k + 8] = block[k << v->top_blk_sh];
828 }
829
830 /* scale AC coeffs */
831 for (k = 1; k < 64; k++)
832 if (block[k]) {
833 block[k] *= scale;
834 if (!v->pquantizer)
835 block[k] += (block[k] < 0) ? -mquant : mquant;
836 }
837
838 } else { // no AC coeffs
839 int k;
840
841 memset(ac_val2, 0, 16 * 2);
842
843 /* apply AC prediction if needed */
844 if (use_pred) {
845 int sh;
846 if (dc_pred_dir) { // left
847 sh = v->left_blk_sh;
848 } else { // top
849 sh = v->top_blk_sh;
850 ac_val += 8;
851 ac_val2 += 8;
852 }
853 memcpy(ac_val2, ac_val, 8 * 2);
854 if (q2 && q1 != q2) {
855 q1 = q1 * 2 + ((q1 == v->pq) ? v->halfpq : 0) - 1;
856 q2 = q2 * 2 + ((q2 == v->pq) ? v->halfpq : 0) - 1;
857 if (q1 < 1)
858 return AVERROR_INVALIDDATA;
859 for (k = 1; k < 8; k++)
860 ac_val2[k] = (ac_val2[k] * q2 * ff_vc1_dqscale[q1 - 1] + 0x20000) >> 18;
861 }
862 for (k = 1; k < 8; k++) {
863 block[k << sh] = ac_val2[k] * scale;
864 if (!v->pquantizer && block[k << sh])
865 block[k << sh] += (block[k << sh] < 0) ? -mquant : mquant;
866 }
867 }
868 }
869 if (use_pred) i = 63;
870 s->block_last_index[n] = i;
871
872 return 0;
873}
874
875/** Decode intra block in inter frames - more generic version than vc1_decode_i_block
876 * @param v VC1Context
877 * @param block block to decode
878 * @param[in] n subblock index
879 * @param coded are AC coeffs present or not
880 * @param mquant block quantizer
881 * @param codingset set of VLC to decode data
882 */
883static int vc1_decode_intra_block(VC1Context *v, int16_t block[64], int n,
884 int coded, int mquant, int codingset)
885{
886 GetBitContext *gb = &v->s.gb;
887 MpegEncContext *s = &v->s;
888 int dc_pred_dir = 0; /* Direction of the DC prediction used */
889 int i;
890 int16_t *dc_val = NULL;
891 int16_t *ac_val, *ac_val2;
892 int dcdiff;
893 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
894 int a_avail = v->a_avail, c_avail = v->c_avail;
895 int use_pred = s->ac_pred;
896 int scale;
897 int q1, q2 = 0;
898
899 s->bdsp.clear_block(block);
900
901 /* XXX: Guard against dumb values of mquant */
902 mquant = av_clip_uintp2(mquant, 5);
903
904 /* Set DC scale - y and c use the same */
905 s->y_dc_scale = s->y_dc_scale_table[mquant];
906 s->c_dc_scale = s->c_dc_scale_table[mquant];
907
908 /* Get DC differential */
909 if (n < 4) {
910 dcdiff = get_vlc2(&s->gb, ff_msmp4_dc_luma_vlc[s->dc_table_index].table, DC_VLC_BITS, 3);
911 } else {
912 dcdiff = get_vlc2(&s->gb, ff_msmp4_dc_chroma_vlc[s->dc_table_index].table, DC_VLC_BITS, 3);
913 }
914 if (dcdiff < 0) {
915 av_log(s->avctx, AV_LOG_ERROR, "Illegal DC VLC\n");
916 return -1;
917 }
918 if (dcdiff) {
919 const int m = (mquant == 1 || mquant == 2) ? 3 - mquant : 0;
920 if (dcdiff == 119 /* ESC index value */) {
921 dcdiff = get_bits(gb, 8 + m);
922 } else {
923 if (m)
924 dcdiff = (dcdiff << m) + get_bits(gb, m) - ((1 << m) - 1);
925 }
926 if (get_bits1(gb))
927 dcdiff = -dcdiff;
928 }
929
930 /* Prediction */
931 dcdiff += ff_vc1_pred_dc(&v->s, v->overlap, mquant, n, a_avail, c_avail, &dc_val, &dc_pred_dir);
932 *dc_val = dcdiff;
933
934 /* Store the quantized DC coeff, used for prediction */
935
936 if (n < 4) {
937 block[0] = dcdiff * s->y_dc_scale;
938 } else {
939 block[0] = dcdiff * s->c_dc_scale;
940 }
941
942 //AC Decoding
943 i = 1;
944
945 /* check if AC is needed at all and adjust direction if needed */
946 if (!a_avail) dc_pred_dir = 1;
947 if (!c_avail) dc_pred_dir = 0;
948 if (!a_avail && !c_avail) use_pred = 0;
949 ac_val = s->ac_val[0][0] + s->block_index[n] * 16;
950 ac_val2 = ac_val;
951
952 scale = mquant * 2 + v->halfpq;
953
954 if (dc_pred_dir) //left
955 ac_val -= 16;
956 else //top
957 ac_val -= 16 * s->block_wrap[n];
958
959 q1 = s->current_picture.qscale_table[mb_pos];
960 if (dc_pred_dir && c_avail && mb_pos)
961 q2 = s->current_picture.qscale_table[mb_pos - 1];
962 if (!dc_pred_dir && a_avail && mb_pos >= s->mb_stride)
963 q2 = s->current_picture.qscale_table[mb_pos - s->mb_stride];
964 if (dc_pred_dir && n == 1)
965 q2 = q1;
966 if (!dc_pred_dir && n == 2)
967 q2 = q1;
968 if (n == 3) q2 = q1;
969
970 if (coded) {
971 int last = 0, skip, value;
972 int k;
973
974 while (!last) {
975 vc1_decode_ac_coeff(v, &last, &skip, &value, codingset);
976 i += skip;
977 if (i > 63)
978 break;
979 if (v->fcm == PROGRESSIVE)
980 block[v->zz_8x8[0][i++]] = value;
981 else {
982 if (use_pred && (v->fcm == ILACE_FRAME)) {
983 if (!dc_pred_dir) // top
984 block[v->zz_8x8[2][i++]] = value;
985 else // left
986 block[v->zz_8x8[3][i++]] = value;
987 } else {
988 block[v->zzi_8x8[i++]] = value;
989 }
990 }
991 }
992
993 /* apply AC prediction if needed */
994 if (use_pred) {
995 /* scale predictors if needed*/
996 if (q2 && q1 != q2) {
997 q1 = q1 * 2 + ((q1 == v->pq) ? v->halfpq : 0) - 1;
998 q2 = q2 * 2 + ((q2 == v->pq) ? v->halfpq : 0) - 1;
999
1000 if (q1 < 1)
1001 return AVERROR_INVALIDDATA;
1002 if (dc_pred_dir) { // left
1003 for (k = 1; k < 8; k++)
1004 block[k << v->left_blk_sh] += (ac_val[k] * q2 * ff_vc1_dqscale[q1 - 1] + 0x20000) >> 18;
1005 } else { //top
1006 for (k = 1; k < 8; k++)
1007 block[k << v->top_blk_sh] += (ac_val[k + 8] * q2 * ff_vc1_dqscale[q1 - 1] + 0x20000) >> 18;
1008 }
1009 } else {
1010 if (dc_pred_dir) { // left
1011 for (k = 1; k < 8; k++)
1012 block[k << v->left_blk_sh] += ac_val[k];
1013 } else { // top
1014 for (k = 1; k < 8; k++)
1015 block[k << v->top_blk_sh] += ac_val[k + 8];
1016 }
1017 }
1018 }
1019 /* save AC coeffs for further prediction */
1020 for (k = 1; k < 8; k++) {
1021 ac_val2[k ] = block[k << v->left_blk_sh];
1022 ac_val2[k + 8] = block[k << v->top_blk_sh];
1023 }
1024
1025 /* scale AC coeffs */
1026 for (k = 1; k < 64; k++)
1027 if (block[k]) {
1028 block[k] *= scale;
1029 if (!v->pquantizer)
1030 block[k] += (block[k] < 0) ? -mquant : mquant;
1031 }
1032
1033 if (use_pred) i = 63;
1034 } else { // no AC coeffs
1035 int k;
1036
1037 memset(ac_val2, 0, 16 * 2);
1038 if (dc_pred_dir) { // left
1039 if (use_pred) {
1040 memcpy(ac_val2, ac_val, 8 * 2);
1041 if (q2 && q1 != q2) {
1042 q1 = q1 * 2 + ((q1 == v->pq) ? v->halfpq : 0) - 1;
1043 q2 = q2 * 2 + ((q2 == v->pq) ? v->halfpq : 0) - 1;
1044 if (q1 < 1)
1045 return AVERROR_INVALIDDATA;
1046 for (k = 1; k < 8; k++)
1047 ac_val2[k] = (ac_val2[k] * q2 * ff_vc1_dqscale[q1 - 1] + 0x20000) >> 18;
1048 }
1049 }
1050 } else { // top
1051 if (use_pred) {
1052 memcpy(ac_val2 + 8, ac_val + 8, 8 * 2);
1053 if (q2 && q1 != q2) {
1054 q1 = q1 * 2 + ((q1 == v->pq) ? v->halfpq : 0) - 1;
1055 q2 = q2 * 2 + ((q2 == v->pq) ? v->halfpq : 0) - 1;
1056 if (q1 < 1)
1057 return AVERROR_INVALIDDATA;
1058 for (k = 1; k < 8; k++)
1059 ac_val2[k + 8] = (ac_val2[k + 8] * q2 * ff_vc1_dqscale[q1 - 1] + 0x20000) >> 18;
1060 }
1061 }
1062 }
1063
1064 /* apply AC prediction if needed */
1065 if (use_pred) {
1066 if (dc_pred_dir) { // left
1067 for (k = 1; k < 8; k++) {
1068 block[k << v->left_blk_sh] = ac_val2[k] * scale;
1069 if (!v->pquantizer && block[k << v->left_blk_sh])
1070 block[k << v->left_blk_sh] += (block[k << v->left_blk_sh] < 0) ? -mquant : mquant;
1071 }
1072 } else { // top
1073 for (k = 1; k < 8; k++) {
1074 block[k << v->top_blk_sh] = ac_val2[k + 8] * scale;
1075 if (!v->pquantizer && block[k << v->top_blk_sh])
1076 block[k << v->top_blk_sh] += (block[k << v->top_blk_sh] < 0) ? -mquant : mquant;
1077 }
1078 }
1079 i = 63;
1080 }
1081 }
1082 s->block_last_index[n] = i;
1083
1084 return 0;
1085}
1086
1087/** Decode P block
1088 */
1089static int vc1_decode_p_block(VC1Context *v, int16_t block[64], int n,
1090 int mquant, int ttmb, int first_block,
1091 uint8_t *dst, int linesize, int skip_block,
1092 int *ttmb_out)
1093{
1094 MpegEncContext *s = &v->s;
1095 GetBitContext *gb = &s->gb;
1096 int i, j;
1097 int subblkpat = 0;
1098 int scale, off, idx, last, skip, value;
1099 int ttblk = ttmb & 7;
1100 int pat = 0;
1101
1102 s->bdsp.clear_block(block);
1103
1104 if (ttmb == -1) {
1105 ttblk = ff_vc1_ttblk_to_tt[v->tt_index][get_vlc2(gb, ff_vc1_ttblk_vlc[v->tt_index].table, VC1_TTBLK_VLC_BITS, 1)];
1106 }
1107 if (ttblk == TT_4X4) {
1108 subblkpat = ~(get_vlc2(gb, ff_vc1_subblkpat_vlc[v->tt_index].table, VC1_SUBBLKPAT_VLC_BITS, 1) + 1);
1109 }
1110 if ((ttblk != TT_8X8 && ttblk != TT_4X4)
1111 && ((v->ttmbf || (ttmb != -1 && (ttmb & 8) && !first_block))
1112 || (!v->res_rtm_flag && !first_block))) {
1113 subblkpat = decode012(gb);
1114 if (subblkpat)
1115 subblkpat ^= 3; // swap decoded pattern bits
1116 if (ttblk == TT_8X4_TOP || ttblk == TT_8X4_BOTTOM)
1117 ttblk = TT_8X4;
1118 if (ttblk == TT_4X8_RIGHT || ttblk == TT_4X8_LEFT)
1119 ttblk = TT_4X8;
1120 }
1121 scale = 2 * mquant + ((v->pq == mquant) ? v->halfpq : 0);
1122
1123 // convert transforms like 8X4_TOP to generic TT and SUBBLKPAT
1124 if (ttblk == TT_8X4_TOP || ttblk == TT_8X4_BOTTOM) {
1125 subblkpat = 2 - (ttblk == TT_8X4_TOP);
1126 ttblk = TT_8X4;
1127 }
1128 if (ttblk == TT_4X8_RIGHT || ttblk == TT_4X8_LEFT) {
1129 subblkpat = 2 - (ttblk == TT_4X8_LEFT);
1130 ttblk = TT_4X8;
1131 }
1132 switch (ttblk) {
1133 case TT_8X8:
1134 pat = 0xF;
1135 i = 0;
1136 last = 0;
1137 while (!last) {
1138 vc1_decode_ac_coeff(v, &last, &skip, &value, v->codingset2);
1139 i += skip;
1140 if (i > 63)
1141 break;
1142 if (!v->fcm)
1143 idx = v->zz_8x8[0][i++];
1144 else
1145 idx = v->zzi_8x8[i++];
1146 block[idx] = value * scale;
1147 if (!v->pquantizer)
1148 block[idx] += (block[idx] < 0) ? -mquant : mquant;
1149 }
1150 if (!skip_block) {
1151 if (i == 1)
1152 v->vc1dsp.vc1_inv_trans_8x8_dc(dst, linesize, block);
1153 else {
1154 v->vc1dsp.vc1_inv_trans_8x8(block);
1155 s->idsp.add_pixels_clamped(block, dst, linesize);
1156 }
1157 }
1158 break;
1159 case TT_4X4:
1160 pat = ~subblkpat & 0xF;
1161 for (j = 0; j < 4; j++) {
1162 last = subblkpat & (1 << (3 - j));
1163 i = 0;
1164 off = (j & 1) * 4 + (j & 2) * 16;
1165 while (!last) {
1166 vc1_decode_ac_coeff(v, &last, &skip, &value, v->codingset2);
1167 i += skip;
1168 if (i > 15)
1169 break;
1170 if (!v->fcm)
1171 idx = ff_vc1_simple_progressive_4x4_zz[i++];
1172 else
1173 idx = ff_vc1_adv_interlaced_4x4_zz[i++];
1174 block[idx + off] = value * scale;
1175 if (!v->pquantizer)
1176 block[idx + off] += (block[idx + off] < 0) ? -mquant : mquant;
1177 }
1178 if (!(subblkpat & (1 << (3 - j))) && !skip_block) {
1179 if (i == 1)
1180 v->vc1dsp.vc1_inv_trans_4x4_dc(dst + (j & 1) * 4 + (j & 2) * 2 * linesize, linesize, block + off);
1181 else
1182 v->vc1dsp.vc1_inv_trans_4x4(dst + (j & 1) * 4 + (j & 2) * 2 * linesize, linesize, block + off);
1183 }
1184 }
1185 break;
1186 case TT_8X4:
1187 pat = ~((subblkpat & 2) * 6 + (subblkpat & 1) * 3) & 0xF;
1188 for (j = 0; j < 2; j++) {
1189 last = subblkpat & (1 << (1 - j));
1190 i = 0;
1191 off = j * 32;
1192 while (!last) {
1193 vc1_decode_ac_coeff(v, &last, &skip, &value, v->codingset2);
1194 i += skip;
1195 if (i > 31)
1196 break;
1197 if (!v->fcm)
1198 idx = v->zz_8x4[i++] + off;
1199 else
1200 idx = ff_vc1_adv_interlaced_8x4_zz[i++] + off;
1201 block[idx] = value * scale;
1202 if (!v->pquantizer)
1203 block[idx] += (block[idx] < 0) ? -mquant : mquant;
1204 }
1205 if (!(subblkpat & (1 << (1 - j))) && !skip_block) {
1206 if (i == 1)
1207 v->vc1dsp.vc1_inv_trans_8x4_dc(dst + j * 4 * linesize, linesize, block + off);
1208 else
1209 v->vc1dsp.vc1_inv_trans_8x4(dst + j * 4 * linesize, linesize, block + off);
1210 }
1211 }
1212 break;
1213 case TT_4X8:
1214 pat = ~(subblkpat * 5) & 0xF;
1215 for (j = 0; j < 2; j++) {
1216 last = subblkpat & (1 << (1 - j));
1217 i = 0;
1218 off = j * 4;
1219 while (!last) {
1220 vc1_decode_ac_coeff(v, &last, &skip, &value, v->codingset2);
1221 i += skip;
1222 if (i > 31)
1223 break;
1224 if (!v->fcm)
1225 idx = v->zz_4x8[i++] + off;
1226 else
1227 idx = ff_vc1_adv_interlaced_4x8_zz[i++] + off;
1228 block[idx] = value * scale;
1229 if (!v->pquantizer)
1230 block[idx] += (block[idx] < 0) ? -mquant : mquant;
1231 }
1232 if (!(subblkpat & (1 << (1 - j))) && !skip_block) {
1233 if (i == 1)
1234 v->vc1dsp.vc1_inv_trans_4x8_dc(dst + j * 4, linesize, block + off);
1235 else
1236 v->vc1dsp.vc1_inv_trans_4x8(dst + j*4, linesize, block + off);
1237 }
1238 }
1239 break;
1240 }
1241 if (ttmb_out)
1242 *ttmb_out |= ttblk << (n * 4);
1243 return pat;
1244}
1245
1246/** @} */ // Macroblock group
1247
1248static const uint8_t size_table[6] = { 0, 2, 3, 4, 5, 8 };
1249
1250/** Decode one P-frame MB
1251 */
1252static int vc1_decode_p_mb(VC1Context *v)
1253{
1254 MpegEncContext *s = &v->s;
1255 GetBitContext *gb = &s->gb;
1256 int i, j;
1257 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
1258 int cbp; /* cbp decoding stuff */
1259 int mqdiff, mquant; /* MB quantization */
1260 int ttmb = v->ttfrm; /* MB Transform type */
1261
1262 int mb_has_coeffs = 1; /* last_flag */
1263 int dmv_x, dmv_y; /* Differential MV components */
1264 int index, index1; /* LUT indexes */
1265 int val, sign; /* temp values */
1266 int first_block = 1;
1267 int dst_idx, off;
1268 int skipped, fourmv;
1269 int block_cbp = 0, pat, block_tt = 0, block_intra = 0;
1270
1271 mquant = v->pq; /* lossy initialization */
1272
1273 if (v->mv_type_is_raw)
1274 fourmv = get_bits1(gb);
1275 else
1276 fourmv = v->mv_type_mb_plane[mb_pos];
1277 if (v->skip_is_raw)
1278 skipped = get_bits1(gb);
1279 else
1280 skipped = v->s.mbskip_table[mb_pos];
1281
1282 if (!fourmv) { /* 1MV mode */
1283 if (!skipped) {
1284 GET_MVDATA(dmv_x, dmv_y);
1285
1286 if (s->mb_intra) {
1287 s->current_picture.motion_val[1][s->block_index[0]][0] = 0;
1288 s->current_picture.motion_val[1][s->block_index[0]][1] = 0;
1289 }
1290 s->current_picture.mb_type[mb_pos] = s->mb_intra ? MB_TYPE_INTRA : MB_TYPE_16x16;
1291 ff_vc1_pred_mv(v, 0, dmv_x, dmv_y, 1, v->range_x, v->range_y, v->mb_type[0], 0, 0);
1292
1293 /* FIXME Set DC val for inter block ? */
1294 if (s->mb_intra && !mb_has_coeffs) {
1295 GET_MQUANT();
1296 s->ac_pred = get_bits1(gb);
1297 cbp = 0;
1298 } else if (mb_has_coeffs) {
1299 if (s->mb_intra)
1300 s->ac_pred = get_bits1(gb);
1301 cbp = get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
1302 GET_MQUANT();
1303 } else {
1304 mquant = v->pq;
1305 cbp = 0;
1306 }
1307 s->current_picture.qscale_table[mb_pos] = mquant;
1308
1309 if (!v->ttmbf && !s->mb_intra && mb_has_coeffs)
1310 ttmb = get_vlc2(gb, ff_vc1_ttmb_vlc[v->tt_index].table,
1311 VC1_TTMB_VLC_BITS, 2);
1312 if (!s->mb_intra) ff_vc1_mc_1mv(v, 0);
1313 dst_idx = 0;
1314 for (i = 0; i < 6; i++) {
1315 s->dc_val[0][s->block_index[i]] = 0;
1316 dst_idx += i >> 2;
1317 val = ((cbp >> (5 - i)) & 1);
1318 off = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
1319 v->mb_type[0][s->block_index[i]] = s->mb_intra;
1320 if (s->mb_intra) {
1321 /* check if prediction blocks A and C are available */
1322 v->a_avail = v->c_avail = 0;
1323 if (i == 2 || i == 3 || !s->first_slice_line)
1324 v->a_avail = v->mb_type[0][s->block_index[i] - s->block_wrap[i]];
1325 if (i == 1 || i == 3 || s->mb_x)
1326 v->c_avail = v->mb_type[0][s->block_index[i] - 1];
1327
1328 vc1_decode_intra_block(v, s->block[i], i, val, mquant,
1329 (i & 4) ? v->codingset2 : v->codingset);
1330 if (CONFIG_GRAY && (i > 3) && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
1331 continue;
1332 v->vc1dsp.vc1_inv_trans_8x8(s->block[i]);
1333 if (v->rangeredfrm)
1334 for (j = 0; j < 64; j++)
1335 s->block[i][j] <<= 1;
1336 s->idsp.put_signed_pixels_clamped(s->block[i],
1337 s->dest[dst_idx] + off,
1338 i & 4 ? s->uvlinesize
1339 : s->linesize);
1340 if (v->pq >= 9 && v->overlap) {
1341 if (v->c_avail)
1342 v->vc1dsp.vc1_h_overlap(s->dest[dst_idx] + off, i & 4 ? s->uvlinesize : s->linesize);
1343 if (v->a_avail)
1344 v->vc1dsp.vc1_v_overlap(s->dest[dst_idx] + off, i & 4 ? s->uvlinesize : s->linesize);
1345 }
1346 block_cbp |= 0xF << (i << 2);
1347 block_intra |= 1 << i;
1348 } else if (val) {
1349 pat = vc1_decode_p_block(v, s->block[i], i, mquant, ttmb, first_block,
1350 s->dest[dst_idx] + off, (i & 4) ? s->uvlinesize : s->linesize,
1351 CONFIG_GRAY && (i & 4) && (s->avctx->flags & AV_CODEC_FLAG_GRAY), &block_tt);
1352 block_cbp |= pat << (i << 2);
1353 if (!v->ttmbf && ttmb < 8)
1354 ttmb = -1;
1355 first_block = 0;
1356 }
1357 }
1358 } else { // skipped
1359 s->mb_intra = 0;
1360 for (i = 0; i < 6; i++) {
1361 v->mb_type[0][s->block_index[i]] = 0;
1362 s->dc_val[0][s->block_index[i]] = 0;
1363 }
1364 s->current_picture.mb_type[mb_pos] = MB_TYPE_SKIP;
1365 s->current_picture.qscale_table[mb_pos] = 0;
1366 ff_vc1_pred_mv(v, 0, 0, 0, 1, v->range_x, v->range_y, v->mb_type[0], 0, 0);
1367 ff_vc1_mc_1mv(v, 0);
1368 }
1369 } else { // 4MV mode
1370 if (!skipped /* unskipped MB */) {
1371 int intra_count = 0, coded_inter = 0;
1372 int is_intra[6], is_coded[6];
1373 /* Get CBPCY */
1374 cbp = get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
1375 for (i = 0; i < 6; i++) {
1376 val = ((cbp >> (5 - i)) & 1);
1377 s->dc_val[0][s->block_index[i]] = 0;
1378 s->mb_intra = 0;
1379 if (i < 4) {
1380 dmv_x = dmv_y = 0;
1381 s->mb_intra = 0;
1382 mb_has_coeffs = 0;
1383 if (val) {
1384 GET_MVDATA(dmv_x, dmv_y);
1385 }
1386 ff_vc1_pred_mv(v, i, dmv_x, dmv_y, 0, v->range_x, v->range_y, v->mb_type[0], 0, 0);
1387 if (!s->mb_intra)
1388 ff_vc1_mc_4mv_luma(v, i, 0, 0);
1389 intra_count += s->mb_intra;
1390 is_intra[i] = s->mb_intra;
1391 is_coded[i] = mb_has_coeffs;
1392 }
1393 if (i & 4) {
1394 is_intra[i] = (intra_count >= 3);
1395 is_coded[i] = val;
1396 }
1397 if (i == 4)
1398 ff_vc1_mc_4mv_chroma(v, 0);
1399 v->mb_type[0][s->block_index[i]] = is_intra[i];
1400 if (!coded_inter)
1401 coded_inter = !is_intra[i] & is_coded[i];
1402 }
1403 // if there are no coded blocks then don't do anything more
1404 dst_idx = 0;
1405 if (!intra_count && !coded_inter)
1406 goto end;
1407 GET_MQUANT();
1408 s->current_picture.qscale_table[mb_pos] = mquant;
1409 /* test if block is intra and has pred */
1410 {
1411 int intrapred = 0;
1412 for (i = 0; i < 6; i++)
1413 if (is_intra[i]) {
1414 if (((!s->first_slice_line || (i == 2 || i == 3)) && v->mb_type[0][s->block_index[i] - s->block_wrap[i]])
1415 || ((s->mb_x || (i == 1 || i == 3)) && v->mb_type[0][s->block_index[i] - 1])) {
1416 intrapred = 1;
1417 break;
1418 }
1419 }
1420 if (intrapred)
1421 s->ac_pred = get_bits1(gb);
1422 else
1423 s->ac_pred = 0;
1424 }
1425 if (!v->ttmbf && coded_inter)
1426 ttmb = get_vlc2(gb, ff_vc1_ttmb_vlc[v->tt_index].table, VC1_TTMB_VLC_BITS, 2);
1427 for (i = 0; i < 6; i++) {
1428 dst_idx += i >> 2;
1429 off = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
1430 s->mb_intra = is_intra[i];
1431 if (is_intra[i]) {
1432 /* check if prediction blocks A and C are available */
1433 v->a_avail = v->c_avail = 0;
1434 if (i == 2 || i == 3 || !s->first_slice_line)
1435 v->a_avail = v->mb_type[0][s->block_index[i] - s->block_wrap[i]];
1436 if (i == 1 || i == 3 || s->mb_x)
1437 v->c_avail = v->mb_type[0][s->block_index[i] - 1];
1438
1439 vc1_decode_intra_block(v, s->block[i], i, is_coded[i], mquant,
1440 (i & 4) ? v->codingset2 : v->codingset);
1441 if (CONFIG_GRAY && (i > 3) && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
1442 continue;
1443 v->vc1dsp.vc1_inv_trans_8x8(s->block[i]);
1444 if (v->rangeredfrm)
1445 for (j = 0; j < 64; j++)
1446 s->block[i][j] <<= 1;
1447 s->idsp.put_signed_pixels_clamped(s->block[i],
1448 s->dest[dst_idx] + off,
1449 (i & 4) ? s->uvlinesize
1450 : s->linesize);
1451 if (v->pq >= 9 && v->overlap) {
1452 if (v->c_avail)
1453 v->vc1dsp.vc1_h_overlap(s->dest[dst_idx] + off, i & 4 ? s->uvlinesize : s->linesize);
1454 if (v->a_avail)
1455 v->vc1dsp.vc1_v_overlap(s->dest[dst_idx] + off, i & 4 ? s->uvlinesize : s->linesize);
1456 }
1457 block_cbp |= 0xF << (i << 2);
1458 block_intra |= 1 << i;
1459 } else if (is_coded[i]) {
1460 pat = vc1_decode_p_block(v, s->block[i], i, mquant, ttmb,
1461 first_block, s->dest[dst_idx] + off,
1462 (i & 4) ? s->uvlinesize : s->linesize,
1463 CONFIG_GRAY && (i & 4) && (s->avctx->flags & AV_CODEC_FLAG_GRAY),
1464 &block_tt);
1465 block_cbp |= pat << (i << 2);
1466 if (!v->ttmbf && ttmb < 8)
1467 ttmb = -1;
1468 first_block = 0;
1469 }
1470 }
1471 } else { // skipped MB
1472 s->mb_intra = 0;
1473 s->current_picture.qscale_table[mb_pos] = 0;
1474 for (i = 0; i < 6; i++) {
1475 v->mb_type[0][s->block_index[i]] = 0;
1476 s->dc_val[0][s->block_index[i]] = 0;
1477 }
1478 for (i = 0; i < 4; i++) {
1479 ff_vc1_pred_mv(v, i, 0, 0, 0, v->range_x, v->range_y, v->mb_type[0], 0, 0);
1480 ff_vc1_mc_4mv_luma(v, i, 0, 0);
1481 }
1482 ff_vc1_mc_4mv_chroma(v, 0);
1483 s->current_picture.qscale_table[mb_pos] = 0;
1484 }
1485 }
1486end:
1487 v->cbp[s->mb_x] = block_cbp;
1488 v->ttblk[s->mb_x] = block_tt;
1489 v->is_intra[s->mb_x] = block_intra;
1490
1491 return 0;
1492}
1493
1494/* Decode one macroblock in an interlaced frame p picture */
1495
1496static int vc1_decode_p_mb_intfr(VC1Context *v)
1497{
1498 MpegEncContext *s = &v->s;
1499 GetBitContext *gb = &s->gb;
1500 int i;
1501 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
1502 int cbp = 0; /* cbp decoding stuff */
1503 int mqdiff, mquant; /* MB quantization */
1504 int ttmb = v->ttfrm; /* MB Transform type */
1505
1506 int mb_has_coeffs = 1; /* last_flag */
1507 int dmv_x, dmv_y; /* Differential MV components */
1508 int val; /* temp value */
1509 int first_block = 1;
1510 int dst_idx, off;
1511 int skipped, fourmv = 0, twomv = 0;
1512 int block_cbp = 0, pat, block_tt = 0;
1513 int idx_mbmode = 0, mvbp;
1514 int stride_y, fieldtx;
1515
1516 mquant = v->pq; /* Lossy initialization */
1517
1518 if (v->skip_is_raw)
1519 skipped = get_bits1(gb);
1520 else
1521 skipped = v->s.mbskip_table[mb_pos];
1522 if (!skipped) {
1523 if (v->fourmvswitch)
1524 idx_mbmode = get_vlc2(gb, v->mbmode_vlc->table, VC1_INTFR_4MV_MBMODE_VLC_BITS, 2); // try getting this done
1525 else
1526 idx_mbmode = get_vlc2(gb, v->mbmode_vlc->table, VC1_INTFR_NON4MV_MBMODE_VLC_BITS, 2); // in a single line
1527 switch (ff_vc1_mbmode_intfrp[v->fourmvswitch][idx_mbmode][0]) {
1528 /* store the motion vector type in a flag (useful later) */
1529 case MV_PMODE_INTFR_4MV:
1530 fourmv = 1;
1531 v->blk_mv_type[s->block_index[0]] = 0;
1532 v->blk_mv_type[s->block_index[1]] = 0;
1533 v->blk_mv_type[s->block_index[2]] = 0;
1534 v->blk_mv_type[s->block_index[3]] = 0;
1535 break;
1536 case MV_PMODE_INTFR_4MV_FIELD:
1537 fourmv = 1;
1538 v->blk_mv_type[s->block_index[0]] = 1;
1539 v->blk_mv_type[s->block_index[1]] = 1;
1540 v->blk_mv_type[s->block_index[2]] = 1;
1541 v->blk_mv_type[s->block_index[3]] = 1;
1542 break;
1543 case MV_PMODE_INTFR_2MV_FIELD:
1544 twomv = 1;
1545 v->blk_mv_type[s->block_index[0]] = 1;
1546 v->blk_mv_type[s->block_index[1]] = 1;
1547 v->blk_mv_type[s->block_index[2]] = 1;
1548 v->blk_mv_type[s->block_index[3]] = 1;
1549 break;
1550 case MV_PMODE_INTFR_1MV:
1551 v->blk_mv_type[s->block_index[0]] = 0;
1552 v->blk_mv_type[s->block_index[1]] = 0;
1553 v->blk_mv_type[s->block_index[2]] = 0;
1554 v->blk_mv_type[s->block_index[3]] = 0;
1555 break;
1556 }
1557 if (ff_vc1_mbmode_intfrp[v->fourmvswitch][idx_mbmode][0] == MV_PMODE_INTFR_INTRA) { // intra MB
1558 for (i = 0; i < 4; i++) {
1559 s->current_picture.motion_val[1][s->block_index[i]][0] = 0;
1560 s->current_picture.motion_val[1][s->block_index[i]][1] = 0;
1561 }
1562 v->is_intra[s->mb_x] = 0x3f; // Set the bitfield to all 1.
1563 s->mb_intra = 1;
1564 s->current_picture.mb_type[mb_pos] = MB_TYPE_INTRA;
1565 fieldtx = v->fieldtx_plane[mb_pos] = get_bits1(gb);
1566 mb_has_coeffs = get_bits1(gb);
1567 if (mb_has_coeffs)
1568 cbp = 1 + get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
1569 v->s.ac_pred = v->acpred_plane[mb_pos] = get_bits1(gb);
1570 GET_MQUANT();
1571 s->current_picture.qscale_table[mb_pos] = mquant;
1572 /* Set DC scale - y and c use the same (not sure if necessary here) */
1573 s->y_dc_scale = s->y_dc_scale_table[mquant];
1574 s->c_dc_scale = s->c_dc_scale_table[mquant];
1575 dst_idx = 0;
1576 for (i = 0; i < 6; i++) {
1577 v->a_avail = v->c_avail = 0;
1578 v->mb_type[0][s->block_index[i]] = 1;
1579 s->dc_val[0][s->block_index[i]] = 0;
1580 dst_idx += i >> 2;
1581 val = ((cbp >> (5 - i)) & 1);
1582 if (i == 2 || i == 3 || !s->first_slice_line)
1583 v->a_avail = v->mb_type[0][s->block_index[i] - s->block_wrap[i]];
1584 if (i == 1 || i == 3 || s->mb_x)
1585 v->c_avail = v->mb_type[0][s->block_index[i] - 1];
1586
1587 vc1_decode_intra_block(v, s->block[i], i, val, mquant,
1588 (i & 4) ? v->codingset2 : v->codingset);
1589 if (CONFIG_GRAY && (i > 3) && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
1590 continue;
1591 v->vc1dsp.vc1_inv_trans_8x8(s->block[i]);
1592 if (i < 4) {
1593 stride_y = s->linesize << fieldtx;
1594 off = (fieldtx) ? ((i & 1) * 8) + ((i & 2) >> 1) * s->linesize : (i & 1) * 8 + 4 * (i & 2) * s->linesize;
1595 } else {
1596 stride_y = s->uvlinesize;
1597 off = 0;
1598 }
1599 s->idsp.put_signed_pixels_clamped(s->block[i],
1600 s->dest[dst_idx] + off,
1601 stride_y);
1602 //TODO: loop filter
1603 }
1604
1605 } else { // inter MB
1606 mb_has_coeffs = ff_vc1_mbmode_intfrp[v->fourmvswitch][idx_mbmode][3];
1607 if (mb_has_coeffs)
1608 cbp = 1 + get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
1609 if (ff_vc1_mbmode_intfrp[v->fourmvswitch][idx_mbmode][0] == MV_PMODE_INTFR_2MV_FIELD) {
1610 v->twomvbp = get_vlc2(gb, v->twomvbp_vlc->table, VC1_2MV_BLOCK_PATTERN_VLC_BITS, 1);
1611 } else {
1612 if ((ff_vc1_mbmode_intfrp[v->fourmvswitch][idx_mbmode][0] == MV_PMODE_INTFR_4MV)
1613 || (ff_vc1_mbmode_intfrp[v->fourmvswitch][idx_mbmode][0] == MV_PMODE_INTFR_4MV_FIELD)) {
1614 v->fourmvbp = get_vlc2(gb, v->fourmvbp_vlc->table, VC1_4MV_BLOCK_PATTERN_VLC_BITS, 1);
1615 }
1616 }
1617 s->mb_intra = v->is_intra[s->mb_x] = 0;
1618 for (i = 0; i < 6; i++)
1619 v->mb_type[0][s->block_index[i]] = 0;
1620 fieldtx = v->fieldtx_plane[mb_pos] = ff_vc1_mbmode_intfrp[v->fourmvswitch][idx_mbmode][1];
1621 /* for all motion vector read MVDATA and motion compensate each block */
1622 dst_idx = 0;
1623 if (fourmv) {
1624 mvbp = v->fourmvbp;
1625 for (i = 0; i < 4; i++) {
1626 dmv_x = dmv_y = 0;
1627 if (mvbp & (8 >> i))
1628 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
1629 ff_vc1_pred_mv_intfr(v, i, dmv_x, dmv_y, 0, v->range_x, v->range_y, v->mb_type[0], 0);
1630 ff_vc1_mc_4mv_luma(v, i, 0, 0);
1631 }
1632 ff_vc1_mc_4mv_chroma4(v, 0, 0, 0);
1633 } else if (twomv) {
1634 mvbp = v->twomvbp;
1635 dmv_x = dmv_y = 0;
1636 if (mvbp & 2) {
1637 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
1638 }
1639 ff_vc1_pred_mv_intfr(v, 0, dmv_x, dmv_y, 2, v->range_x, v->range_y, v->mb_type[0], 0);
1640 ff_vc1_mc_4mv_luma(v, 0, 0, 0);
1641 ff_vc1_mc_4mv_luma(v, 1, 0, 0);
1642 dmv_x = dmv_y = 0;
1643 if (mvbp & 1) {
1644 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
1645 }
1646 ff_vc1_pred_mv_intfr(v, 2, dmv_x, dmv_y, 2, v->range_x, v->range_y, v->mb_type[0], 0);
1647 ff_vc1_mc_4mv_luma(v, 2, 0, 0);
1648 ff_vc1_mc_4mv_luma(v, 3, 0, 0);
1649 ff_vc1_mc_4mv_chroma4(v, 0, 0, 0);
1650 } else {
1651 mvbp = ff_vc1_mbmode_intfrp[v->fourmvswitch][idx_mbmode][2];
1652 dmv_x = dmv_y = 0;
1653 if (mvbp) {
1654 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
1655 }
1656 ff_vc1_pred_mv_intfr(v, 0, dmv_x, dmv_y, 1, v->range_x, v->range_y, v->mb_type[0], 0);
1657 ff_vc1_mc_1mv(v, 0);
1658 }
1659 if (cbp)
1660 GET_MQUANT(); // p. 227
1661 s->current_picture.qscale_table[mb_pos] = mquant;
1662 if (!v->ttmbf && cbp)
1663 ttmb = get_vlc2(gb, ff_vc1_ttmb_vlc[v->tt_index].table, VC1_TTMB_VLC_BITS, 2);
1664 for (i = 0; i < 6; i++) {
1665 s->dc_val[0][s->block_index[i]] = 0;
1666 dst_idx += i >> 2;
1667 val = ((cbp >> (5 - i)) & 1);
1668 if (!fieldtx)
1669 off = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
1670 else
1671 off = (i & 4) ? 0 : ((i & 1) * 8 + ((i > 1) * s->linesize));
1672 if (val) {
1673 pat = vc1_decode_p_block(v, s->block[i], i, mquant, ttmb,
1674 first_block, s->dest[dst_idx] + off,
1675 (i & 4) ? s->uvlinesize : (s->linesize << fieldtx),
1676 CONFIG_GRAY && (i & 4) && (s->avctx->flags & AV_CODEC_FLAG_GRAY), &block_tt);
1677 block_cbp |= pat << (i << 2);
1678 if (!v->ttmbf && ttmb < 8)
1679 ttmb = -1;
1680 first_block = 0;
1681 }
1682 }
1683 }
1684 } else { // skipped
1685 s->mb_intra = v->is_intra[s->mb_x] = 0;
1686 for (i = 0; i < 6; i++) {
1687 v->mb_type[0][s->block_index[i]] = 0;
1688 s->dc_val[0][s->block_index[i]] = 0;
1689 }
1690 s->current_picture.mb_type[mb_pos] = MB_TYPE_SKIP;
1691 s->current_picture.qscale_table[mb_pos] = 0;
1692 v->blk_mv_type[s->block_index[0]] = 0;
1693 v->blk_mv_type[s->block_index[1]] = 0;
1694 v->blk_mv_type[s->block_index[2]] = 0;
1695 v->blk_mv_type[s->block_index[3]] = 0;
1696 ff_vc1_pred_mv_intfr(v, 0, 0, 0, 1, v->range_x, v->range_y, v->mb_type[0], 0);
1697 ff_vc1_mc_1mv(v, 0);
1698 }
1699 if (s->mb_x == s->mb_width - 1)
1700 memmove(v->is_intra_base, v->is_intra, sizeof(v->is_intra_base[0])*s->mb_stride);
1701 return 0;
1702}
1703
1704static int vc1_decode_p_mb_intfi(VC1Context *v)
1705{
1706 MpegEncContext *s = &v->s;
1707 GetBitContext *gb = &s->gb;
1708 int i;
1709 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
1710 int cbp = 0; /* cbp decoding stuff */
1711 int mqdiff, mquant; /* MB quantization */
1712 int ttmb = v->ttfrm; /* MB Transform type */
1713
1714 int mb_has_coeffs = 1; /* last_flag */
1715 int dmv_x, dmv_y; /* Differential MV components */
1716 int val; /* temp values */
1717 int first_block = 1;
1718 int dst_idx, off;
1719 int pred_flag = 0;
1720 int block_cbp = 0, pat, block_tt = 0;
1721 int idx_mbmode = 0;
1722
1723 mquant = v->pq; /* Lossy initialization */
1724
1725 idx_mbmode = get_vlc2(gb, v->mbmode_vlc->table, VC1_IF_MBMODE_VLC_BITS, 2);
1726 if (idx_mbmode <= 1) { // intra MB
1727 v->is_intra[s->mb_x] = 0x3f; // Set the bitfield to all 1.
1728 s->mb_intra = 1;
1729 s->current_picture.motion_val[1][s->block_index[0] + v->blocks_off][0] = 0;
1730 s->current_picture.motion_val[1][s->block_index[0] + v->blocks_off][1] = 0;
1731 s->current_picture.mb_type[mb_pos + v->mb_off] = MB_TYPE_INTRA;
1732 GET_MQUANT();
1733 s->current_picture.qscale_table[mb_pos] = mquant;
1734 /* Set DC scale - y and c use the same (not sure if necessary here) */
1735 s->y_dc_scale = s->y_dc_scale_table[mquant];
1736 s->c_dc_scale = s->c_dc_scale_table[mquant];
1737 v->s.ac_pred = v->acpred_plane[mb_pos] = get_bits1(gb);
1738 mb_has_coeffs = idx_mbmode & 1;
1739 if (mb_has_coeffs)
1740 cbp = 1 + get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_ICBPCY_VLC_BITS, 2);
1741 dst_idx = 0;
1742 for (i = 0; i < 6; i++) {
1743 v->a_avail = v->c_avail = 0;
1744 v->mb_type[0][s->block_index[i]] = 1;
1745 s->dc_val[0][s->block_index[i]] = 0;
1746 dst_idx += i >> 2;
1747 val = ((cbp >> (5 - i)) & 1);
1748 if (i == 2 || i == 3 || !s->first_slice_line)
1749 v->a_avail = v->mb_type[0][s->block_index[i] - s->block_wrap[i]];
1750 if (i == 1 || i == 3 || s->mb_x)
1751 v->c_avail = v->mb_type[0][s->block_index[i] - 1];
1752
1753 vc1_decode_intra_block(v, s->block[i], i, val, mquant,
1754 (i & 4) ? v->codingset2 : v->codingset);
1755 if (CONFIG_GRAY && (i > 3) && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
1756 continue;
1757 v->vc1dsp.vc1_inv_trans_8x8(s->block[i]);
1758 off = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
1759 s->idsp.put_signed_pixels_clamped(s->block[i],
1760 s->dest[dst_idx] + off,
1761 (i & 4) ? s->uvlinesize
1762 : s->linesize);
1763 // TODO: loop filter
1764 }
1765 } else {
1766 s->mb_intra = v->is_intra[s->mb_x] = 0;
1767 s->current_picture.mb_type[mb_pos + v->mb_off] = MB_TYPE_16x16;
1768 for (i = 0; i < 6; i++)
1769 v->mb_type[0][s->block_index[i]] = 0;
1770 if (idx_mbmode <= 5) { // 1-MV
1771 dmv_x = dmv_y = pred_flag = 0;
1772 if (idx_mbmode & 1) {
1773 get_mvdata_interlaced(v, &dmv_x, &dmv_y, &pred_flag);
1774 }
1775 ff_vc1_pred_mv(v, 0, dmv_x, dmv_y, 1, v->range_x, v->range_y, v->mb_type[0], pred_flag, 0);
1776 ff_vc1_mc_1mv(v, 0);
1777 mb_has_coeffs = !(idx_mbmode & 2);
1778 } else { // 4-MV
1779 v->fourmvbp = get_vlc2(gb, v->fourmvbp_vlc->table, VC1_4MV_BLOCK_PATTERN_VLC_BITS, 1);
1780 for (i = 0; i < 4; i++) {
1781 dmv_x = dmv_y = pred_flag = 0;
1782 if (v->fourmvbp & (8 >> i))
1783 get_mvdata_interlaced(v, &dmv_x, &dmv_y, &pred_flag);
1784 ff_vc1_pred_mv(v, i, dmv_x, dmv_y, 0, v->range_x, v->range_y, v->mb_type[0], pred_flag, 0);
1785 ff_vc1_mc_4mv_luma(v, i, 0, 0);
1786 }
1787 ff_vc1_mc_4mv_chroma(v, 0);
1788 mb_has_coeffs = idx_mbmode & 1;
1789 }
1790 if (mb_has_coeffs)
1791 cbp = 1 + get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
1792 if (cbp) {
1793 GET_MQUANT();
1794 }
1795 s->current_picture.qscale_table[mb_pos] = mquant;
1796 if (!v->ttmbf && cbp) {
1797 ttmb = get_vlc2(gb, ff_vc1_ttmb_vlc[v->tt_index].table, VC1_TTMB_VLC_BITS, 2);
1798 }
1799 dst_idx = 0;
1800 for (i = 0; i < 6; i++) {
1801 s->dc_val[0][s->block_index[i]] = 0;
1802 dst_idx += i >> 2;
1803 val = ((cbp >> (5 - i)) & 1);
1804 off = (i & 4) ? 0 : (i & 1) * 8 + (i & 2) * 4 * s->linesize;
1805 if (val) {
1806 pat = vc1_decode_p_block(v, s->block[i], i, mquant, ttmb,
1807 first_block, s->dest[dst_idx] + off,
1808 (i & 4) ? s->uvlinesize : s->linesize,
1809 CONFIG_GRAY && (i & 4) && (s->avctx->flags & AV_CODEC_FLAG_GRAY),
1810 &block_tt);
1811 block_cbp |= pat << (i << 2);
1812 if (!v->ttmbf && ttmb < 8)
1813 ttmb = -1;
1814 first_block = 0;
1815 }
1816 }
1817 }
1818 if (s->mb_x == s->mb_width - 1)
1819 memmove(v->is_intra_base, v->is_intra, sizeof(v->is_intra_base[0]) * s->mb_stride);
1820 return 0;
1821}
1822
1823/** Decode one B-frame MB (in Main profile)
1824 */
1825static void vc1_decode_b_mb(VC1Context *v)
1826{
1827 MpegEncContext *s = &v->s;
1828 GetBitContext *gb = &s->gb;
1829 int i, j;
1830 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
1831 int cbp = 0; /* cbp decoding stuff */
1832 int mqdiff, mquant; /* MB quantization */
1833 int ttmb = v->ttfrm; /* MB Transform type */
1834 int mb_has_coeffs = 0; /* last_flag */
1835 int index, index1; /* LUT indexes */
1836 int val, sign; /* temp values */
1837 int first_block = 1;
1838 int dst_idx, off;
1839 int skipped, direct;
1840 int dmv_x[2], dmv_y[2];
1841 int bmvtype = BMV_TYPE_BACKWARD;
1842
1843 mquant = v->pq; /* lossy initialization */
1844 s->mb_intra = 0;
1845
1846 if (v->dmb_is_raw)
1847 direct = get_bits1(gb);
1848 else
1849 direct = v->direct_mb_plane[mb_pos];
1850 if (v->skip_is_raw)
1851 skipped = get_bits1(gb);
1852 else
1853 skipped = v->s.mbskip_table[mb_pos];
1854
1855 dmv_x[0] = dmv_x[1] = dmv_y[0] = dmv_y[1] = 0;
1856 for (i = 0; i < 6; i++) {
1857 v->mb_type[0][s->block_index[i]] = 0;
1858 s->dc_val[0][s->block_index[i]] = 0;
1859 }
1860 s->current_picture.qscale_table[mb_pos] = 0;
1861
1862 if (!direct) {
1863 if (!skipped) {
1864 GET_MVDATA(dmv_x[0], dmv_y[0]);
1865 dmv_x[1] = dmv_x[0];
1866 dmv_y[1] = dmv_y[0];
1867 }
1868 if (skipped || !s->mb_intra) {
1869 bmvtype = decode012(gb);
1870 switch (bmvtype) {
1871 case 0:
1872 bmvtype = (v->bfraction >= (B_FRACTION_DEN/2)) ? BMV_TYPE_BACKWARD : BMV_TYPE_FORWARD;
1873 break;
1874 case 1:
1875 bmvtype = (v->bfraction >= (B_FRACTION_DEN/2)) ? BMV_TYPE_FORWARD : BMV_TYPE_BACKWARD;
1876 break;
1877 case 2:
1878 bmvtype = BMV_TYPE_INTERPOLATED;
1879 dmv_x[0] = dmv_y[0] = 0;
1880 }
1881 }
1882 }
1883 for (i = 0; i < 6; i++)
1884 v->mb_type[0][s->block_index[i]] = s->mb_intra;
1885
1886 if (skipped) {
1887 if (direct)
1888 bmvtype = BMV_TYPE_INTERPOLATED;
1889 ff_vc1_pred_b_mv(v, dmv_x, dmv_y, direct, bmvtype);
1890 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1891 return;
1892 }
1893 if (direct) {
1894 cbp = get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
1895 GET_MQUANT();
1896 s->mb_intra = 0;
1897 s->current_picture.qscale_table[mb_pos] = mquant;
1898 if (!v->ttmbf)
1899 ttmb = get_vlc2(gb, ff_vc1_ttmb_vlc[v->tt_index].table, VC1_TTMB_VLC_BITS, 2);
1900 dmv_x[0] = dmv_y[0] = dmv_x[1] = dmv_y[1] = 0;
1901 ff_vc1_pred_b_mv(v, dmv_x, dmv_y, direct, bmvtype);
1902 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1903 } else {
1904 if (!mb_has_coeffs && !s->mb_intra) {
1905 /* no coded blocks - effectively skipped */
1906 ff_vc1_pred_b_mv(v, dmv_x, dmv_y, direct, bmvtype);
1907 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1908 return;
1909 }
1910 if (s->mb_intra && !mb_has_coeffs) {
1911 GET_MQUANT();
1912 s->current_picture.qscale_table[mb_pos] = mquant;
1913 s->ac_pred = get_bits1(gb);
1914 cbp = 0;
1915 ff_vc1_pred_b_mv(v, dmv_x, dmv_y, direct, bmvtype);
1916 } else {
1917 if (bmvtype == BMV_TYPE_INTERPOLATED) {
1918 GET_MVDATA(dmv_x[0], dmv_y[0]);
1919 if (!mb_has_coeffs) {
1920 /* interpolated skipped block */
1921 ff_vc1_pred_b_mv(v, dmv_x, dmv_y, direct, bmvtype);
1922 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1923 return;
1924 }
1925 }
1926 ff_vc1_pred_b_mv(v, dmv_x, dmv_y, direct, bmvtype);
1927 if (!s->mb_intra) {
1928 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1929 }
1930 if (s->mb_intra)
1931 s->ac_pred = get_bits1(gb);
1932 cbp = get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
1933 GET_MQUANT();
1934 s->current_picture.qscale_table[mb_pos] = mquant;
1935 if (!v->ttmbf && !s->mb_intra && mb_has_coeffs)
1936 ttmb = get_vlc2(gb, ff_vc1_ttmb_vlc[v->tt_index].table, VC1_TTMB_VLC_BITS, 2);
1937 }
1938 }
1939 dst_idx = 0;
1940 for (i = 0; i < 6; i++) {
1941 s->dc_val[0][s->block_index[i]] = 0;
1942 dst_idx += i >> 2;
1943 val = ((cbp >> (5 - i)) & 1);
1944 off = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
1945 v->mb_type[0][s->block_index[i]] = s->mb_intra;
1946 if (s->mb_intra) {
1947 /* check if prediction blocks A and C are available */
1948 v->a_avail = v->c_avail = 0;
1949 if (i == 2 || i == 3 || !s->first_slice_line)
1950 v->a_avail = v->mb_type[0][s->block_index[i] - s->block_wrap[i]];
1951 if (i == 1 || i == 3 || s->mb_x)
1952 v->c_avail = v->mb_type[0][s->block_index[i] - 1];
1953
1954 vc1_decode_intra_block(v, s->block[i], i, val, mquant,
1955 (i & 4) ? v->codingset2 : v->codingset);
1956 if (CONFIG_GRAY && (i > 3) && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
1957 continue;
1958 v->vc1dsp.vc1_inv_trans_8x8(s->block[i]);
1959 if (v->rangeredfrm)
1960 for (j = 0; j < 64; j++)
1961 s->block[i][j] <<= 1;
1962 s->idsp.put_signed_pixels_clamped(s->block[i],
1963 s->dest[dst_idx] + off,
1964 i & 4 ? s->uvlinesize
1965 : s->linesize);
1966 } else if (val) {
1967 vc1_decode_p_block(v, s->block[i], i, mquant, ttmb,
1968 first_block, s->dest[dst_idx] + off,
1969 (i & 4) ? s->uvlinesize : s->linesize,
1970 CONFIG_GRAY && (i & 4) && (s->avctx->flags & AV_CODEC_FLAG_GRAY), NULL);
1971 if (!v->ttmbf && ttmb < 8)
1972 ttmb = -1;
1973 first_block = 0;
1974 }
1975 }
1976}
1977
1978/** Decode one B-frame MB (in interlaced field B picture)
1979 */
1980static void vc1_decode_b_mb_intfi(VC1Context *v)
1981{
1982 MpegEncContext *s = &v->s;
1983 GetBitContext *gb = &s->gb;
1984 int i, j;
1985 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
1986 int cbp = 0; /* cbp decoding stuff */
1987 int mqdiff, mquant; /* MB quantization */
1988 int ttmb = v->ttfrm; /* MB Transform type */
1989 int mb_has_coeffs = 0; /* last_flag */
1990 int val; /* temp value */
1991 int first_block = 1;
1992 int dst_idx, off;
1993 int fwd;
1994 int dmv_x[2], dmv_y[2], pred_flag[2];
1995 int bmvtype = BMV_TYPE_BACKWARD;
1996 int idx_mbmode;
1997
1998 mquant = v->pq; /* Lossy initialization */
1999 s->mb_intra = 0;
2000
2001 idx_mbmode = get_vlc2(gb, v->mbmode_vlc->table, VC1_IF_MBMODE_VLC_BITS, 2);
2002 if (idx_mbmode <= 1) { // intra MB
2003 v->is_intra[s->mb_x] = 0x3f; // Set the bitfield to all 1.
2004 s->mb_intra = 1;
2005 s->current_picture.motion_val[1][s->block_index[0]][0] = 0;
2006 s->current_picture.motion_val[1][s->block_index[0]][1] = 0;
2007 s->current_picture.mb_type[mb_pos + v->mb_off] = MB_TYPE_INTRA;
2008 GET_MQUANT();
2009 s->current_picture.qscale_table[mb_pos] = mquant;
2010 /* Set DC scale - y and c use the same (not sure if necessary here) */
2011 s->y_dc_scale = s->y_dc_scale_table[mquant];
2012 s->c_dc_scale = s->c_dc_scale_table[mquant];
2013 v->s.ac_pred = v->acpred_plane[mb_pos] = get_bits1(gb);
2014 mb_has_coeffs = idx_mbmode & 1;
2015 if (mb_has_coeffs)
2016 cbp = 1 + get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_ICBPCY_VLC_BITS, 2);
2017 dst_idx = 0;
2018 for (i = 0; i < 6; i++) {
2019 v->a_avail = v->c_avail = 0;
2020 v->mb_type[0][s->block_index[i]] = 1;
2021 s->dc_val[0][s->block_index[i]] = 0;
2022 dst_idx += i >> 2;
2023 val = ((cbp >> (5 - i)) & 1);
2024 if (i == 2 || i == 3 || !s->first_slice_line)
2025 v->a_avail = v->mb_type[0][s->block_index[i] - s->block_wrap[i]];
2026 if (i == 1 || i == 3 || s->mb_x)
2027 v->c_avail = v->mb_type[0][s->block_index[i] - 1];
2028
2029 vc1_decode_intra_block(v, s->block[i], i, val, mquant,
2030 (i & 4) ? v->codingset2 : v->codingset);
2031 if (CONFIG_GRAY && (i > 3) && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
2032 continue;
2033 v->vc1dsp.vc1_inv_trans_8x8(s->block[i]);
2034 if (v->rangeredfrm)
2035 for (j = 0; j < 64; j++)
2036 s->block[i][j] <<= 1;
2037 off = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
2038 s->idsp.put_signed_pixels_clamped(s->block[i],
2039 s->dest[dst_idx] + off,
2040 (i & 4) ? s->uvlinesize
2041 : s->linesize);
2042 // TODO: yet to perform loop filter
2043 }
2044 } else {
2045 s->mb_intra = v->is_intra[s->mb_x] = 0;
2046 s->current_picture.mb_type[mb_pos + v->mb_off] = MB_TYPE_16x16;
2047 for (i = 0; i < 6; i++)
2048 v->mb_type[0][s->block_index[i]] = 0;
2049 if (v->fmb_is_raw)
2050 fwd = v->forward_mb_plane[mb_pos] = get_bits1(gb);
2051 else
2052 fwd = v->forward_mb_plane[mb_pos];
2053 if (idx_mbmode <= 5) { // 1-MV
2054 int interpmvp = 0;
2055 dmv_x[0] = dmv_x[1] = dmv_y[0] = dmv_y[1] = 0;
2056 pred_flag[0] = pred_flag[1] = 0;
2057 if (fwd)
2058 bmvtype = BMV_TYPE_FORWARD;
2059 else {
2060 bmvtype = decode012(gb);
2061 switch (bmvtype) {
2062 case 0:
2063 bmvtype = BMV_TYPE_BACKWARD;
2064 break;
2065 case 1:
2066 bmvtype = BMV_TYPE_DIRECT;
2067 break;
2068 case 2:
2069 bmvtype = BMV_TYPE_INTERPOLATED;
2070 interpmvp = get_bits1(gb);
2071 }
2072 }
2073 v->bmvtype = bmvtype;
2074 if (bmvtype != BMV_TYPE_DIRECT && idx_mbmode & 1) {
2075 get_mvdata_interlaced(v, &dmv_x[bmvtype == BMV_TYPE_BACKWARD], &dmv_y[bmvtype == BMV_TYPE_BACKWARD], &pred_flag[bmvtype == BMV_TYPE_BACKWARD]);
2076 }
2077 if (interpmvp) {
2078 get_mvdata_interlaced(v, &dmv_x[1], &dmv_y[1], &pred_flag[1]);
2079 }
2080 if (bmvtype == BMV_TYPE_DIRECT) {
2081 dmv_x[0] = dmv_y[0] = pred_flag[0] = 0;
2082 dmv_x[1] = dmv_y[1] = pred_flag[0] = 0;
2083 if (!s->next_picture_ptr->field_picture) {
2084 av_log(s->avctx, AV_LOG_ERROR, "Mixed field/frame direct mode not supported\n");
2085 return;
2086 }
2087 }
2088 ff_vc1_pred_b_mv_intfi(v, 0, dmv_x, dmv_y, 1, pred_flag);
2089 vc1_b_mc(v, dmv_x, dmv_y, (bmvtype == BMV_TYPE_DIRECT), bmvtype);
2090 mb_has_coeffs = !(idx_mbmode & 2);
2091 } else { // 4-MV
2092 if (fwd)
2093 bmvtype = BMV_TYPE_FORWARD;
2094 v->bmvtype = bmvtype;
2095 v->fourmvbp = get_vlc2(gb, v->fourmvbp_vlc->table, VC1_4MV_BLOCK_PATTERN_VLC_BITS, 1);
2096 for (i = 0; i < 4; i++) {
2097 dmv_x[0] = dmv_y[0] = pred_flag[0] = 0;
2098 dmv_x[1] = dmv_y[1] = pred_flag[1] = 0;
2099 if (v->fourmvbp & (8 >> i)) {
2100 get_mvdata_interlaced(v, &dmv_x[bmvtype == BMV_TYPE_BACKWARD],
2101 &dmv_y[bmvtype == BMV_TYPE_BACKWARD],
2102 &pred_flag[bmvtype == BMV_TYPE_BACKWARD]);
2103 }
2104 ff_vc1_pred_b_mv_intfi(v, i, dmv_x, dmv_y, 0, pred_flag);
2105 ff_vc1_mc_4mv_luma(v, i, bmvtype == BMV_TYPE_BACKWARD, 0);
2106 }
2107 ff_vc1_mc_4mv_chroma(v, bmvtype == BMV_TYPE_BACKWARD);
2108 mb_has_coeffs = idx_mbmode & 1;
2109 }
2110 if (mb_has_coeffs)
2111 cbp = 1 + get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
2112 if (cbp) {
2113 GET_MQUANT();
2114 }
2115 s->current_picture.qscale_table[mb_pos] = mquant;
2116 if (!v->ttmbf && cbp) {
2117 ttmb = get_vlc2(gb, ff_vc1_ttmb_vlc[v->tt_index].table, VC1_TTMB_VLC_BITS, 2);
2118 }
2119 dst_idx = 0;
2120 for (i = 0; i < 6; i++) {
2121 s->dc_val[0][s->block_index[i]] = 0;
2122 dst_idx += i >> 2;
2123 val = ((cbp >> (5 - i)) & 1);
2124 off = (i & 4) ? 0 : (i & 1) * 8 + (i & 2) * 4 * s->linesize;
2125 if (val) {
2126 vc1_decode_p_block(v, s->block[i], i, mquant, ttmb,
2127 first_block, s->dest[dst_idx] + off,
2128 (i & 4) ? s->uvlinesize : s->linesize,
2129 CONFIG_GRAY && (i & 4) && (s->avctx->flags & AV_CODEC_FLAG_GRAY), NULL);
2130 if (!v->ttmbf && ttmb < 8)
2131 ttmb = -1;
2132 first_block = 0;
2133 }
2134 }
2135 }
2136}
2137
2138/** Decode one B-frame MB (in interlaced frame B picture)
2139 */
2140static int vc1_decode_b_mb_intfr(VC1Context *v)
2141{
2142 MpegEncContext *s = &v->s;
2143 GetBitContext *gb = &s->gb;
2144 int i, j;
2145 int mb_pos = s->mb_x + s->mb_y * s->mb_stride;
2146 int cbp = 0; /* cbp decoding stuff */
2147 int mqdiff, mquant; /* MB quantization */
2148 int ttmb = v->ttfrm; /* MB Transform type */
2149 int mvsw = 0; /* motion vector switch */
2150 int mb_has_coeffs = 1; /* last_flag */
2151 int dmv_x, dmv_y; /* Differential MV components */
2152 int val; /* temp value */
2153 int first_block = 1;
2154 int dst_idx, off;
2155 int skipped, direct, twomv = 0;
2156 int block_cbp = 0, pat, block_tt = 0;
2157 int idx_mbmode = 0, mvbp;
2158 int stride_y, fieldtx;
2159 int bmvtype = BMV_TYPE_BACKWARD;
2160 int dir, dir2;
2161
2162 mquant = v->pq; /* Lossy initialization */
2163 s->mb_intra = 0;
2164 if (v->skip_is_raw)
2165 skipped = get_bits1(gb);
2166 else
2167 skipped = v->s.mbskip_table[mb_pos];
2168
2169 if (!skipped) {
2170 idx_mbmode = get_vlc2(gb, v->mbmode_vlc->table, VC1_INTFR_NON4MV_MBMODE_VLC_BITS, 2);
2171 if (ff_vc1_mbmode_intfrp[0][idx_mbmode][0] == MV_PMODE_INTFR_2MV_FIELD) {
2172 twomv = 1;
2173 v->blk_mv_type[s->block_index[0]] = 1;
2174 v->blk_mv_type[s->block_index[1]] = 1;
2175 v->blk_mv_type[s->block_index[2]] = 1;
2176 v->blk_mv_type[s->block_index[3]] = 1;
2177 } else {
2178 v->blk_mv_type[s->block_index[0]] = 0;
2179 v->blk_mv_type[s->block_index[1]] = 0;
2180 v->blk_mv_type[s->block_index[2]] = 0;
2181 v->blk_mv_type[s->block_index[3]] = 0;
2182 }
2183 }
2184
2185 if (v->dmb_is_raw)
2186 direct = get_bits1(gb);
2187 else
2188 direct = v->direct_mb_plane[mb_pos];
2189
2190 if (direct) {
2191 if (s->next_picture_ptr->field_picture)
2192 av_log(s->avctx, AV_LOG_WARNING, "Mixed frame/field direct mode not supported\n");
2193 s->mv[0][0][0] = s->current_picture.motion_val[0][s->block_index[0]][0] = scale_mv(s->next_picture.motion_val[1][s->block_index[0]][0], v->bfraction, 0, s->quarter_sample);
2194 s->mv[0][0][1] = s->current_picture.motion_val[0][s->block_index[0]][1] = scale_mv(s->next_picture.motion_val[1][s->block_index[0]][1], v->bfraction, 0, s->quarter_sample);
2195 s->mv[1][0][0] = s->current_picture.motion_val[1][s->block_index[0]][0] = scale_mv(s->next_picture.motion_val[1][s->block_index[0]][0], v->bfraction, 1, s->quarter_sample);
2196 s->mv[1][0][1] = s->current_picture.motion_val[1][s->block_index[0]][1] = scale_mv(s->next_picture.motion_val[1][s->block_index[0]][1], v->bfraction, 1, s->quarter_sample);
2197
2198 if (twomv) {
2199 s->mv[0][2][0] = s->current_picture.motion_val[0][s->block_index[2]][0] = scale_mv(s->next_picture.motion_val[1][s->block_index[2]][0], v->bfraction, 0, s->quarter_sample);
2200 s->mv[0][2][1] = s->current_picture.motion_val[0][s->block_index[2]][1] = scale_mv(s->next_picture.motion_val[1][s->block_index[2]][1], v->bfraction, 0, s->quarter_sample);
2201 s->mv[1][2][0] = s->current_picture.motion_val[1][s->block_index[2]][0] = scale_mv(s->next_picture.motion_val[1][s->block_index[2]][0], v->bfraction, 1, s->quarter_sample);
2202 s->mv[1][2][1] = s->current_picture.motion_val[1][s->block_index[2]][1] = scale_mv(s->next_picture.motion_val[1][s->block_index[2]][1], v->bfraction, 1, s->quarter_sample);
2203
2204 for (i = 1; i < 4; i += 2) {
2205 s->mv[0][i][0] = s->current_picture.motion_val[0][s->block_index[i]][0] = s->mv[0][i-1][0];
2206 s->mv[0][i][1] = s->current_picture.motion_val[0][s->block_index[i]][1] = s->mv[0][i-1][1];
2207 s->mv[1][i][0] = s->current_picture.motion_val[1][s->block_index[i]][0] = s->mv[1][i-1][0];
2208 s->mv[1][i][1] = s->current_picture.motion_val[1][s->block_index[i]][1] = s->mv[1][i-1][1];
2209 }
2210 } else {
2211 for (i = 1; i < 4; i++) {
2212 s->mv[0][i][0] = s->current_picture.motion_val[0][s->block_index[i]][0] = s->mv[0][0][0];
2213 s->mv[0][i][1] = s->current_picture.motion_val[0][s->block_index[i]][1] = s->mv[0][0][1];
2214 s->mv[1][i][0] = s->current_picture.motion_val[1][s->block_index[i]][0] = s->mv[1][0][0];
2215 s->mv[1][i][1] = s->current_picture.motion_val[1][s->block_index[i]][1] = s->mv[1][0][1];
2216 }
2217 }
2218 }
2219
2220 if (ff_vc1_mbmode_intfrp[0][idx_mbmode][0] == MV_PMODE_INTFR_INTRA) { // intra MB
2221 for (i = 0; i < 4; i++) {
2222 s->mv[0][i][0] = s->current_picture.motion_val[0][s->block_index[i]][0] = 0;
2223 s->mv[0][i][1] = s->current_picture.motion_val[0][s->block_index[i]][1] = 0;
2224 s->mv[1][i][0] = s->current_picture.motion_val[1][s->block_index[i]][0] = 0;
2225 s->mv[1][i][1] = s->current_picture.motion_val[1][s->block_index[i]][1] = 0;
2226 }
2227 v->is_intra[s->mb_x] = 0x3f; // Set the bitfield to all 1.
2228 s->mb_intra = 1;
2229 s->current_picture.mb_type[mb_pos] = MB_TYPE_INTRA;
2230 fieldtx = v->fieldtx_plane[mb_pos] = get_bits1(gb);
2231 mb_has_coeffs = get_bits1(gb);
2232 if (mb_has_coeffs)
2233 cbp = 1 + get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
2234 v->s.ac_pred = v->acpred_plane[mb_pos] = get_bits1(gb);
2235 GET_MQUANT();
2236 s->current_picture.qscale_table[mb_pos] = mquant;
2237 /* Set DC scale - y and c use the same (not sure if necessary here) */
2238 s->y_dc_scale = s->y_dc_scale_table[mquant];
2239 s->c_dc_scale = s->c_dc_scale_table[mquant];
2240 dst_idx = 0;
2241 for (i = 0; i < 6; i++) {
2242 v->a_avail = v->c_avail = 0;
2243 v->mb_type[0][s->block_index[i]] = 1;
2244 s->dc_val[0][s->block_index[i]] = 0;
2245 dst_idx += i >> 2;
2246 val = ((cbp >> (5 - i)) & 1);
2247 if (i == 2 || i == 3 || !s->first_slice_line)
2248 v->a_avail = v->mb_type[0][s->block_index[i] - s->block_wrap[i]];
2249 if (i == 1 || i == 3 || s->mb_x)
2250 v->c_avail = v->mb_type[0][s->block_index[i] - 1];
2251
2252 vc1_decode_intra_block(v, s->block[i], i, val, mquant,
2253 (i & 4) ? v->codingset2 : v->codingset);
2254 if (CONFIG_GRAY && i > 3 && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
2255 continue;
2256 v->vc1dsp.vc1_inv_trans_8x8(s->block[i]);
2257 if (i < 4) {
2258 stride_y = s->linesize << fieldtx;
2259 off = (fieldtx) ? ((i & 1) * 8) + ((i & 2) >> 1) * s->linesize : (i & 1) * 8 + 4 * (i & 2) * s->linesize;
2260 } else {
2261 stride_y = s->uvlinesize;
2262 off = 0;
2263 }
2264 s->idsp.put_signed_pixels_clamped(s->block[i],
2265 s->dest[dst_idx] + off,
2266 stride_y);
2267 }
2268 } else {
2269 s->mb_intra = v->is_intra[s->mb_x] = 0;
2270 if (!direct) {
2271 if (skipped || !s->mb_intra) {
2272 bmvtype = decode012(gb);
2273 switch (bmvtype) {
2274 case 0:
2275 bmvtype = (v->bfraction >= (B_FRACTION_DEN/2)) ? BMV_TYPE_BACKWARD : BMV_TYPE_FORWARD;
2276 break;
2277 case 1:
2278 bmvtype = (v->bfraction >= (B_FRACTION_DEN/2)) ? BMV_TYPE_FORWARD : BMV_TYPE_BACKWARD;
2279 break;
2280 case 2:
2281 bmvtype = BMV_TYPE_INTERPOLATED;
2282 }
2283 }
2284
2285 if (twomv && bmvtype != BMV_TYPE_INTERPOLATED)
2286 mvsw = get_bits1(gb);
2287 }
2288
2289 if (!skipped) { // inter MB
2290 mb_has_coeffs = ff_vc1_mbmode_intfrp[0][idx_mbmode][3];
2291 if (mb_has_coeffs)
2292 cbp = 1 + get_vlc2(&v->s.gb, v->cbpcy_vlc->table, VC1_CBPCY_P_VLC_BITS, 2);
2293 if (!direct) {
2294 if (bmvtype == BMV_TYPE_INTERPOLATED && twomv) {
2295 v->fourmvbp = get_vlc2(gb, v->fourmvbp_vlc->table, VC1_4MV_BLOCK_PATTERN_VLC_BITS, 1);
2296 } else if (bmvtype == BMV_TYPE_INTERPOLATED || twomv) {
2297 v->twomvbp = get_vlc2(gb, v->twomvbp_vlc->table, VC1_2MV_BLOCK_PATTERN_VLC_BITS, 1);
2298 }
2299 }
2300
2301 for (i = 0; i < 6; i++)
2302 v->mb_type[0][s->block_index[i]] = 0;
2303 fieldtx = v->fieldtx_plane[mb_pos] = ff_vc1_mbmode_intfrp[0][idx_mbmode][1];
2304 /* for all motion vector read MVDATA and motion compensate each block */
2305 dst_idx = 0;
2306 if (direct) {
2307 if (twomv) {
2308 for (i = 0; i < 4; i++) {
2309 ff_vc1_mc_4mv_luma(v, i, 0, 0);
2310 ff_vc1_mc_4mv_luma(v, i, 1, 1);
2311 }
2312 ff_vc1_mc_4mv_chroma4(v, 0, 0, 0);
2313 ff_vc1_mc_4mv_chroma4(v, 1, 1, 1);
2314 } else {
2315 ff_vc1_mc_1mv(v, 0);
2316 ff_vc1_interp_mc(v);
2317 }
2318 } else if (twomv && bmvtype == BMV_TYPE_INTERPOLATED) {
2319 mvbp = v->fourmvbp;
2320 for (i = 0; i < 4; i++) {
2321 dir = i==1 || i==3;
2322 dmv_x = dmv_y = 0;
2323 val = ((mvbp >> (3 - i)) & 1);
2324 if (val)
2325 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
2326 j = i > 1 ? 2 : 0;
2327 ff_vc1_pred_mv_intfr(v, j, dmv_x, dmv_y, 2, v->range_x, v->range_y, v->mb_type[0], dir);
2328 ff_vc1_mc_4mv_luma(v, j, dir, dir);
2329 ff_vc1_mc_4mv_luma(v, j+1, dir, dir);
2330 }
2331
2332 ff_vc1_mc_4mv_chroma4(v, 0, 0, 0);
2333 ff_vc1_mc_4mv_chroma4(v, 1, 1, 1);
2334 } else if (bmvtype == BMV_TYPE_INTERPOLATED) {
2335 mvbp = v->twomvbp;
2336 dmv_x = dmv_y = 0;
2337 if (mvbp & 2)
2338 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
2339
2340 ff_vc1_pred_mv_intfr(v, 0, dmv_x, dmv_y, 1, v->range_x, v->range_y, v->mb_type[0], 0);
2341 ff_vc1_mc_1mv(v, 0);
2342
2343 dmv_x = dmv_y = 0;
2344 if (mvbp & 1)
2345 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
2346
2347 ff_vc1_pred_mv_intfr(v, 0, dmv_x, dmv_y, 1, v->range_x, v->range_y, v->mb_type[0], 1);
2348 ff_vc1_interp_mc(v);
2349 } else if (twomv) {
2350 dir = bmvtype == BMV_TYPE_BACKWARD;
2351 dir2 = dir;
2352 if (mvsw)
2353 dir2 = !dir;
2354 mvbp = v->twomvbp;
2355 dmv_x = dmv_y = 0;
2356 if (mvbp & 2)
2357 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
2358 ff_vc1_pred_mv_intfr(v, 0, dmv_x, dmv_y, 2, v->range_x, v->range_y, v->mb_type[0], dir);
2359
2360 dmv_x = dmv_y = 0;
2361 if (mvbp & 1)
2362 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
2363 ff_vc1_pred_mv_intfr(v, 2, dmv_x, dmv_y, 2, v->range_x, v->range_y, v->mb_type[0], dir2);
2364
2365 if (mvsw) {
2366 for (i = 0; i < 2; i++) {
2367 s->mv[dir][i+2][0] = s->mv[dir][i][0] = s->current_picture.motion_val[dir][s->block_index[i+2]][0] = s->current_picture.motion_val[dir][s->block_index[i]][0];
2368 s->mv[dir][i+2][1] = s->mv[dir][i][1] = s->current_picture.motion_val[dir][s->block_index[i+2]][1] = s->current_picture.motion_val[dir][s->block_index[i]][1];
2369 s->mv[dir2][i+2][0] = s->mv[dir2][i][0] = s->current_picture.motion_val[dir2][s->block_index[i]][0] = s->current_picture.motion_val[dir2][s->block_index[i+2]][0];
2370 s->mv[dir2][i+2][1] = s->mv[dir2][i][1] = s->current_picture.motion_val[dir2][s->block_index[i]][1] = s->current_picture.motion_val[dir2][s->block_index[i+2]][1];
2371 }
2372 } else {
2373 ff_vc1_pred_mv_intfr(v, 0, 0, 0, 2, v->range_x, v->range_y, v->mb_type[0], !dir);
2374 ff_vc1_pred_mv_intfr(v, 2, 0, 0, 2, v->range_x, v->range_y, v->mb_type[0], !dir);
2375 }
2376
2377 ff_vc1_mc_4mv_luma(v, 0, dir, 0);
2378 ff_vc1_mc_4mv_luma(v, 1, dir, 0);
2379 ff_vc1_mc_4mv_luma(v, 2, dir2, 0);
2380 ff_vc1_mc_4mv_luma(v, 3, dir2, 0);
2381 ff_vc1_mc_4mv_chroma4(v, dir, dir2, 0);
2382 } else {
2383 dir = bmvtype == BMV_TYPE_BACKWARD;
2384
2385 mvbp = ff_vc1_mbmode_intfrp[0][idx_mbmode][2];
2386 dmv_x = dmv_y = 0;
2387 if (mvbp)
2388 get_mvdata_interlaced(v, &dmv_x, &dmv_y, 0);
2389
2390 ff_vc1_pred_mv_intfr(v, 0, dmv_x, dmv_y, 1, v->range_x, v->range_y, v->mb_type[0], dir);
2391 v->blk_mv_type[s->block_index[0]] = 1;
2392 v->blk_mv_type[s->block_index[1]] = 1;
2393 v->blk_mv_type[s->block_index[2]] = 1;
2394 v->blk_mv_type[s->block_index[3]] = 1;
2395 ff_vc1_pred_mv_intfr(v, 0, 0, 0, 2, v->range_x, v->range_y, 0, !dir);
2396 for (i = 0; i < 2; i++) {
2397 s->mv[!dir][i+2][0] = s->mv[!dir][i][0] = s->current_picture.motion_val[!dir][s->block_index[i+2]][0] = s->current_picture.motion_val[!dir][s->block_index[i]][0];
2398 s->mv[!dir][i+2][1] = s->mv[!dir][i][1] = s->current_picture.motion_val[!dir][s->block_index[i+2]][1] = s->current_picture.motion_val[!dir][s->block_index[i]][1];
2399 }
2400 ff_vc1_mc_1mv(v, dir);
2401 }
2402
2403 if (cbp)
2404 GET_MQUANT(); // p. 227
2405 s->current_picture.qscale_table[mb_pos] = mquant;
2406 if (!v->ttmbf && cbp)
2407 ttmb = get_vlc2(gb, ff_vc1_ttmb_vlc[v->tt_index].table, VC1_TTMB_VLC_BITS, 2);
2408 for (i = 0; i < 6; i++) {
2409 s->dc_val[0][s->block_index[i]] = 0;
2410 dst_idx += i >> 2;
2411 val = ((cbp >> (5 - i)) & 1);
2412 if (!fieldtx)
2413 off = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
2414 else
2415 off = (i & 4) ? 0 : ((i & 1) * 8 + ((i > 1) * s->linesize));
2416 if (val) {
2417 pat = vc1_decode_p_block(v, s->block[i], i, mquant, ttmb,
2418 first_block, s->dest[dst_idx] + off,
2419 (i & 4) ? s->uvlinesize : (s->linesize << fieldtx),
2420 CONFIG_GRAY && (i & 4) && (s->avctx->flags & AV_CODEC_FLAG_GRAY), &block_tt);
2421 block_cbp |= pat << (i << 2);
2422 if (!v->ttmbf && ttmb < 8)
2423 ttmb = -1;
2424 first_block = 0;
2425 }
2426 }
2427
2428 } else { // skipped
2429 dir = 0;
2430 for (i = 0; i < 6; i++) {
2431 v->mb_type[0][s->block_index[i]] = 0;
2432 s->dc_val[0][s->block_index[i]] = 0;
2433 }
2434 s->current_picture.mb_type[mb_pos] = MB_TYPE_SKIP;
2435 s->current_picture.qscale_table[mb_pos] = 0;
2436 v->blk_mv_type[s->block_index[0]] = 0;
2437 v->blk_mv_type[s->block_index[1]] = 0;
2438 v->blk_mv_type[s->block_index[2]] = 0;
2439 v->blk_mv_type[s->block_index[3]] = 0;
2440
2441 if (!direct) {
2442 if (bmvtype == BMV_TYPE_INTERPOLATED) {
2443 ff_vc1_pred_mv_intfr(v, 0, 0, 0, 1, v->range_x, v->range_y, v->mb_type[0], 0);
2444 ff_vc1_pred_mv_intfr(v, 0, 0, 0, 1, v->range_x, v->range_y, v->mb_type[0], 1);
2445 } else {
2446 dir = bmvtype == BMV_TYPE_BACKWARD;
2447 ff_vc1_pred_mv_intfr(v, 0, 0, 0, 1, v->range_x, v->range_y, v->mb_type[0], dir);
2448 if (mvsw) {
2449 int dir2 = dir;
2450 if (mvsw)
2451 dir2 = !dir;
2452 for (i = 0; i < 2; i++) {
2453 s->mv[dir][i+2][0] = s->mv[dir][i][0] = s->current_picture.motion_val[dir][s->block_index[i+2]][0] = s->current_picture.motion_val[dir][s->block_index[i]][0];
2454 s->mv[dir][i+2][1] = s->mv[dir][i][1] = s->current_picture.motion_val[dir][s->block_index[i+2]][1] = s->current_picture.motion_val[dir][s->block_index[i]][1];
2455 s->mv[dir2][i+2][0] = s->mv[dir2][i][0] = s->current_picture.motion_val[dir2][s->block_index[i]][0] = s->current_picture.motion_val[dir2][s->block_index[i+2]][0];
2456 s->mv[dir2][i+2][1] = s->mv[dir2][i][1] = s->current_picture.motion_val[dir2][s->block_index[i]][1] = s->current_picture.motion_val[dir2][s->block_index[i+2]][1];
2457 }
2458 } else {
2459 v->blk_mv_type[s->block_index[0]] = 1;
2460 v->blk_mv_type[s->block_index[1]] = 1;
2461 v->blk_mv_type[s->block_index[2]] = 1;
2462 v->blk_mv_type[s->block_index[3]] = 1;
2463 ff_vc1_pred_mv_intfr(v, 0, 0, 0, 2, v->range_x, v->range_y, 0, !dir);
2464 for (i = 0; i < 2; i++) {
2465 s->mv[!dir][i+2][0] = s->mv[!dir][i][0] = s->current_picture.motion_val[!dir][s->block_index[i+2]][0] = s->current_picture.motion_val[!dir][s->block_index[i]][0];
2466 s->mv[!dir][i+2][1] = s->mv[!dir][i][1] = s->current_picture.motion_val[!dir][s->block_index[i+2]][1] = s->current_picture.motion_val[!dir][s->block_index[i]][1];
2467 }
2468 }
2469 }
2470 }
2471
2472 ff_vc1_mc_1mv(v, dir);
2473 if (direct || bmvtype == BMV_TYPE_INTERPOLATED) {
2474 ff_vc1_interp_mc(v);
2475 }
2476 }
2477 }
2478 if (s->mb_x == s->mb_width - 1)
2479 memmove(v->is_intra_base, v->is_intra, sizeof(v->is_intra_base[0]) * s->mb_stride);
2480 v->cbp[s->mb_x] = block_cbp;
2481 v->ttblk[s->mb_x] = block_tt;
2482 return 0;
2483}
2484
2485/** Decode blocks of I-frame
2486 */
2487static void vc1_decode_i_blocks(VC1Context *v)
2488{
2489 int k, j;
2490 MpegEncContext *s = &v->s;
2491 int cbp, val;
2492 uint8_t *coded_val;
2493 int mb_pos;
2494
2495 /* select coding mode used for VLC tables selection */
2496 switch (v->y_ac_table_index) {
2497 case 0:
2498 v->codingset = (v->pqindex <= 8) ? CS_HIGH_RATE_INTRA : CS_LOW_MOT_INTRA;
2499 break;
2500 case 1:
2501 v->codingset = CS_HIGH_MOT_INTRA;
2502 break;
2503 case 2:
2504 v->codingset = CS_MID_RATE_INTRA;
2505 break;
2506 }
2507
2508 switch (v->c_ac_table_index) {
2509 case 0:
2510 v->codingset2 = (v->pqindex <= 8) ? CS_HIGH_RATE_INTER : CS_LOW_MOT_INTER;
2511 break;
2512 case 1:
2513 v->codingset2 = CS_HIGH_MOT_INTER;
2514 break;
2515 case 2:
2516 v->codingset2 = CS_MID_RATE_INTER;
2517 break;
2518 }
2519
2520 /* Set DC scale - y and c use the same */
2521 s->y_dc_scale = s->y_dc_scale_table[v->pq];
2522 s->c_dc_scale = s->c_dc_scale_table[v->pq];
2523
2524 //do frame decode
2525 s->mb_x = s->mb_y = 0;
2526 s->mb_intra = 1;
2527 s->first_slice_line = 1;
2528 for (s->mb_y = 0; s->mb_y < s->end_mb_y; s->mb_y++) {
2529 s->mb_x = 0;
2530 init_block_index(v);
2531 for (; s->mb_x < v->end_mb_x; s->mb_x++) {
2532 uint8_t *dst[6];
2533 ff_update_block_index(s);
2534 dst[0] = s->dest[0];
2535 dst[1] = dst[0] + 8;
2536 dst[2] = s->dest[0] + s->linesize * 8;
2537 dst[3] = dst[2] + 8;
2538 dst[4] = s->dest[1];
2539 dst[5] = s->dest[2];
2540 s->bdsp.clear_blocks(s->block[0]);
2541 mb_pos = s->mb_x + s->mb_y * s->mb_width;
2542 s->current_picture.mb_type[mb_pos] = MB_TYPE_INTRA;
2543 s->current_picture.qscale_table[mb_pos] = v->pq;
2544 s->current_picture.motion_val[1][s->block_index[0]][0] = 0;
2545 s->current_picture.motion_val[1][s->block_index[0]][1] = 0;
2546
2547 // do actual MB decoding and displaying
2548 cbp = get_vlc2(&v->s.gb, ff_msmp4_mb_i_vlc.table, MB_INTRA_VLC_BITS, 2);
2549 v->s.ac_pred = get_bits1(&v->s.gb);
2550
2551 for (k = 0; k < 6; k++) {
2552 val = ((cbp >> (5 - k)) & 1);
2553
2554 if (k < 4) {
2555 int pred = vc1_coded_block_pred(&v->s, k, &coded_val);
2556 val = val ^ pred;
2557 *coded_val = val;
2558 }
2559 cbp |= val << (5 - k);
2560
2561 vc1_decode_i_block(v, s->block[k], k, val, (k < 4) ? v->codingset : v->codingset2);
2562
2563 if (CONFIG_GRAY && k > 3 && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
2564 continue;
2565 v->vc1dsp.vc1_inv_trans_8x8(s->block[k]);
2566 if (v->pq >= 9 && v->overlap) {
2567 if (v->rangeredfrm)
2568 for (j = 0; j < 64; j++)
2569 s->block[k][j] <<= 1;
2570 s->idsp.put_signed_pixels_clamped(s->block[k], dst[k],
2571 k & 4 ? s->uvlinesize
2572 : s->linesize);
2573 } else {
2574 if (v->rangeredfrm)
2575 for (j = 0; j < 64; j++)
2576 s->block[k][j] = (s->block[k][j] - 64) << 1;
2577 s->idsp.put_pixels_clamped(s->block[k], dst[k],
2578 k & 4 ? s->uvlinesize
2579 : s->linesize);
2580 }
2581 }
2582
2583 if (v->pq >= 9 && v->overlap) {
2584 if (s->mb_x) {
2585 v->vc1dsp.vc1_h_overlap(s->dest[0], s->linesize);
2586 v->vc1dsp.vc1_h_overlap(s->dest[0] + 8 * s->linesize, s->linesize);
2587 if (!CONFIG_GRAY || !(s->avctx->flags & AV_CODEC_FLAG_GRAY)) {
2588 v->vc1dsp.vc1_h_overlap(s->dest[1], s->uvlinesize);
2589 v->vc1dsp.vc1_h_overlap(s->dest[2], s->uvlinesize);
2590 }
2591 }
2592 v->vc1dsp.vc1_h_overlap(s->dest[0] + 8, s->linesize);
2593 v->vc1dsp.vc1_h_overlap(s->dest[0] + 8 * s->linesize + 8, s->linesize);
2594 if (!s->first_slice_line) {
2595 v->vc1dsp.vc1_v_overlap(s->dest[0], s->linesize);
2596 v->vc1dsp.vc1_v_overlap(s->dest[0] + 8, s->linesize);
2597 if (!CONFIG_GRAY || !(s->avctx->flags & AV_CODEC_FLAG_GRAY)) {
2598 v->vc1dsp.vc1_v_overlap(s->dest[1], s->uvlinesize);
2599 v->vc1dsp.vc1_v_overlap(s->dest[2], s->uvlinesize);
2600 }
2601 }
2602 v->vc1dsp.vc1_v_overlap(s->dest[0] + 8 * s->linesize, s->linesize);
2603 v->vc1dsp.vc1_v_overlap(s->dest[0] + 8 * s->linesize + 8, s->linesize);
2604 }
2605 if (v->s.loop_filter)
2606 ff_vc1_loop_filter_iblk(v, v->pq);
2607
2608 if (get_bits_count(&s->gb) > v->bits) {
2609 ff_er_add_slice(&s->er, 0, 0, s->mb_x, s->mb_y, ER_MB_ERROR);
2610 av_log(s->avctx, AV_LOG_ERROR, "Bits overconsumption: %i > %i\n",
2611 get_bits_count(&s->gb), v->bits);
2612 return;
2613 }
2614 }
2615 if (!v->s.loop_filter)
2616 ff_mpeg_draw_horiz_band(s, s->mb_y * 16, 16);
2617 else if (s->mb_y)
2618 ff_mpeg_draw_horiz_band(s, (s->mb_y - 1) * 16, 16);
2619
2620 s->first_slice_line = 0;
2621 }
2622 if (v->s.loop_filter)
2623 ff_mpeg_draw_horiz_band(s, (s->end_mb_y - 1) * 16, 16);
2624
2625 /* This is intentionally mb_height and not end_mb_y - unlike in advanced
2626 * profile, these only differ are when decoding MSS2 rectangles. */
2627 ff_er_add_slice(&s->er, 0, 0, s->mb_width - 1, s->mb_height - 1, ER_MB_END);
2628}
2629
2630/** Decode blocks of I-frame for advanced profile
2631 */
2632static void vc1_decode_i_blocks_adv(VC1Context *v)
2633{
2634 int k;
2635 MpegEncContext *s = &v->s;
2636 int cbp, val;
2637 uint8_t *coded_val;
2638 int mb_pos;
2639 int mquant = v->pq;
2640 int mqdiff;
2641 GetBitContext *gb = &s->gb;
2642
2643 /* select coding mode used for VLC tables selection */
2644 switch (v->y_ac_table_index) {
2645 case 0:
2646 v->codingset = (v->pqindex <= 8) ? CS_HIGH_RATE_INTRA : CS_LOW_MOT_INTRA;
2647 break;
2648 case 1:
2649 v->codingset = CS_HIGH_MOT_INTRA;
2650 break;
2651 case 2:
2652 v->codingset = CS_MID_RATE_INTRA;
2653 break;
2654 }
2655
2656 switch (v->c_ac_table_index) {
2657 case 0:
2658 v->codingset2 = (v->pqindex <= 8) ? CS_HIGH_RATE_INTER : CS_LOW_MOT_INTER;
2659 break;
2660 case 1:
2661 v->codingset2 = CS_HIGH_MOT_INTER;
2662 break;
2663 case 2:
2664 v->codingset2 = CS_MID_RATE_INTER;
2665 break;
2666 }
2667
2668 // do frame decode
2669 s->mb_x = s->mb_y = 0;
2670 s->mb_intra = 1;
2671 s->first_slice_line = 1;
2672 s->mb_y = s->start_mb_y;
2673 if (s->start_mb_y) {
2674 s->mb_x = 0;
2675 init_block_index(v);
2676 memset(&s->coded_block[s->block_index[0] - s->b8_stride], 0,
2677 (1 + s->b8_stride) * sizeof(*s->coded_block));
2678 }
2679 for (; s->mb_y < s->end_mb_y; s->mb_y++) {
2680 s->mb_x = 0;
2681 init_block_index(v);
2682 for (;s->mb_x < s->mb_width; s->mb_x++) {
2683 int16_t (*block)[64] = v->block[v->cur_blk_idx];
2684 ff_update_block_index(s);
2685 s->bdsp.clear_blocks(block[0]);
2686 mb_pos = s->mb_x + s->mb_y * s->mb_stride;
2687 s->current_picture.mb_type[mb_pos + v->mb_off] = MB_TYPE_INTRA;
2688 s->current_picture.motion_val[1][s->block_index[0] + v->blocks_off][0] = 0;
2689 s->current_picture.motion_val[1][s->block_index[0] + v->blocks_off][1] = 0;
2690
2691 // do actual MB decoding and displaying
2692 if (v->fieldtx_is_raw)
2693 v->fieldtx_plane[mb_pos] = get_bits1(&v->s.gb);
2694 cbp = get_vlc2(&v->s.gb, ff_msmp4_mb_i_vlc.table, MB_INTRA_VLC_BITS, 2);
2695 if (v->acpred_is_raw)
2696 v->s.ac_pred = get_bits1(&v->s.gb);
2697 else
2698 v->s.ac_pred = v->acpred_plane[mb_pos];
2699
2700 if (v->condover == CONDOVER_SELECT && v->overflg_is_raw)
2701 v->over_flags_plane[mb_pos] = get_bits1(&v->s.gb);
2702
2703 GET_MQUANT();
2704
2705 s->current_picture.qscale_table[mb_pos] = mquant;
2706 /* Set DC scale - y and c use the same */
2707 s->y_dc_scale = s->y_dc_scale_table[mquant];
2708 s->c_dc_scale = s->c_dc_scale_table[mquant];
2709
2710 for (k = 0; k < 6; k++) {
2711 val = ((cbp >> (5 - k)) & 1);
2712
2713 if (k < 4) {
2714 int pred = vc1_coded_block_pred(&v->s, k, &coded_val);
2715 val = val ^ pred;
2716 *coded_val = val;
2717 }
2718 cbp |= val << (5 - k);
2719
2720 v->a_avail = !s->first_slice_line || (k == 2 || k == 3);
2721 v->c_avail = !!s->mb_x || (k == 1 || k == 3);
2722
2723 vc1_decode_i_block_adv(v, block[k], k, val,
2724 (k < 4) ? v->codingset : v->codingset2, mquant);
2725
2726 if (CONFIG_GRAY && k > 3 && (s->avctx->flags & AV_CODEC_FLAG_GRAY))
2727 continue;
2728 v->vc1dsp.vc1_inv_trans_8x8(block[k]);
2729 }
2730
2731 ff_vc1_smooth_overlap_filter_iblk(v);
2732 vc1_put_signed_blocks_clamped(v);
2733 if (v->s.loop_filter)
2734 ff_vc1_loop_filter_iblk_delayed(v, v->pq);
2735
2736 if (get_bits_count(&s->gb) > v->bits) {
2737 // TODO: may need modification to handle slice coding
2738 ff_er_add_slice(&s->er, 0, s->start_mb_y, s->mb_x, s->mb_y, ER_MB_ERROR);
2739 av_log(s->avctx, AV_LOG_ERROR, "Bits overconsumption: %i > %i\n",
2740 get_bits_count(&s->gb), v->bits);
2741 return;
2742 }
2743 }
2744 if (!v->s.loop_filter)
2745 ff_mpeg_draw_horiz_band(s, s->mb_y * 16, 16);
2746 else if (s->mb_y)
2747 ff_mpeg_draw_horiz_band(s, (s->mb_y-1) * 16, 16);
2748 s->first_slice_line = 0;
2749 }
2750
2751 /* raw bottom MB row */
2752 s->mb_x = 0;
2753 init_block_index(v);
2754 for (; s->mb_x < s->mb_width; s->mb_x++) {
2755 ff_update_block_index(s);
2756 vc1_put_signed_blocks_clamped(v);
2757 if (v->s.loop_filter)
2758 ff_vc1_loop_filter_iblk_delayed(v, v->pq);
2759 }
2760 if (v->s.loop_filter)
2761 ff_mpeg_draw_horiz_band(s, (s->end_mb_y - 1) * 16, 16);
2762 ff_er_add_slice(&s->er, 0, s->start_mb_y << v->field_mode, s->mb_width - 1,
2763 (s->end_mb_y << v->field_mode) - 1, ER_MB_END);
2764}
2765
2766static void vc1_decode_p_blocks(VC1Context *v)
2767{
2768 MpegEncContext *s = &v->s;
2769 int apply_loop_filter;
2770
2771 /* select coding mode used for VLC tables selection */
2772 switch (v->c_ac_table_index) {
2773 case 0:
2774 v->codingset = (v->pqindex <= 8) ? CS_HIGH_RATE_INTRA : CS_LOW_MOT_INTRA;
2775 break;
2776 case 1:
2777 v->codingset = CS_HIGH_MOT_INTRA;
2778 break;
2779 case 2:
2780 v->codingset = CS_MID_RATE_INTRA;
2781 break;
2782 }
2783
2784 switch (v->c_ac_table_index) {
2785 case 0:
2786 v->codingset2 = (v->pqindex <= 8) ? CS_HIGH_RATE_INTER : CS_LOW_MOT_INTER;
2787 break;
2788 case 1:
2789 v->codingset2 = CS_HIGH_MOT_INTER;
2790 break;
2791 case 2:
2792 v->codingset2 = CS_MID_RATE_INTER;
2793 break;
2794 }
2795
2796 apply_loop_filter = s->loop_filter && !(s->avctx->skip_loop_filter >= AVDISCARD_NONKEY) &&
2797 v->fcm == PROGRESSIVE;
2798 s->first_slice_line = 1;
2799 memset(v->cbp_base, 0, sizeof(v->cbp_base[0])*2*s->mb_stride);
2800 for (s->mb_y = s->start_mb_y; s->mb_y < s->end_mb_y; s->mb_y++) {
2801 s->mb_x = 0;
2802 init_block_index(v);
2803 for (; s->mb_x < s->mb_width; s->mb_x++) {
2804 ff_update_block_index(s);
2805
2806 if (v->fcm == ILACE_FIELD)
2807 vc1_decode_p_mb_intfi(v);
2808 else if (v->fcm == ILACE_FRAME)
2809 vc1_decode_p_mb_intfr(v);
2810 else vc1_decode_p_mb(v);
2811 if (s->mb_y != s->start_mb_y && apply_loop_filter)
2812 ff_vc1_apply_p_loop_filter(v);
2813 if (get_bits_count(&s->gb) > v->bits || get_bits_count(&s->gb) < 0) {
2814 // TODO: may need modification to handle slice coding
2815 ff_er_add_slice(&s->er, 0, s->start_mb_y, s->mb_x, s->mb_y, ER_MB_ERROR);
2816 av_log(s->avctx, AV_LOG_ERROR, "Bits overconsumption: %i > %i at %ix%i\n",
2817 get_bits_count(&s->gb), v->bits, s->mb_x, s->mb_y);
2818 return;
2819 }
2820 }
2821 memmove(v->cbp_base, v->cbp, sizeof(v->cbp_base[0]) * s->mb_stride);
2822 memmove(v->ttblk_base, v->ttblk, sizeof(v->ttblk_base[0]) * s->mb_stride);
2823 memmove(v->is_intra_base, v->is_intra, sizeof(v->is_intra_base[0]) * s->mb_stride);
2824 memmove(v->luma_mv_base, v->luma_mv, sizeof(v->luma_mv_base[0]) * s->mb_stride);
2825 if (s->mb_y != s->start_mb_y)
2826 ff_mpeg_draw_horiz_band(s, (s->mb_y - 1) * 16, 16);
2827 s->first_slice_line = 0;
2828 }
2829 if (apply_loop_filter) {
2830 s->mb_x = 0;
2831 init_block_index(v);
2832 for (; s->mb_x < s->mb_width; s->mb_x++) {
2833 ff_update_block_index(s);
2834 ff_vc1_apply_p_loop_filter(v);
2835 }
2836 }
2837 if (s->end_mb_y >= s->start_mb_y)
2838 ff_mpeg_draw_horiz_band(s, (s->end_mb_y - 1) * 16, 16);
2839 ff_er_add_slice(&s->er, 0, s->start_mb_y << v->field_mode, s->mb_width - 1,
2840 (s->end_mb_y << v->field_mode) - 1, ER_MB_END);
2841}
2842
2843static void vc1_decode_b_blocks(VC1Context *v)
2844{
2845 MpegEncContext *s = &v->s;
2846
2847 /* select coding mode used for VLC tables selection */
2848 switch (v->c_ac_table_index) {
2849 case 0:
2850 v->codingset = (v->pqindex <= 8) ? CS_HIGH_RATE_INTRA : CS_LOW_MOT_INTRA;
2851 break;
2852 case 1:
2853 v->codingset = CS_HIGH_MOT_INTRA;
2854 break;
2855 case 2:
2856 v->codingset = CS_MID_RATE_INTRA;
2857 break;
2858 }
2859
2860 switch (v->c_ac_table_index) {
2861 case 0:
2862 v->codingset2 = (v->pqindex <= 8) ? CS_HIGH_RATE_INTER : CS_LOW_MOT_INTER;
2863 break;
2864 case 1:
2865 v->codingset2 = CS_HIGH_MOT_INTER;
2866 break;
2867 case 2:
2868 v->codingset2 = CS_MID_RATE_INTER;
2869 break;
2870 }
2871
2872 s->first_slice_line = 1;
2873 for (s->mb_y = s->start_mb_y; s->mb_y < s->end_mb_y; s->mb_y++) {
2874 s->mb_x = 0;
2875 init_block_index(v);
2876 for (; s->mb_x < s->mb_width; s->mb_x++) {
2877 ff_update_block_index(s);
2878
2879 if (v->fcm == ILACE_FIELD)
2880 vc1_decode_b_mb_intfi(v);
2881 else if (v->fcm == ILACE_FRAME)
2882 vc1_decode_b_mb_intfr(v);
2883 else
2884 vc1_decode_b_mb(v);
2885 if (get_bits_count(&s->gb) > v->bits || get_bits_count(&s->gb) < 0) {
2886 // TODO: may need modification to handle slice coding
2887 ff_er_add_slice(&s->er, 0, s->start_mb_y, s->mb_x, s->mb_y, ER_MB_ERROR);
2888 av_log(s->avctx, AV_LOG_ERROR, "Bits overconsumption: %i > %i at %ix%i\n",
2889 get_bits_count(&s->gb), v->bits, s->mb_x, s->mb_y);
2890 return;
2891 }
2892 if (v->s.loop_filter)
2893 ff_vc1_loop_filter_iblk(v, v->pq);
2894 }
2895 if (!v->s.loop_filter)
2896 ff_mpeg_draw_horiz_band(s, s->mb_y * 16, 16);
2897 else if (s->mb_y)
2898 ff_mpeg_draw_horiz_band(s, (s->mb_y - 1) * 16, 16);
2899 s->first_slice_line = 0;
2900 }
2901 if (v->s.loop_filter)
2902 ff_mpeg_draw_horiz_band(s, (s->end_mb_y - 1) * 16, 16);
2903 ff_er_add_slice(&s->er, 0, s->start_mb_y << v->field_mode, s->mb_width - 1,
2904 (s->end_mb_y << v->field_mode) - 1, ER_MB_END);
2905}
2906
2907static void vc1_decode_skip_blocks(VC1Context *v)
2908{
2909 MpegEncContext *s = &v->s;
2910
2911 if (!v->s.last_picture.f->data[0])
2912 return;
2913
2914 ff_er_add_slice(&s->er, 0, s->start_mb_y, s->mb_width - 1, s->end_mb_y - 1, ER_MB_END);
2915 s->first_slice_line = 1;
2916 for (s->mb_y = s->start_mb_y; s->mb_y < s->end_mb_y; s->mb_y++) {
2917 s->mb_x = 0;
2918 init_block_index(v);
2919 ff_update_block_index(s);
2920 memcpy(s->dest[0], s->last_picture.f->data[0] + s->mb_y * 16 * s->linesize, s->linesize * 16);
2921 memcpy(s->dest[1], s->last_picture.f->data[1] + s->mb_y * 8 * s->uvlinesize, s->uvlinesize * 8);
2922 memcpy(s->dest[2], s->last_picture.f->data[2] + s->mb_y * 8 * s->uvlinesize, s->uvlinesize * 8);
2923 ff_mpeg_draw_horiz_band(s, s->mb_y * 16, 16);
2924 s->first_slice_line = 0;
2925 }
2926 s->pict_type = AV_PICTURE_TYPE_P;
2927}
2928
2929void ff_vc1_decode_blocks(VC1Context *v)
2930{
2931
2932 v->s.esc3_level_length = 0;
2933 if (v->x8_type) {
2934 ff_intrax8_decode_picture(&v->x8, &v->s.current_picture,
2935 &v->s.gb, &v->s.mb_x, &v->s.mb_y,
2936 2 * v->pq + v->halfpq, v->pq * !v->pquantizer,
2937 v->s.loop_filter, v->s.low_delay);
2938
2939 ff_er_add_slice(&v->s.er, 0, 0,
2940 (v->s.mb_x >> 1) - 1, (v->s.mb_y >> 1) - 1,
2941 ER_MB_END);
2942 } else {
2943 v->cur_blk_idx = 0;
2944 v->left_blk_idx = -1;
2945 v->topleft_blk_idx = 1;
2946 v->top_blk_idx = 2;
2947 switch (v->s.pict_type) {
2948 case AV_PICTURE_TYPE_I:
2949 if (v->profile == PROFILE_ADVANCED)
2950 vc1_decode_i_blocks_adv(v);
2951 else
2952 vc1_decode_i_blocks(v);
2953 break;
2954 case AV_PICTURE_TYPE_P:
2955 if (v->p_frame_skipped)
2956 vc1_decode_skip_blocks(v);
2957 else
2958 vc1_decode_p_blocks(v);
2959 break;
2960 case AV_PICTURE_TYPE_B:
2961 if (v->bi_type) {
2962 if (v->profile == PROFILE_ADVANCED)
2963 vc1_decode_i_blocks_adv(v);
2964 else
2965 vc1_decode_i_blocks(v);
2966 } else
2967 vc1_decode_b_blocks(v);
2968 break;
2969 }
2970 }
2971}
2972