25 #include "config_components.h"
90 if (
s->height != s1->
height ||
s->width != s1->
width ||
s->context_reinit) {
141 if (!
s->context_initialized)
150 if ((
s->width ||
s->height) &&
164 memset(
s->thread_context, 0,
sizeof(
s->thread_context));
165 s->thread_context[0] =
s;
167 if (
s->width &&
s->height) {
172 s->context_reinit = 0;
177 s->context_reinit = 1;
218 av_assert1(
s->mb_width ==
s->buffer_pools.alloc_mb_width);
219 av_assert1(
s->mb_height ==
s->buffer_pools.alloc_mb_height ||
220 FFALIGN(
s->mb_height, 2) ==
s->buffer_pools.alloc_mb_height);
221 av_assert1(
s->mb_stride ==
s->buffer_pools.alloc_mb_stride);
223 &
s->buffer_pools,
s->mb_height);
250 int h_chroma_shift, v_chroma_shift;
252 for (
int i = 0;
i <
frame->height;
i++)
271 av_assert1(!
s->last_pic.ptr ||
s->last_pic.ptr->f->buf[0]);
272 av_assert1(!
s->next_pic.ptr ||
s->next_pic.ptr->f->buf[0]);
276 "allocating dummy last picture for B frame\n");
280 "warning: first frame is no keyframe\n");
300 s->last_pic.ptr->f->buf[0]));
328 (!
s->progressive_frame && !
s->progressive_sequence);
329 s->cur_pic.ptr->field_picture =
s->picture_structure !=
PICT_FRAME;
331 s->cur_pic.ptr->f->pict_type =
s->pict_type;
342 ff_dlog(
s->avctx,
"L%p N%p C%p L%p N%p C%p type:%d drop:%d\n",
343 (
void*)
s->last_pic.ptr, (
void*)
s->next_pic.ptr, (
void*)
s->cur_pic.ptr,
344 s->last_pic.ptr ?
s->last_pic.ptr->f->data[0] :
NULL,
345 s->next_pic.ptr ?
s->next_pic.ptr->f->data[0] :
NULL,
346 s->cur_pic.ptr ?
s->cur_pic.ptr->f->data[0] :
NULL,
347 s->pict_type,
s->droppable);
364 if (
s->cur_pic.reference)
389 for (
unsigned y = 0; y < p->
mb_height; y++)
390 for (
unsigned x = 0; x < p->
mb_width; x++) {
391 const unsigned int block_idx = y * p->
mb_width + x;
392 const unsigned int mb_xy = y * p->
mb_stride + x;
409 s->last_pic.ptr ?
s->last_pic.ptr->f :
NULL,
410 y,
h,
s->picture_structure,
411 s->first_field,
s->low_delay);
422 s->mb_x =
s->mb_y = 0;
428 uint8_t *
dest,
const uint8_t *
src,
430 int src_x,
int src_y,
434 int motion_x,
int motion_y)
436 const int lowres =
s->avctx->lowres;
437 const int op_index =
lowres;
438 const int s_mask = (2 <<
lowres) - 1;
444 if (
s->quarter_sample) {
449 sx = motion_x & s_mask;
450 sy = motion_y & s_mask;
451 src_x += motion_x >>
lowres + 1;
452 src_y += motion_y >>
lowres + 1;
458 s->vdsp.emulated_edge_mc(
s->sc.edge_emu_buffer,
src,
459 s->linesize,
s->linesize,
460 w + 1, (
h + 1) << field_based,
461 src_x, src_y * (1 << field_based),
463 src =
s->sc.edge_emu_buffer;
483 uint8_t *
const *ref_picture,
485 int motion_x,
int motion_y,
488 const uint8_t *ptr_y, *ptr_cb, *ptr_cr;
489 int mx,
my, src_x, src_y, uvsrc_x, uvsrc_y, sx, sy, uvsx, uvsy;
491 const int lowres =
s->avctx->lowres;
492 const int op_index =
lowres - 1 +
s->chroma_x_shift;
493 const int block_s = 8 >>
lowres;
494 const int s_mask = (2 <<
lowres) - 1;
497 int hc =
s->chroma_y_shift ? (
h+1-bottom_field)>>1 :
h;
501 linesize =
s->cur_pic.linesize[0] << field_based;
502 uvlinesize =
s->cur_pic.linesize[1] << field_based;
505 if (
s->quarter_sample) {
514 sx = motion_x & s_mask;
515 sy = motion_y & s_mask;
516 src_x =
s->mb_x * 2 * block_s + (motion_x >>
lowres + 1);
517 src_y = (
mb_y * 2 * block_s >> field_based) + (motion_y >>
lowres + 1);
520 uvsx = ((motion_x >> 1) & s_mask) | (sx & 1);
521 uvsy = ((motion_y >> 1) & s_mask) | (sy & 1);
522 uvsrc_x = src_x >> 1;
523 uvsrc_y = src_y >> 1;
528 uvsx = (2 *
mx) & s_mask;
529 uvsy = (2 *
my) & s_mask;
530 uvsrc_x =
s->mb_x * block_s + (
mx >>
lowres);
533 if (
s->chroma_y_shift) {
538 uvsrc_x =
s->mb_x * block_s + (
mx >>
lowres + 1);
539 uvsrc_y = (
mb_y * block_s >> field_based) + (
my >>
lowres + 1);
541 if (
s->chroma_x_shift) {
545 uvsy = motion_y & s_mask;
547 uvsrc_x =
s->mb_x*block_s + (
mx >> (
lowres+1));
550 uvsx = motion_x & s_mask;
551 uvsy = motion_y & s_mask;
558 ptr_y = ref_picture[0] + src_y *
linesize + src_x;
559 ptr_cb = ref_picture[1] + uvsrc_y *
uvlinesize + uvsrc_x;
560 ptr_cr = ref_picture[2] + uvsrc_y *
uvlinesize + uvsrc_x;
562 if ((
unsigned) src_x >
FFMAX(
h_edge_pos - (!!sx) - 2 * block_s, 0) || uvsrc_y<0 ||
564 s->vdsp.emulated_edge_mc(
s->sc.edge_emu_buffer, ptr_y,
566 17, 17 + field_based,
567 src_x, src_y * (1 << field_based),
h_edge_pos,
569 ptr_y =
s->sc.edge_emu_buffer;
571 uint8_t *ubuf =
s->sc.edge_emu_buffer + 18 *
s->linesize;
572 uint8_t *vbuf =ubuf + 10 *
s->uvlinesize;
574 vbuf -=
s->uvlinesize;
575 s->vdsp.emulated_edge_mc(ubuf, ptr_cb,
578 uvsrc_x, uvsrc_y * (1 << field_based),
580 s->vdsp.emulated_edge_mc(vbuf, ptr_cr,
583 uvsrc_x, uvsrc_y * (1 << field_based),
592 dest_y +=
s->linesize;
593 dest_cb +=
s->uvlinesize;
594 dest_cr +=
s->uvlinesize;
598 ptr_y +=
s->linesize;
599 ptr_cb +=
s->uvlinesize;
600 ptr_cr +=
s->uvlinesize;
608 uvsx = (uvsx << 2) >>
lowres;
609 uvsy = (uvsy << 2) >>
lowres;
611 pix_op[op_index](dest_cb, ptr_cb,
uvlinesize, hc, uvsx, uvsy);
612 pix_op[op_index](dest_cr, ptr_cr,
uvlinesize, hc, uvsx, uvsy);
619 uint8_t *dest_cb, uint8_t *dest_cr,
620 uint8_t *
const *ref_picture,
624 const int lowres =
s->avctx->lowres;
625 const int op_index =
lowres;
626 const int block_s = 8 >>
lowres;
627 const int s_mask = (2 <<
lowres) - 1;
630 int emu = 0, src_x, src_y, sx, sy;
636 if (
s->quarter_sample) {
648 src_x =
s->mb_x * block_s + (
mx >>
lowres + 1);
649 src_y =
s->mb_y * block_s + (
my >>
lowres + 1);
651 offset = src_y *
s->uvlinesize + src_x;
652 ptr = ref_picture[1] +
offset;
655 s->vdsp.emulated_edge_mc(
s->sc.edge_emu_buffer, ptr,
656 s->uvlinesize,
s->uvlinesize,
659 ptr =
s->sc.edge_emu_buffer;
664 pix_op[op_index](dest_cb, ptr,
s->uvlinesize, block_s, sx, sy);
666 ptr = ref_picture[2] +
offset;
668 s->vdsp.emulated_edge_mc(
s->sc.edge_emu_buffer, ptr,
669 s->uvlinesize,
s->uvlinesize,
672 ptr =
s->sc.edge_emu_buffer;
674 pix_op[op_index](dest_cr, ptr,
s->uvlinesize, block_s, sx, sy);
689 uint8_t *dest_y, uint8_t *dest_cb,
691 int dir, uint8_t *
const *ref_picture,
696 const int lowres =
s->avctx->lowres;
697 const int block_s = 8 >>
lowres;
702 switch (
s->mv_type) {
707 s->mv[dir][0][0],
s->mv[dir][0][1],
713 for (
int i = 0;
i < 4;
i++) {
715 s->linesize) * block_s,
716 ref_picture[0], 0, 0,
717 (2 *
mb_x + (
i & 1)) * block_s,
718 (2 *
mb_y + (
i >> 1)) * block_s,
719 s->width,
s->height,
s->linesize,
721 block_s, block_s, pix_op,
722 s->mv[dir][
i][0],
s->mv[dir][
i][1]);
724 mx +=
s->mv[dir][
i][0];
725 my +=
s->mv[dir][
i][1];
736 1, 0,
s->field_select[dir][0],
738 s->mv[dir][0][0],
s->mv[dir][0][1],
742 1, 1,
s->field_select[dir][1],
744 s->mv[dir][1][0],
s->mv[dir][1][1],
747 if (
s->picture_structure !=
s->field_select[dir][0] + 1 &&
749 ref_picture =
s->cur_pic.ptr->f->data;
752 0, 0,
s->field_select[dir][0],
755 s->mv[dir][0][1], 2 * block_s,
mb_y >> 1);
759 for (
int i = 0;
i < 2;
i++) {
760 uint8_t *
const *ref2picture;
762 if (
s->picture_structure ==
s->field_select[dir][
i] + 1 ||
764 ref2picture = ref_picture;
766 ref2picture =
s->cur_pic.ptr->f->data;
770 0, 0,
s->field_select[dir][
i],
772 s->mv[dir][
i][0],
s->mv[dir][
i][1] +
773 2 * block_s *
i, block_s,
mb_y >> 1);
775 dest_y += 2 * block_s *
s->linesize;
776 dest_cb += (2 * block_s >>
s->chroma_y_shift) *
s->uvlinesize;
777 dest_cr += (2 * block_s >>
s->chroma_y_shift) *
s->uvlinesize;
782 for (
int i = 0;
i < 2;
i++) {
783 for (
int j = 0; j < 2; j++) {
787 s->mv[dir][2 *
i + j][0],
788 s->mv[dir][2 *
i + j][1],
791 pix_op =
s->h264chroma.avg_h264_chroma_pixels_tab;
794 for (
int i = 0;
i < 2;
i++) {
796 0, 0,
s->picture_structure !=
i + 1,
798 s->mv[dir][2 *
i][0],
s->mv[dir][2 *
i][1],
799 2 * block_s,
mb_y >> 1);
802 pix_op =
s->h264chroma.avg_h264_chroma_pixels_tab;
806 if (!
s->first_field) {
807 ref_picture =
s->cur_pic.ptr->f->data;
822 int my_max = INT_MIN, my_min = INT_MAX, qpel_shift = !
s->quarter_sample;
828 switch (
s->mv_type) {
842 for (
int i = 0;
i < mvs;
i++) {
843 int my =
s->mv[dir][
i][1];
848 off = ((
FFMAX(-my_min, my_max) << qpel_shift) + 63) >> 6;
850 return av_clip(
s->mb_y + off, 0,
s->mb_height - 1);
852 return s->mb_height - 1;
857 int16_t *
block,
int i, uint8_t *
dest,
int line_size)
859 if (
s->block_last_index[
i] >= 0) {
875 if (
s->block_last_index[
i] >= 0) {
882 #define NOT_MPEG12_H261 0
883 #define MAY_BE_MPEG12_H261 1
884 #define DEFINITELY_MPEG12_H261 2
897 int lowres_flag,
int is_mpeg12)
899 #define IS_MPEG12_H261(s) (is_mpeg12 == MAY_BE_MPEG12_H261 ? ((s)->out_format <= FMT_H261) : is_mpeg12)
900 uint8_t *dest_y =
s->dest[0], *dest_cb =
s->dest[1], *dest_cr =
s->dest[2];
901 int dct_linesize, dct_offset;
902 const int linesize =
s->cur_pic.linesize[0];
904 const int block_size = lowres_flag ? 8 >>
s->avctx->lowres : 8;
906 dct_linesize =
linesize <<
s->interlaced_dct;
928 op_pix =
s->h264chroma.avg_h264_chroma_pixels_tab;
938 op_pix =
s->hdsp.put_pixels_tab;
939 op_qpix =
s->qdsp.put_qpel_pixels_tab;
941 op_pix =
s->hdsp.put_no_rnd_pixels_tab;
942 op_qpix =
s->qdsp.put_no_rnd_qpel_pixels_tab;
945 ff_mpv_motion(
s, dest_y, dest_cb, dest_cr, 0,
s->last_pic.data, op_pix, op_qpix);
946 op_pix =
s->hdsp.avg_pixels_tab;
947 op_qpix =
s->qdsp.avg_qpel_pixels_tab;
950 ff_mpv_motion(
s, dest_y, dest_cb, dest_cr, 1,
s->next_pic.data, op_pix, op_qpix);
955 if (
s->avctx->skip_idct) {
983 add_dct(
s,
block[3], 3, dest_y + dct_offset + block_size, dct_linesize);
986 if (
s->chroma_y_shift) {
998 if (!
s->chroma_x_shift) {
1000 add_dct(
s,
block[9], 9, dest_cr + block_size, dct_linesize);
1001 add_dct(
s,
block[10], 10, dest_cb + block_size + dct_offset, dct_linesize);
1002 add_dct(
s,
block[11], 11, dest_cr + block_size + dct_offset, dct_linesize);
1006 }
else if (CONFIG_WMV2_DECODER) {
1014 s->avctx->bits_per_raw_sample > 8) {
1020 put_dct(
s,
block[1], 1, dest_y + block_size, dct_linesize,
s->qscale);
1021 put_dct(
s,
block[2], 2, dest_y + dct_offset , dct_linesize,
s->qscale);
1022 put_dct(
s,
block[3], 3, dest_y + dct_offset + block_size, dct_linesize,
s->qscale);
1025 if (
s->chroma_y_shift) {
1031 put_dct(
s,
block[4], 4, dest_cb, dct_linesize,
s->chroma_qscale);
1032 put_dct(
s,
block[5], 5, dest_cr, dct_linesize,
s->chroma_qscale);
1033 put_dct(
s,
block[6], 6, dest_cb + dct_offset, dct_linesize,
s->chroma_qscale);
1034 put_dct(
s,
block[7], 7, dest_cr + dct_offset, dct_linesize,
s->chroma_qscale);
1038 s->idsp.idct_put(dest_y, dct_linesize,
block[0]);
1039 s->idsp.idct_put(dest_y + block_size, dct_linesize,
block[1]);
1040 s->idsp.idct_put(dest_y + dct_offset, dct_linesize,
block[2]);
1041 s->idsp.idct_put(dest_y + dct_offset + block_size, dct_linesize,
block[3]);
1044 if (
s->chroma_y_shift) {
1051 s->idsp.idct_put(dest_cb, dct_linesize,
block[4]);
1052 s->idsp.idct_put(dest_cr, dct_linesize,
block[5]);
1053 s->idsp.idct_put(dest_cb + dct_offset, dct_linesize,
block[6]);
1054 s->idsp.idct_put(dest_cr + dct_offset, dct_linesize,
block[7]);
1055 if (!
s->chroma_x_shift) {
1056 s->idsp.idct_put(dest_cb + block_size, dct_linesize,
block[8]);
1057 s->idsp.idct_put(dest_cr + block_size, dct_linesize,
block[9]);
1058 s->idsp.idct_put(dest_cb + block_size + dct_offset, dct_linesize,
block[10]);
1059 s->idsp.idct_put(dest_cr + block_size + dct_offset, dct_linesize,
block[11]);
1069 const int mb_xy =
s->mb_y *
s->mb_stride +
s->mb_x;
1070 uint8_t *mbskip_ptr = &
s->mbskip_table[mb_xy];
1072 s->cur_pic.qscale_table[mb_xy] =
s->qscale;
1075 if (
s->mb_skipped) {
1079 }
else if (!
s->cur_pic.reference) {
1088 for (
int i = 0;
i < 6;
i++) {
1089 for (
int j = 0; j < 64; j++) {
1091 block[
i][
s->idsp.idct_permutation[j]]);
1098 if (!
s->avctx->lowres) {