42 { 0, 1, 2, 4, 8, 16, 32, 64, 128 },
43 { 0, 1, 3, 7, 15, 31, 63, 127, 255 },
62 s->dest[0] +=
s->cur_pic.ptr->f->linesize[0];
63 s->dest[1] +=
s->cur_pic.ptr->f->linesize[1];
64 s->dest[2] +=
s->cur_pic.ptr->f->linesize[2];
92 for (
i = 0;
i < block_count;
i++) {
93 if (
i > 3 ? v->
mb_type[
s->block_index[
i] -
s->block_wrap[
i] - 1] :
94 v->
mb_type[
s->block_index[
i] - 2 *
s->block_wrap[
i] - 2]) {
95 dest =
s->dest[0] + ((
i & 2) - 4) * 4 *
s->linesize + ((
i & 1) - 2) * 8;
98 i > 3 ?
s->dest[
i - 3] - 8 *
s->uvlinesize - 8 : dest,
99 i > 3 ?
s->uvlinesize :
s->linesize);
102 i > 3 ?
s->dest[
i - 3] - 8 *
s->uvlinesize - 8 : dest,
103 i > 3 ?
s->uvlinesize :
s->linesize);
108 for (
i = 0;
i < block_count;
i++) {
109 if (
i > 3 ? v->
mb_type[
s->block_index[
i] -
s->block_wrap[
i]] :
110 v->
mb_type[
s->block_index[
i] - 2 *
s->block_wrap[
i]]) {
111 dest =
s->dest[0] + ((
i & 2) - 4) * 4 *
s->linesize + (
i & 1) * 8;
114 i > 3 ?
s->dest[
i - 3] - 8 *
s->uvlinesize : dest,
115 i > 3 ?
s->uvlinesize :
s->linesize);
118 i > 3 ?
s->dest[
i - 3] - 8 *
s->uvlinesize : dest,
119 i > 3 ?
s->uvlinesize :
s->linesize);
128 for (
i = 0;
i < block_count;
i++) {
129 if (
i > 3 ? v->
mb_type[
s->block_index[
i] - 1] :
132 dest =
s->dest[0] + ((
i & 2) >> 1) *
s->linesize + ((
i & 1) - 2) * 8;
134 dest =
s->dest[0] + (
i & 2) * 4 *
s->linesize + ((
i & 1) - 2) * 8;
137 i > 3 ?
s->dest[
i - 3] - 8 : dest,
138 i > 3 ?
s->uvlinesize :
s->linesize << fieldtx);
141 i > 3 ?
s->dest[
i - 3] - 8 : dest,
142 i > 3 ?
s->uvlinesize :
s->linesize << fieldtx);
149 for (
i = 0;
i < block_count;
i++) {
152 dest =
s->dest[0] + ((
i & 2) >> 1) *
s->linesize + (
i & 1) * 8;
154 dest =
s->dest[0] + (
i & 2) * 4 *
s->linesize + (
i & 1) * 8;
157 i > 3 ?
s->dest[
i - 3] : dest,
158 i > 3 ?
s->uvlinesize :
s->linesize << fieldtx);
161 i > 3 ?
s->dest[
i - 3] : dest,
162 i > 3 ?
s->uvlinesize :
s->linesize << fieldtx);
169 #define inc_blk_idx(idx) do { \
171 if (idx >= v->n_allocated_blks) \
186 #define GET_MQUANT() \
187 if (v->dquantfrm) { \
189 if (v->dqprofile == DQPROFILE_ALL_MBS) { \
190 if (v->dqbilevel) { \
191 mquant = (get_bits1(gb)) ? -v->altpq : v->pq; \
193 mqdiff = get_bits(gb, 3); \
195 mquant = -v->pq - mqdiff; \
197 mquant = -get_bits(gb, 5); \
200 if (v->dqprofile == DQPROFILE_SINGLE_EDGE) \
201 edges = 1 << v->dqsbedge; \
202 else if (v->dqprofile == DQPROFILE_DOUBLE_EDGES) \
203 edges = (3 << v->dqsbedge) % 15; \
204 else if (v->dqprofile == DQPROFILE_FOUR_EDGES) \
206 if ((edges&1) && !s->mb_x) \
207 mquant = -v->altpq; \
208 if ((edges&2) && !s->mb_y) \
209 mquant = -v->altpq; \
210 if ((edges&4) && s->mb_x == (s->mb_width - 1)) \
211 mquant = -v->altpq; \
213 s->mb_y == ((s->mb_height >> v->field_mode) - 1)) \
214 mquant = -v->altpq; \
215 if (!mquant || mquant > 31 || mquant < -31) { \
216 av_log(v->s.avctx, AV_LOG_ERROR, \
217 "Overriding invalid mquant %d\n", mquant); \
229 #define GET_MVDATA(_dmv_x, _dmv_y) \
230 index = 1 + get_vlc2(gb, ff_vc1_mv_diff_vlc[v->mv_table_index], \
231 VC1_MV_DIFF_VLC_BITS, 2); \
239 _dmv_x = _dmv_y = 0; \
240 } else if (index == 35) { \
241 _dmv_x = get_bits(gb, v->k_x - 1 + s->quarter_sample); \
242 _dmv_y = get_bits(gb, v->k_y - 1 + s->quarter_sample); \
243 } else if (index == 36) { \
248 index1 = index % 6; \
249 _dmv_x = offset_table[1][index1]; \
250 val = size_table[index1] - (!s->quarter_sample && index1 == 5); \
252 val = get_bits(gb, val); \
253 sign = 0 - (val & 1); \
254 _dmv_x = (sign ^ ((val >> 1) + _dmv_x)) - sign; \
257 index1 = index / 6; \
258 _dmv_y = offset_table[1][index1]; \
259 val = size_table[index1] - (!s->quarter_sample && index1 == 5); \
261 val = get_bits(gb, val); \
262 sign = 0 - (val & 1); \
263 _dmv_y = (sign ^ ((val >> 1) + _dmv_y)) - sign; \
268 int *dmv_y,
int *pred_flag)
271 int extend_x, extend_y;
291 *pred_flag = *dmv_y & 1;
292 *dmv_y = (*dmv_y + (*dmv_y & 1)) >> 1;
297 index1 = (
index + 1) % 9;
300 sign = 0 - (
val & 1);
301 *dmv_x = (sign ^ ((
val >> 1) +
offset_table[extend_x][index1])) - sign;
304 index1 = (
index + 1) / 9;
307 sign = 0 - (
val & 1);
311 if (v->
numref && pred_flag)
312 *pred_flag = index1 & 1;
319 int direct,
int mode)
345 int16_t **dc_val_ptr,
int *dir_ptr)
349 static const uint16_t dcpred[32] = {
350 -1, 1024, 512, 341, 256, 205, 171, 146, 128,
351 114, 102, 93, 85, 79, 73, 68, 64,
352 60, 57, 54, 51, 49, 47, 45, 43,
353 41, 39, 38, 37, 35, 34, 33
359 wrap =
s->block_wrap[n];
360 dc_val =
s->dc_val +
s->block_index[n];
366 b = dc_val[ - 1 -
wrap];
369 if (pq < 9 || !overlap) {
371 if (
s->first_slice_line && (n != 2 && n != 3))
373 if (
s->mb_x == 0 && (n != 1 && n != 3))
377 if (
s->first_slice_line && (n != 2 && n != 3))
379 if (
s->mb_x == 0 && (n != 1 && n != 3))
392 *dc_val_ptr = &dc_val[0];
409 int a_avail,
int c_avail,
410 int16_t **dc_val_ptr,
int *dir_ptr)
414 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
419 q1 =
FFABS(
s->cur_pic.qscale_table[mb_pos]);
421 if (dqscale_index < 0)
424 wrap =
s->block_wrap[n];
425 dc_val =
s->dc_val +
s->block_index[n];
431 b = dc_val[ - 1 -
wrap];
434 if (c_avail && (n != 1 && n != 3)) {
435 q2 =
FFABS(
s->cur_pic.qscale_table[mb_pos - 1]);
439 if (a_avail && (n != 2 && n != 3)) {
440 q2 =
FFABS(
s->cur_pic.qscale_table[mb_pos -
s->mb_stride]);
444 if (a_avail && c_avail && (n != 3)) {
450 q2 =
FFABS(
s->cur_pic.qscale_table[off]);
455 if (c_avail && (!a_avail ||
abs(
a -
b) <=
abs(
b -
c))) {
458 }
else if (a_avail) {
467 *dc_val_ptr = &dc_val[0];
483 xy =
s->block_index[n];
489 a =
s->coded_block[xy - 1 ];
490 b =
s->coded_block[xy - 1 -
wrap];
491 c =
s->coded_block[xy -
wrap];
515 int *
value,
int codingset)
582 int coded,
int codingset)
588 int16_t *ac_val, *ac_val2;
595 const int m = (v->
pq == 1 || v->
pq == 2) ? 3 - v->
pq : 0;
596 if (dcdiff == 119 ) {
600 dcdiff = (dcdiff << m) +
get_bits(gb, m) - ((1 << m) - 1);
611 block[0] = dcdiff *
s->y_dc_scale;
613 ac_val =
s->ac_val[
s->block_index[n]];
618 ac_val -= 16 *
s->block_wrap[n];
626 const uint8_t *zz_table;
637 for (
int i = 1; !last; ++
i) {
656 for (k = 1; k < 8; k++)
657 block[k << sh] += ac_val[k];
660 for (k = 1; k < 8; k++) {
666 for (k = 1; k < 64; k++)
676 memset(ac_val2, 0, 16 * 2);
688 memcpy(ac_val2, ac_val, 8 * 2);
689 for (k = 1; k < 8; k++) {
709 int coded,
int codingset,
int mquant)
714 int16_t *dc_val =
NULL;
715 int16_t *ac_val, *ac_val2;
718 int use_pred =
s->ac_pred;
721 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
729 if (dcdiff == 119 ) {
733 dcdiff = (dcdiff << m) +
get_bits(gb, m) - ((1 << m) - 1);
744 block[0] = dcdiff *
s->y_dc_scale;
747 if (!a_avail && !c_avail)
752 ac_val =
s->ac_val[
s->block_index[n]];
757 ac_val -= 16 *
s->block_wrap[n];
759 q1 =
s->cur_pic.qscale_table[mb_pos];
762 else if (dc_pred_dir) {
765 else if (c_avail && mb_pos)
766 q2 =
s->cur_pic.qscale_table[mb_pos - 1];
770 else if (a_avail && mb_pos >=
s->mb_stride)
771 q2 =
s->cur_pic.qscale_table[mb_pos -
s->mb_stride];
778 const uint8_t *zz_table;
797 for (
int i = 1; !last; ++
i) {
821 q2 =
FFABS(q2) * 2 + ((q2 < 0) ? 0 : v->
halfpq) - 1;
822 if (q2 &&
q1 != q2) {
823 for (k = 1; k < 8; k++)
826 for (k = 1; k < 8; k++)
827 block[k << sh] += ac_val[k];
831 for (k = 1; k < 8; k++) {
837 for (k = 1; k < 64; k++)
847 memset(ac_val2, 0, 16 * 2);
859 memcpy(ac_val2, ac_val, 8 * 2);
864 q2 =
FFABS(q2) * 2 + ((q2 < 0) ? 0 : v->
halfpq) - 1;
865 if (q2 &&
q1 != q2) {
866 for (k = 1; k < 8; k++)
867 ac_val2[k] = (
int)(ac_val2[k] * q2 * (unsigned)
ff_vc1_dqscale[
q1 - 1] + 0x20000) >> 18;
869 for (k = 1; k < 8; k++) {
889 int coded,
int mquant,
int codingset)
894 int16_t *dc_val =
NULL;
895 int16_t *ac_val, *ac_val2;
897 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
899 int use_pred =
s->ac_pred;
904 s->bdsp.clear_block(
block);
917 if (dcdiff == 119 ) {
921 dcdiff = (dcdiff << m) +
get_bits(gb, m) - ((1 << m) - 1);
932 block[0] = dcdiff *
s->y_dc_scale;
937 if (!a_avail) dc_pred_dir = 1;
938 if (!c_avail) dc_pred_dir = 0;
939 if (!a_avail && !c_avail) use_pred = 0;
940 ac_val =
s->ac_val[
s->block_index[n]];
948 ac_val -= 16 *
s->block_wrap[n];
950 q1 =
s->cur_pic.qscale_table[mb_pos];
951 if (dc_pred_dir && c_avail && mb_pos)
952 q2 =
s->cur_pic.qscale_table[mb_pos - 1];
953 if (!dc_pred_dir && a_avail && mb_pos >=
s->mb_stride)
954 q2 =
s->cur_pic.qscale_table[mb_pos -
s->mb_stride];
955 if (dc_pred_dir && n == 1)
957 if (!dc_pred_dir && n == 2)
965 for (
int i = 1; !last; ++
i) {
993 q2 =
FFABS(q2) * 2 + ((q2 < 0) ? 0 : v->
halfpq) - 1;
994 if (q2 &&
q1 != q2) {
996 for (k = 1; k < 8; k++)
999 for (k = 1; k < 8; k++)
1004 for (k = 1; k < 8; k++)
1007 for (k = 1; k < 8; k++)
1013 for (k = 1; k < 8; k++) {
1019 for (k = 1; k < 64; k++)
1028 memset(ac_val2, 0, 16 * 2);
1031 memcpy(ac_val2, ac_val, 8 * 2);
1036 q2 =
FFABS(q2) * 2 + ((q2 < 0) ? 0 : v->
halfpq) - 1;
1037 if (q2 &&
q1 != q2) {
1038 for (k = 1; k < 8; k++)
1039 ac_val2[k] = (
int)(ac_val2[k] * (unsigned)q2 *
ff_vc1_dqscale[
q1 - 1] + 0x20000) >> 18;
1044 memcpy(ac_val2 + 8, ac_val + 8, 8 * 2);
1049 q2 =
FFABS(q2) * 2 + ((q2 < 0) ? 0 : v->
halfpq) - 1;
1050 if (q2 &&
q1 != q2) {
1051 for (k = 1; k < 8; k++)
1052 ac_val2[k + 8] = (
int)(ac_val2[k + 8] * (unsigned)q2 *
ff_vc1_dqscale[
q1 - 1] + 0x20000) >> 18;
1060 for (k = 1; k < 8; k++) {
1066 for (k = 1; k < 8; k++) {
1081 int mquant,
int ttmb,
int first_block,
1082 uint8_t *
dst,
int linesize,
int skip_block,
1090 int ttblk = ttmb & 7;
1094 s->bdsp.clear_block(
block);
1103 && ((v->
ttmbf || (ttmb != -1 && (ttmb & 8) && !first_block))
1149 s->idsp.add_pixels_clamped(
block,
dst, linesize);
1154 pat = ~subblkpat & 0xF;
1155 for (j = 0; j < 4; j++) {
1156 last = subblkpat & (1 << (3 - j));
1158 off = (j & 1) * 4 + (j & 2) * 16;
1174 if (!(subblkpat & (1 << (3 - j))) && !skip_block) {
1183 pat = ~((subblkpat & 2) * 6 + (subblkpat & 1) * 3) & 0xF;
1184 for (j = 0; j < 2; j++) {
1185 last = subblkpat & (1 << (1 - j));
1203 if (!(subblkpat & (1 << (1 - j))) && !skip_block) {
1212 pat = ~(subblkpat * 5) & 0xF;
1213 for (j = 0; j < 2; j++) {
1214 last = subblkpat & (1 << (1 - j));
1232 if (!(subblkpat & (1 << (1 - j))) && !skip_block) {
1242 *ttmb_out |= ttblk << (n * 4);
1257 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
1260 int ttmb = v->
ttfrm;
1262 int mb_has_coeffs = 1;
1266 int first_block = 1;
1268 int skipped, fourmv;
1269 int block_cbp = 0, pat, block_tt = 0, block_intra = 0;
1288 s->cur_pic.motion_val[1][
s->block_index[0]][0] = 0;
1289 s->cur_pic.motion_val[1][
s->block_index[0]][1] = 0;
1295 if (
s->mb_intra && !mb_has_coeffs) {
1299 }
else if (mb_has_coeffs) {
1308 s->cur_pic.qscale_table[mb_pos] = mquant;
1310 if (!v->
ttmbf && !
s->mb_intra && mb_has_coeffs)
1315 for (
i = 0;
i < 6;
i++) {
1316 s->dc_val[
s->block_index[
i]] = 0;
1318 val = ((cbp >> (5 -
i)) & 1);
1319 off = (
i & 4) ? 0 : ((
i & 1) * 8 + (
i & 2) * 4 *
s->linesize);
1324 if (
i == 2 ||
i == 3 || !
s->first_slice_line)
1326 if (
i == 1 ||
i == 3 ||
s->mb_x)
1337 for (j = 0; j < 64; j++)
1339 block_cbp |= 0xF << (
i << 2);
1340 block_intra |= 1 <<
i;
1343 s->dest[dst_idx] + off, (
i & 4) ?
s->uvlinesize :
s->linesize,
1347 block_cbp |= pat << (
i << 2);
1348 if (!v->
ttmbf && ttmb < 8)
1355 for (
i = 0;
i < 6;
i++) {
1357 s->dc_val[
s->block_index[
i]] = 0;
1360 s->cur_pic.qscale_table[mb_pos] = 0;
1366 int intra_count = 0, coded_inter = 0;
1367 int is_intra[6], is_coded[6];
1370 for (
i = 0;
i < 6;
i++) {
1371 val = ((cbp >> (5 -
i)) & 1);
1372 s->dc_val[
s->block_index[
i]] = 0;
1384 intra_count +=
s->mb_intra;
1385 is_intra[
i] =
s->mb_intra;
1386 is_coded[
i] = mb_has_coeffs;
1389 is_intra[
i] = (intra_count >= 3);
1396 coded_inter = !is_intra[
i] & is_coded[
i];
1400 if (!intra_count && !coded_inter)
1403 s->cur_pic.qscale_table[mb_pos] = mquant;
1407 for (
i = 0;
i < 6;
i++)
1409 if (((!
s->first_slice_line || (
i == 2 ||
i == 3)) && v->
mb_type[
s->block_index[
i] -
s->block_wrap[
i]])
1410 || ((
s->mb_x || (
i == 1 ||
i == 3)) && v->
mb_type[
s->block_index[
i] - 1])) {
1420 if (!v->
ttmbf && coded_inter)
1422 for (
i = 0;
i < 6;
i++) {
1424 off = (
i & 4) ? 0 : ((
i & 1) * 8 + (
i & 2) * 4 *
s->linesize);
1425 s->mb_intra = is_intra[
i];
1429 if (
i == 2 ||
i == 3 || !
s->first_slice_line)
1431 if (
i == 1 ||
i == 3 ||
s->mb_x)
1442 for (j = 0; j < 64; j++)
1444 block_cbp |= 0xF << (
i << 2);
1445 block_intra |= 1 <<
i;
1446 }
else if (is_coded[
i]) {
1448 first_block,
s->dest[dst_idx] + off,
1449 (
i & 4) ?
s->uvlinesize :
s->linesize,
1454 block_cbp |= pat << (
i << 2);
1455 if (!v->
ttmbf && ttmb < 8)
1462 s->cur_pic.qscale_table[mb_pos] = 0;
1463 for (
i = 0;
i < 6;
i++) {
1465 s->dc_val[
s->block_index[
i]] = 0;
1467 for (
i = 0;
i < 4;
i++) {
1472 s->cur_pic.qscale_table[mb_pos] = 0;
1480 v->
cbp[
s->mb_x] = block_cbp;
1481 v->
ttblk[
s->mb_x] = block_tt;
1494 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
1497 int ttmb = v->
ttfrm;
1499 int mb_has_coeffs = 1;
1502 int first_block = 1;
1504 int skipped, fourmv = 0, twomv = 0;
1505 int block_cbp = 0, pat, block_tt = 0;
1506 int idx_mbmode = 0, mvbp;
1552 for (
i = 0;
i < 4;
i++) {
1553 s->cur_pic.motion_val[1][
s->block_index[
i]][0] = 0;
1554 s->cur_pic.motion_val[1][
s->block_index[
i]][1] = 0;
1565 s->cur_pic.qscale_table[mb_pos] = mquant;
1569 for (
i = 0;
i < 6;
i++) {
1572 s->dc_val[
s->block_index[
i]] = 0;
1574 val = ((cbp >> (5 -
i)) & 1);
1575 if (
i == 2 ||
i == 3 || !
s->first_slice_line)
1577 if (
i == 1 ||
i == 3 ||
s->mb_x)
1587 block_cbp |= 0xf << (
i << 2);
1603 for (
i = 0;
i < 6;
i++)
1610 for (
i = 0;
i < 4;
i++) {
1612 if (mvbp & (8 >>
i))
1646 s->cur_pic.qscale_table[mb_pos] = mquant;
1647 if (!v->
ttmbf && cbp)
1649 for (
i = 0;
i < 6;
i++) {
1650 s->dc_val[
s->block_index[
i]] = 0;
1652 val = ((cbp >> (5 -
i)) & 1);
1654 off = (
i & 4) ? 0 : ((
i & 1) * 8 + (
i & 2) * 4 *
s->linesize);
1656 off = (
i & 4) ? 0 : ((
i & 1) * 8 + ((
i > 1) *
s->linesize));
1659 first_block,
s->dest[dst_idx] + off,
1660 (
i & 4) ?
s->uvlinesize : (
s->linesize << fieldtx),
1664 block_cbp |= pat << (
i << 2);
1665 if (!v->
ttmbf && ttmb < 8)
1673 for (
i = 0;
i < 6;
i++) {
1675 s->dc_val[
s->block_index[
i]] = 0;
1678 s->cur_pic.qscale_table[mb_pos] = 0;
1691 v->
cbp[
s->mb_x] = block_cbp;
1692 v->
ttblk[
s->mb_x] = block_tt;
1702 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
1705 int ttmb = v->
ttfrm;
1707 int mb_has_coeffs = 1;
1710 int first_block = 1;
1713 int block_cbp = 0, pat, block_tt = 0;
1720 if (idx_mbmode <= 1) {
1723 s->cur_pic.motion_val[1][
s->block_index[0] + v->
blocks_off][0] = 0;
1724 s->cur_pic.motion_val[1][
s->block_index[0] + v->
blocks_off][1] = 0;
1727 s->cur_pic.qscale_table[mb_pos] = mquant;
1731 mb_has_coeffs = idx_mbmode & 1;
1735 for (
i = 0;
i < 6;
i++) {
1738 s->dc_val[
s->block_index[
i]] = 0;
1740 val = ((cbp >> (5 -
i)) & 1);
1741 if (
i == 2 ||
i == 3 || !
s->first_slice_line)
1743 if (
i == 1 ||
i == 3 ||
s->mb_x)
1753 block_cbp |= 0xf << (
i << 2);
1758 for (
i = 0;
i < 6;
i++)
1760 if (idx_mbmode <= 5) {
1761 dmv_x = dmv_y = pred_flag = 0;
1762 if (idx_mbmode & 1) {
1767 mb_has_coeffs = !(idx_mbmode & 2);
1770 for (
i = 0;
i < 4;
i++) {
1771 dmv_x = dmv_y = pred_flag = 0;
1778 mb_has_coeffs = idx_mbmode & 1;
1785 s->cur_pic.qscale_table[mb_pos] = mquant;
1786 if (!v->
ttmbf && cbp) {
1790 for (
i = 0;
i < 6;
i++) {
1791 s->dc_val[
s->block_index[
i]] = 0;
1793 val = ((cbp >> (5 -
i)) & 1);
1794 off = (
i & 4) ? 0 : (
i & 1) * 8 + (
i & 2) * 4 *
s->linesize;
1797 first_block,
s->dest[dst_idx] + off,
1798 (
i & 4) ?
s->uvlinesize :
s->linesize,
1803 block_cbp |= pat << (
i << 2);
1804 if (!v->
ttmbf && ttmb < 8)
1814 v->
cbp[
s->mb_x] = block_cbp;
1815 v->
ttblk[
s->mb_x] = block_tt;
1827 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
1830 int ttmb = v->
ttfrm;
1831 int mb_has_coeffs = 0;
1834 int first_block = 1;
1836 int skipped, direct;
1837 int dmv_x[2], dmv_y[2];
1853 dmv_x[0] = dmv_x[1] = dmv_y[0] = dmv_y[1] = 0;
1854 for (
i = 0;
i < 6;
i++) {
1856 s->dc_val[
s->block_index[
i]] = 0;
1858 s->cur_pic.qscale_table[mb_pos] = 0;
1863 dmv_x[1] = dmv_x[0];
1864 dmv_y[1] = dmv_y[0];
1866 if (skipped || !
s->mb_intra) {
1877 dmv_x[0] = dmv_y[0] = 0;
1881 for (
i = 0;
i < 6;
i++)
1888 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1895 s->cur_pic.qscale_table[mb_pos] = mquant;
1898 dmv_x[0] = dmv_y[0] = dmv_x[1] = dmv_y[1] = 0;
1900 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1902 if (!mb_has_coeffs && !
s->mb_intra) {
1905 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1908 if (
s->mb_intra && !mb_has_coeffs) {
1910 s->cur_pic.qscale_table[mb_pos] = mquant;
1917 if (!mb_has_coeffs) {
1920 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1926 vc1_b_mc(v, dmv_x, dmv_y, direct, bmvtype);
1932 s->cur_pic.qscale_table[mb_pos] = mquant;
1933 if (!v->
ttmbf && !
s->mb_intra && mb_has_coeffs)
1938 for (
i = 0;
i < 6;
i++) {
1939 s->dc_val[
s->block_index[
i]] = 0;
1941 val = ((cbp >> (5 -
i)) & 1);
1942 off = (
i & 4) ? 0 : ((
i & 1) * 8 + (
i & 2) * 4 *
s->linesize);
1947 if (
i == 2 ||
i == 3 || !
s->first_slice_line)
1949 if (
i == 1 ||
i == 3 ||
s->mb_x)
1960 for (j = 0; j < 64; j++)
1961 v->blocks[
i][j] *= 2;
1962 s->idsp.put_signed_pixels_clamped(v->blocks[
i],
1963 s->dest[dst_idx] + off,
1964 i & 4 ?
s->uvlinesize
1968 first_block,
s->dest[dst_idx] + off,
1969 (
i & 4) ?
s->uvlinesize :
s->linesize,
1973 if (!v->
ttmbf && ttmb < 8)
1988 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
1991 int ttmb = v->
ttfrm;
1992 int mb_has_coeffs = 0;
1994 int first_block = 1;
1997 int dmv_x[2], dmv_y[2], pred_flag[2];
1999 int block_cbp = 0, pat, block_tt = 0;
2007 if (idx_mbmode <= 1) {
2010 s->cur_pic.motion_val[1][
s->block_index[0]][0] = 0;
2011 s->cur_pic.motion_val[1][
s->block_index[0]][1] = 0;
2014 s->cur_pic.qscale_table[mb_pos] = mquant;
2018 mb_has_coeffs = idx_mbmode & 1;
2022 for (
i = 0;
i < 6;
i++) {
2025 s->dc_val[
s->block_index[
i]] = 0;
2027 val = ((cbp >> (5 -
i)) & 1);
2028 if (
i == 2 ||
i == 3 || !
s->first_slice_line)
2030 if (
i == 1 ||
i == 3 ||
s->mb_x)
2041 for (j = 0; j < 64; j++)
2042 v->blocks[
i][j] <<= 1;
2043 off = (
i & 4) ? 0 : ((
i & 1) * 8 + (
i & 2) * 4 *
s->linesize);
2044 s->idsp.put_signed_pixels_clamped(v->blocks[
i],
2045 s->dest[dst_idx] + off,
2046 (
i & 4) ?
s->uvlinesize
2052 for (
i = 0;
i < 6;
i++)
2058 if (idx_mbmode <= 5) {
2060 dmv_x[0] = dmv_x[1] = dmv_y[0] = dmv_y[1] = 0;
2061 pred_flag[0] = pred_flag[1] = 0;
2086 dmv_x[0] = dmv_y[0] = pred_flag[0] = 0;
2087 dmv_x[1] = dmv_y[1] = pred_flag[0] = 0;
2088 if (!
s->next_pic.ptr->field_picture) {
2095 mb_has_coeffs = !(idx_mbmode & 2);
2101 for (
i = 0;
i < 4;
i++) {
2102 dmv_x[0] = dmv_y[0] = pred_flag[0] = 0;
2103 dmv_x[1] = dmv_y[1] = pred_flag[1] = 0;
2113 mb_has_coeffs = idx_mbmode & 1;
2120 s->cur_pic.qscale_table[mb_pos] = mquant;
2121 if (!v->
ttmbf && cbp) {
2125 for (
i = 0;
i < 6;
i++) {
2126 s->dc_val[
s->block_index[
i]] = 0;
2128 val = ((cbp >> (5 -
i)) & 1);
2129 off = (
i & 4) ? 0 : (
i & 1) * 8 + (
i & 2) * 4 *
s->linesize;
2132 first_block,
s->dest[dst_idx] + off,
2133 (
i & 4) ?
s->uvlinesize :
s->linesize,
2137 block_cbp |= pat << (
i << 2);
2138 if (!v->
ttmbf && ttmb < 8)
2144 v->
cbp[
s->mb_x] = block_cbp;
2145 v->
ttblk[
s->mb_x] = block_tt;
2157 int mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
2160 int ttmb = v->
ttfrm;
2162 int mb_has_coeffs = 1;
2165 int first_block = 1;
2167 int skipped, direct, twomv = 0;
2168 int block_cbp = 0, pat, block_tt = 0;
2169 int idx_mbmode = 0, mvbp;
2170 int stride_y, fieldtx;
2199 for (
i = 0;
i < 4;
i++) {
2200 s->mv[0][
i][0] =
s->cur_pic.motion_val[0][
s->block_index[
i]][0] = 0;
2201 s->mv[0][
i][1] =
s->cur_pic.motion_val[0][
s->block_index[
i]][1] = 0;
2202 s->mv[1][
i][0] =
s->cur_pic.motion_val[1][
s->block_index[
i]][0] = 0;
2203 s->mv[1][
i][1] =
s->cur_pic.motion_val[1][
s->block_index[
i]][1] = 0;
2214 s->cur_pic.qscale_table[mb_pos] = mquant;
2218 for (
i = 0;
i < 6;
i++) {
2221 s->dc_val[
s->block_index[
i]] = 0;
2223 val = ((cbp >> (5 -
i)) & 1);
2224 if (
i == 2 ||
i == 3 || !
s->first_slice_line)
2226 if (
i == 1 ||
i == 3 ||
s->mb_x)
2237 stride_y =
s->linesize << fieldtx;
2238 off = (fieldtx) ? ((
i & 1) * 8) + ((
i & 2) >> 1) *
s->linesize : (
i & 1) * 8 + 4 * (
i & 2) *
s->linesize;
2240 stride_y =
s->uvlinesize;
2243 s->idsp.put_signed_pixels_clamped(v->blocks[
i],
2244 s->dest[dst_idx] + off,
2256 if (
s->next_pic.ptr->field_picture)
2258 s->mv[0][0][0] =
s->cur_pic.motion_val[0][
s->block_index[0]][0] =
scale_mv(
s->next_pic.motion_val[1][
s->block_index[0]][0], v->
bfraction, 0,
s->quarter_sample);
2259 s->mv[0][0][1] =
s->cur_pic.motion_val[0][
s->block_index[0]][1] =
scale_mv(
s->next_pic.motion_val[1][
s->block_index[0]][1], v->
bfraction, 0,
s->quarter_sample);
2260 s->mv[1][0][0] =
s->cur_pic.motion_val[1][
s->block_index[0]][0] =
scale_mv(
s->next_pic.motion_val[1][
s->block_index[0]][0], v->
bfraction, 1,
s->quarter_sample);
2261 s->mv[1][0][1] =
s->cur_pic.motion_val[1][
s->block_index[0]][1] =
scale_mv(
s->next_pic.motion_val[1][
s->block_index[0]][1], v->
bfraction, 1,
s->quarter_sample);
2264 s->mv[0][2][0] =
s->cur_pic.motion_val[0][
s->block_index[2]][0] =
scale_mv(
s->next_pic.motion_val[1][
s->block_index[2]][0], v->
bfraction, 0,
s->quarter_sample);
2265 s->mv[0][2][1] =
s->cur_pic.motion_val[0][
s->block_index[2]][1] =
scale_mv(
s->next_pic.motion_val[1][
s->block_index[2]][1], v->
bfraction, 0,
s->quarter_sample);
2266 s->mv[1][2][0] =
s->cur_pic.motion_val[1][
s->block_index[2]][0] =
scale_mv(
s->next_pic.motion_val[1][
s->block_index[2]][0], v->
bfraction, 1,
s->quarter_sample);
2267 s->mv[1][2][1] =
s->cur_pic.motion_val[1][
s->block_index[2]][1] =
scale_mv(
s->next_pic.motion_val[1][
s->block_index[2]][1], v->
bfraction, 1,
s->quarter_sample);
2269 for (
i = 1;
i < 4;
i += 2) {
2270 s->mv[0][
i][0] =
s->cur_pic.motion_val[0][
s->block_index[
i]][0] =
s->mv[0][
i-1][0];
2271 s->mv[0][
i][1] =
s->cur_pic.motion_val[0][
s->block_index[
i]][1] =
s->mv[0][
i-1][1];
2272 s->mv[1][
i][0] =
s->cur_pic.motion_val[1][
s->block_index[
i]][0] =
s->mv[1][
i-1][0];
2273 s->mv[1][
i][1] =
s->cur_pic.motion_val[1][
s->block_index[
i]][1] =
s->mv[1][
i-1][1];
2276 for (
i = 1;
i < 4;
i++) {
2277 s->mv[0][
i][0] =
s->cur_pic.motion_val[0][
s->block_index[
i]][0] =
s->mv[0][0][0];
2278 s->mv[0][
i][1] =
s->cur_pic.motion_val[0][
s->block_index[
i]][1] =
s->mv[0][0][1];
2279 s->mv[1][
i][0] =
s->cur_pic.motion_val[1][
s->block_index[
i]][0] =
s->mv[1][0][0];
2280 s->mv[1][
i][1] =
s->cur_pic.motion_val[1][
s->block_index[
i]][1] =
s->mv[1][0][1];
2286 if (skipped || !
s->mb_intra) {
2316 for (
i = 0;
i < 6;
i++)
2323 for (
i = 0;
i < 4;
i++) {
2335 for (
i = 0;
i < 4;
i++) {
2338 val = ((mvbp >> (3 -
i)) & 1);
2381 for (
i = 0;
i < 2;
i++) {
2382 s->mv[dir][
i+2][0] =
s->mv[dir][
i][0] =
s->cur_pic.motion_val[dir][
s->block_index[
i+2]][0] =
s->cur_pic.motion_val[dir][
s->block_index[
i]][0];
2383 s->mv[dir][
i+2][1] =
s->mv[dir][
i][1] =
s->cur_pic.motion_val[dir][
s->block_index[
i+2]][1] =
s->cur_pic.motion_val[dir][
s->block_index[
i]][1];
2384 s->mv[dir2][
i+2][0] =
s->mv[dir2][
i][0] =
s->cur_pic.motion_val[dir2][
s->block_index[
i]][0] =
s->cur_pic.motion_val[dir2][
s->block_index[
i+2]][0];
2385 s->mv[dir2][
i+2][1] =
s->mv[dir2][
i][1] =
s->cur_pic.motion_val[dir2][
s->block_index[
i]][1] =
s->cur_pic.motion_val[dir2][
s->block_index[
i+2]][1];
2411 for (
i = 0;
i < 2;
i++) {
2412 s->mv[!dir][
i+2][0] =
s->mv[!dir][
i][0] =
s->cur_pic.motion_val[!dir][
s->block_index[
i+2]][0] =
s->cur_pic.motion_val[!dir][
s->block_index[
i]][0];
2413 s->mv[!dir][
i+2][1] =
s->mv[!dir][
i][1] =
s->cur_pic.motion_val[!dir][
s->block_index[
i+2]][1] =
s->cur_pic.motion_val[!dir][
s->block_index[
i]][1];
2420 s->cur_pic.qscale_table[mb_pos] = mquant;
2421 if (!v->
ttmbf && cbp)
2423 for (
i = 0;
i < 6;
i++) {
2424 s->dc_val[
s->block_index[
i]] = 0;
2426 val = ((cbp >> (5 -
i)) & 1);
2428 off = (
i & 4) ? 0 : ((
i & 1) * 8 + (
i & 2) * 4 *
s->linesize);
2430 off = (
i & 4) ? 0 : ((
i & 1) * 8 + ((
i > 1) *
s->linesize));
2433 first_block,
s->dest[dst_idx] + off,
2434 (
i & 4) ?
s->uvlinesize : (
s->linesize << fieldtx),
2438 block_cbp |= pat << (
i << 2);
2439 if (!v->
ttmbf && ttmb < 8)
2447 for (
i = 0;
i < 6;
i++) {
2449 s->dc_val[
s->block_index[
i]] = 0;
2452 s->cur_pic.qscale_table[mb_pos] = 0;
2469 for (
i = 0;
i < 2;
i++) {
2470 s->mv[dir][
i+2][0] =
s->mv[dir][
i][0] =
s->cur_pic.motion_val[dir][
s->block_index[
i+2]][0] =
s->cur_pic.motion_val[dir][
s->block_index[
i]][0];
2471 s->mv[dir][
i+2][1] =
s->mv[dir][
i][1] =
s->cur_pic.motion_val[dir][
s->block_index[
i+2]][1] =
s->cur_pic.motion_val[dir][
s->block_index[
i]][1];
2472 s->mv[dir2][
i+2][0] =
s->mv[dir2][
i][0] =
s->cur_pic.motion_val[dir2][
s->block_index[
i]][0] =
s->cur_pic.motion_val[dir2][
s->block_index[
i+2]][0];
2473 s->mv[dir2][
i+2][1] =
s->mv[dir2][
i][1] =
s->cur_pic.motion_val[dir2][
s->block_index[
i]][1] =
s->cur_pic.motion_val[dir2][
s->block_index[
i+2]][1];
2481 for (
i = 0;
i < 2;
i++) {
2482 s->mv[!dir][
i+2][0] =
s->mv[!dir][
i][0] =
s->cur_pic.motion_val[!dir][
s->block_index[
i+2]][0] =
s->cur_pic.motion_val[!dir][
s->block_index[
i]][0];
2483 s->mv[!dir][
i+2][1] =
s->mv[!dir][
i][1] =
s->cur_pic.motion_val[!dir][
s->block_index[
i+2]][1] =
s->cur_pic.motion_val[!dir][
s->block_index[
i]][1];
2496 v->
cbp[
s->mb_x] = block_cbp;
2497 v->
ttblk[
s->mb_x] = block_tt;
2540 s->mb_x =
s->mb_y = 0;
2542 s->first_slice_line = 1;
2543 for (
s->mb_y =
s->start_mb_y;
s->mb_y <
s->end_mb_y;
s->mb_y++) {
2549 mb_pos =
s->mb_x +
s->mb_y *
s->mb_width;
2551 s->cur_pic.qscale_table[mb_pos] = v->
pq;
2552 for (
int i = 0;
i < 4;
i++) {
2553 s->cur_pic.motion_val[1][
s->block_index[
i]][0] = 0;
2554 s->cur_pic.motion_val[1][
s->block_index[
i]][1] = 0;
2562 for (k = 0; k < 6; k++) {
2565 val = ((cbp >> (5 - k)) & 1);
2569 cbp |=
val << (5 - k);
2581 for (k = 0; k < 6; k++)
2582 for (j = 0; j < 64; j++)
2587 for (k = 0; k < 6; k++)
2588 for (j = 0; j < 64; j++)
2609 s->first_slice_line = 0;
2659 s->first_slice_line = 1;
2661 s->mb_y =
s->start_mb_y;
2662 if (
s->start_mb_y) {
2663 memset(&
s->coded_block[(2 *
s->mb_y - 1) *
s->b8_stride - 2], 0,
2664 (1 +
s->b8_stride) *
sizeof(*
s->coded_block));
2666 for (;
s->mb_y <
s->end_mb_y;
s->mb_y++) {
2669 for (;
s->mb_x <
s->mb_width;
s->mb_x++) {
2673 mb_pos =
s->mb_x +
s->mb_y *
s->mb_stride;
2675 for (
int i = 0;
i < 4;
i++) {
2676 s->cur_pic.motion_val[1][
s->block_index[
i] + v->
blocks_off][0] = 0;
2677 s->cur_pic.motion_val[1][
s->block_index[
i] + v->
blocks_off][1] = 0;
2700 s->cur_pic.qscale_table[mb_pos] = mquant;
2704 for (k = 0; k < 6; k++) {
2707 val = ((cbp >> (5 - k)) & 1);
2711 cbp |=
val << (5 - k);
2713 v->
a_avail = !
s->first_slice_line || (k == 2 || k == 3);
2714 v->
c_avail = !!
s->mb_x || (k == 1 || k == 3);
2742 s->first_slice_line = 0;
2782 s->first_slice_line = 1;
2784 for (
s->mb_y =
s->start_mb_y;
s->mb_y <
s->end_mb_y;
s->mb_y++) {
2787 for (;
s->mb_x <
s->mb_width;
s->mb_x++) {
2822 v->
cbp -
s->mb_stride,
2823 sizeof(v->
cbp_base[0]) * 2 *
s->mb_stride);
2833 s->first_slice_line = 0;
2868 s->first_slice_line = 1;
2869 for (
s->mb_y =
s->start_mb_y;
s->mb_y <
s->end_mb_y;
s->mb_y++) {
2872 for (;
s->mb_x <
s->mb_width;
s->mb_x++) {
2903 v->
cbp -
s->mb_stride,
2904 sizeof(v->
cbp_base[0]) * 2 *
s->mb_stride);
2911 s->first_slice_line = 0;
2925 s->first_slice_line = 1;
2926 for (
s->mb_y =
s->start_mb_y;
s->mb_y <
s->end_mb_y;
s->mb_y++) {
2930 memcpy(
s->dest[0],
s->last_pic.data[0] +
s->mb_y * 16 *
s->linesize,
s->linesize * 16);
2931 memcpy(
s->dest[1],
s->last_pic.data[1] +
s->mb_y * 8 *
s->uvlinesize,
s->uvlinesize * 8);
2932 memcpy(
s->dest[2],
s->last_pic.data[2] +
s->mb_y * 8 *
s->uvlinesize,
s->uvlinesize * 8);
2933 s->first_slice_line = 0;