|
|
@ -891,9 +891,11 @@ static void vc1_put_block(VC1Context *v, DCTELEM block[6][64]) |
|
|
|
dsp->put_pixels_clamped(block[2], Y, ys); |
|
|
|
dsp->put_pixels_clamped(block[2], Y, ys); |
|
|
|
dsp->put_pixels_clamped(block[3], Y + 8, ys); |
|
|
|
dsp->put_pixels_clamped(block[3], Y + 8, ys); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(!(v->s.flags & CODEC_FLAG_GRAY)) { |
|
|
|
dsp->put_pixels_clamped(block[4], v->s.dest[1], us); |
|
|
|
dsp->put_pixels_clamped(block[4], v->s.dest[1], us); |
|
|
|
dsp->put_pixels_clamped(block[5], v->s.dest[2], vs); |
|
|
|
dsp->put_pixels_clamped(block[5], v->s.dest[2], vs); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** Do motion compensation over 1 macroblock
|
|
|
|
/** Do motion compensation over 1 macroblock
|
|
|
|
* Mostly adapted hpel_motion and qpel_motion from mpegvideo.c |
|
|
|
* Mostly adapted hpel_motion and qpel_motion from mpegvideo.c |
|
|
@ -935,6 +937,12 @@ static void vc1_mc_1mv(VC1Context *v, int dir) |
|
|
|
srcU += uvsrc_y * s->uvlinesize + uvsrc_x; |
|
|
|
srcU += uvsrc_y * s->uvlinesize + uvsrc_x; |
|
|
|
srcV += uvsrc_y * s->uvlinesize + uvsrc_x; |
|
|
|
srcV += uvsrc_y * s->uvlinesize + uvsrc_x; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* for grayscale we should not try to read from unknown area */ |
|
|
|
|
|
|
|
if(s->flags & CODEC_FLAG_GRAY) { |
|
|
|
|
|
|
|
srcU = s->edge_emu_buffer + 18 * s->linesize; |
|
|
|
|
|
|
|
srcV = s->edge_emu_buffer + 18 * s->linesize; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if((v->mv_mode == MV_PMODE_INTENSITY_COMP) |
|
|
|
if((v->mv_mode == MV_PMODE_INTENSITY_COMP) |
|
|
|
|| (unsigned)src_x > s->h_edge_pos - (mx&3) - 16 |
|
|
|
|| (unsigned)src_x > s->h_edge_pos - (mx&3) - 16 |
|
|
|
|| (unsigned)src_y > s->v_edge_pos - (my&3) - 16){ |
|
|
|
|| (unsigned)src_y > s->v_edge_pos - (my&3) - 16){ |
|
|
@ -993,6 +1001,8 @@ static void vc1_mc_1mv(VC1Context *v, int dir) |
|
|
|
else |
|
|
|
else |
|
|
|
dsp->put_no_rnd_qpel_pixels_tab[0][dxy](s->dest[0], srcY, s->linesize); |
|
|
|
dsp->put_no_rnd_qpel_pixels_tab[0][dxy](s->dest[0], srcY, s->linesize); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(s->flags & CODEC_FLAG_GRAY) return; |
|
|
|
/* Chroma MC always uses qpel blilinear */ |
|
|
|
/* Chroma MC always uses qpel blilinear */ |
|
|
|
uvdxy = ((uvmy & 3) << 2) | (uvmx & 3); |
|
|
|
uvdxy = ((uvmy & 3) << 2) | (uvmx & 3); |
|
|
|
if(!v->rnd){ |
|
|
|
if(!v->rnd){ |
|
|
@ -1080,6 +1090,7 @@ static void vc1_mc_4mv_chroma(VC1Context *v) |
|
|
|
static const int count[16] = { 0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4}; |
|
|
|
static const int count[16] = { 0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4}; |
|
|
|
|
|
|
|
|
|
|
|
if(!v->s.last_picture.data[0])return; |
|
|
|
if(!v->s.last_picture.data[0])return; |
|
|
|
|
|
|
|
if(s->flags & CODEC_FLAG_GRAY) return; |
|
|
|
|
|
|
|
|
|
|
|
for(i = 0; i < 4; i++) { |
|
|
|
for(i = 0; i < 4; i++) { |
|
|
|
mvx[i] = s->mv[0][i][0]; |
|
|
|
mvx[i] = s->mv[0][i][0]; |
|
|
@ -2565,6 +2576,7 @@ static int vc1_decode_p_mb(VC1Context *v) |
|
|
|
v->c_avail = v->mb_type[0][s->block_index[i] - 1]; |
|
|
|
v->c_avail = v->mb_type[0][s->block_index[i] - 1]; |
|
|
|
|
|
|
|
|
|
|
|
vc1_decode_intra_block(v, s->block[i], i, val, mquant, (i&4)?v->codingset2:v->codingset); |
|
|
|
vc1_decode_intra_block(v, s->block[i], i, val, mquant, (i&4)?v->codingset2:v->codingset); |
|
|
|
|
|
|
|
if((i>3) && (s->flags & CODEC_FLAG_GRAY)) continue; |
|
|
|
vc1_inv_trans(s->block[i], 8, 8); |
|
|
|
vc1_inv_trans(s->block[i], 8, 8); |
|
|
|
for(j = 0; j < 64; j++) s->block[i][j] += 128; |
|
|
|
for(j = 0; j < 64; j++) s->block[i][j] += 128; |
|
|
|
s->dsp.put_pixels_clamped(s->block[i], s->dest[dst_idx] + off, s->linesize >> ((i & 4) >> 2)); |
|
|
|
s->dsp.put_pixels_clamped(s->block[i], s->dest[dst_idx] + off, s->linesize >> ((i & 4) >> 2)); |
|
|
@ -2579,6 +2591,7 @@ static int vc1_decode_p_mb(VC1Context *v) |
|
|
|
vc1_decode_p_block(v, s->block[i], i, mquant, ttmb, first_block); |
|
|
|
vc1_decode_p_block(v, s->block[i], i, mquant, ttmb, first_block); |
|
|
|
if(!v->ttmbf && ttmb < 8) ttmb = -1; |
|
|
|
if(!v->ttmbf && ttmb < 8) ttmb = -1; |
|
|
|
first_block = 0; |
|
|
|
first_block = 0; |
|
|
|
|
|
|
|
if((i<4) || !(s->flags & CODEC_FLAG_GRAY)) |
|
|
|
s->dsp.add_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i&4)?s->uvlinesize:s->linesize); |
|
|
|
s->dsp.add_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i&4)?s->uvlinesize:s->linesize); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -2666,6 +2679,7 @@ static int vc1_decode_p_mb(VC1Context *v) |
|
|
|
v->c_avail = v->mb_type[0][s->block_index[i] - 1]; |
|
|
|
v->c_avail = v->mb_type[0][s->block_index[i] - 1]; |
|
|
|
|
|
|
|
|
|
|
|
vc1_decode_intra_block(v, s->block[i], i, is_coded[i], mquant, (i&4)?v->codingset2:v->codingset); |
|
|
|
vc1_decode_intra_block(v, s->block[i], i, is_coded[i], mquant, (i&4)?v->codingset2:v->codingset); |
|
|
|
|
|
|
|
if((i>3) && (s->flags & CODEC_FLAG_GRAY)) continue; |
|
|
|
vc1_inv_trans(s->block[i], 8, 8); |
|
|
|
vc1_inv_trans(s->block[i], 8, 8); |
|
|
|
for(j = 0; j < 64; j++) s->block[i][j] += 128; |
|
|
|
for(j = 0; j < 64; j++) s->block[i][j] += 128; |
|
|
|
s->dsp.put_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i&4)?s->uvlinesize:s->linesize); |
|
|
|
s->dsp.put_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i&4)?s->uvlinesize:s->linesize); |
|
|
@ -2680,6 +2694,7 @@ static int vc1_decode_p_mb(VC1Context *v) |
|
|
|
status = vc1_decode_p_block(v, s->block[i], i, mquant, ttmb, first_block); |
|
|
|
status = vc1_decode_p_block(v, s->block[i], i, mquant, ttmb, first_block); |
|
|
|
if(!v->ttmbf && ttmb < 8) ttmb = -1; |
|
|
|
if(!v->ttmbf && ttmb < 8) ttmb = -1; |
|
|
|
first_block = 0; |
|
|
|
first_block = 0; |
|
|
|
|
|
|
|
if((i<4) || !(s->flags & CODEC_FLAG_GRAY)) |
|
|
|
s->dsp.add_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i&4)?s->uvlinesize:s->linesize); |
|
|
|
s->dsp.add_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i&4)?s->uvlinesize:s->linesize); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -2829,6 +2844,7 @@ static void vc1_decode_b_mb(VC1Context *v) |
|
|
|
v->c_avail = v->mb_type[0][s->block_index[i] - 1]; |
|
|
|
v->c_avail = v->mb_type[0][s->block_index[i] - 1]; |
|
|
|
|
|
|
|
|
|
|
|
vc1_decode_intra_block(v, s->block[i], i, val, mquant, (i&4)?v->codingset2:v->codingset); |
|
|
|
vc1_decode_intra_block(v, s->block[i], i, val, mquant, (i&4)?v->codingset2:v->codingset); |
|
|
|
|
|
|
|
if((i>3) && (s->flags & CODEC_FLAG_GRAY)) continue; |
|
|
|
vc1_inv_trans(s->block[i], 8, 8); |
|
|
|
vc1_inv_trans(s->block[i], 8, 8); |
|
|
|
for(j = 0; j < 64; j++) s->block[i][j] += 128; |
|
|
|
for(j = 0; j < 64; j++) s->block[i][j] += 128; |
|
|
|
s->dsp.put_pixels_clamped(s->block[i], s->dest[dst_idx] + off, s->linesize >> ((i & 4) >> 2)); |
|
|
|
s->dsp.put_pixels_clamped(s->block[i], s->dest[dst_idx] + off, s->linesize >> ((i & 4) >> 2)); |
|
|
@ -2843,6 +2859,7 @@ static void vc1_decode_b_mb(VC1Context *v) |
|
|
|
vc1_decode_p_block(v, s->block[i], i, mquant, ttmb, first_block); |
|
|
|
vc1_decode_p_block(v, s->block[i], i, mquant, ttmb, first_block); |
|
|
|
if(!v->ttmbf && ttmb < 8) ttmb = -1; |
|
|
|
if(!v->ttmbf && ttmb < 8) ttmb = -1; |
|
|
|
first_block = 0; |
|
|
|
first_block = 0; |
|
|
|
|
|
|
|
if((i<4) || !(s->flags & CODEC_FLAG_GRAY)) |
|
|
|
s->dsp.add_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i&4)?s->uvlinesize:s->linesize); |
|
|
|
s->dsp.add_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i&4)?s->uvlinesize:s->linesize); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -2928,17 +2945,21 @@ static void vc1_decode_i_blocks(VC1Context *v) |
|
|
|
if(!s->first_slice_line) { |
|
|
|
if(!s->first_slice_line) { |
|
|
|
vc1_v_overlap(s->dest[0], s->linesize, 0); |
|
|
|
vc1_v_overlap(s->dest[0], s->linesize, 0); |
|
|
|
vc1_v_overlap(s->dest[0] + 8, s->linesize, 0); |
|
|
|
vc1_v_overlap(s->dest[0] + 8, s->linesize, 0); |
|
|
|
|
|
|
|
if(!(s->flags & CODEC_FLAG_GRAY)) { |
|
|
|
vc1_v_overlap(s->dest[1], s->uvlinesize, s->mb_y&1); |
|
|
|
vc1_v_overlap(s->dest[1], s->uvlinesize, s->mb_y&1); |
|
|
|
vc1_v_overlap(s->dest[2], s->uvlinesize, s->mb_y&1); |
|
|
|
vc1_v_overlap(s->dest[2], s->uvlinesize, s->mb_y&1); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
vc1_v_overlap(s->dest[0] + 8 * s->linesize, s->linesize, 1); |
|
|
|
vc1_v_overlap(s->dest[0] + 8 * s->linesize, s->linesize, 1); |
|
|
|
vc1_v_overlap(s->dest[0] + 8 * s->linesize + 8, s->linesize, 1); |
|
|
|
vc1_v_overlap(s->dest[0] + 8 * s->linesize + 8, s->linesize, 1); |
|
|
|
if(s->mb_x) { |
|
|
|
if(s->mb_x) { |
|
|
|
vc1_h_overlap(s->dest[0], s->linesize, 0); |
|
|
|
vc1_h_overlap(s->dest[0], s->linesize, 0); |
|
|
|
vc1_h_overlap(s->dest[0] + 8 * s->linesize, s->linesize, 0); |
|
|
|
vc1_h_overlap(s->dest[0] + 8 * s->linesize, s->linesize, 0); |
|
|
|
|
|
|
|
if(!(s->flags & CODEC_FLAG_GRAY)) { |
|
|
|
vc1_h_overlap(s->dest[1], s->uvlinesize, s->mb_x&1); |
|
|
|
vc1_h_overlap(s->dest[1], s->uvlinesize, s->mb_x&1); |
|
|
|
vc1_h_overlap(s->dest[2], s->uvlinesize, s->mb_x&1); |
|
|
|
vc1_h_overlap(s->dest[2], s->uvlinesize, s->mb_x&1); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
vc1_h_overlap(s->dest[0] + 8, s->linesize, 1); |
|
|
|
vc1_h_overlap(s->dest[0] + 8, s->linesize, 1); |
|
|
|
vc1_h_overlap(s->dest[0] + 8 * s->linesize + 8, s->linesize, 1); |
|
|
|
vc1_h_overlap(s->dest[0] + 8 * s->linesize + 8, s->linesize, 1); |
|
|
|
} |
|
|
|
} |
|
|
@ -3079,7 +3100,10 @@ static int vc1_decode_init(AVCodecContext *avctx) |
|
|
|
GetBitContext gb; |
|
|
|
GetBitContext gb; |
|
|
|
|
|
|
|
|
|
|
|
if (!avctx->extradata_size || !avctx->extradata) return -1; |
|
|
|
if (!avctx->extradata_size || !avctx->extradata) return -1; |
|
|
|
|
|
|
|
if (!(avctx->flags & CODEC_FLAG_GRAY)) |
|
|
|
avctx->pix_fmt = PIX_FMT_YUV420P; |
|
|
|
avctx->pix_fmt = PIX_FMT_YUV420P; |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
avctx->pix_fmt = PIX_FMT_GRAY8; |
|
|
|
v->s.avctx = avctx; |
|
|
|
v->s.avctx = avctx; |
|
|
|
avctx->flags |= CODEC_FLAG_EMU_EDGE; |
|
|
|
avctx->flags |= CODEC_FLAG_EMU_EDGE; |
|
|
|
v->s.flags |= CODEC_FLAG_EMU_EDGE; |
|
|
|
v->s.flags |= CODEC_FLAG_EMU_EDGE; |
|
|
|