Hi, On Tue, Oct 9, 2012 at 4:56 PM, Mashiat Sarker Shakkhar <mashiat.sar...@gmail.com> wrote: > On 10/9/2012 7:37 PM, Ronald S. Bultje wrote: >> >> Hi, >> >> On Tue, Oct 9, 2012 at 1:38 PM, Mashiat Sarker Shakkhar >> <mashiat.sar...@gmail.com> wrote: >>> >>> This is required due to the way VC-1 handles chroma pull-back which may >>> end >>> up causing negative chroma MV for zero luma MV. Edge emulation needs to >>> be >>> invoked in such cases. >>> >>> This problem only affects chroma Y motion vector. >>> --- >>> libavcodec/vc1dec.c | 2 +- >>> 1 file changed, 1 insertion(+), 1 deletion(-) >>> >>> diff --git a/libavcodec/vc1dec.c b/libavcodec/vc1dec.c >>> index 42eb4a5..2683c86 100644 >>> --- a/libavcodec/vc1dec.c >>> +++ b/libavcodec/vc1dec.c >>> @@ -430,7 +430,7 @@ static void vc1_mc_1mv(VC1Context *v, int dir) >>> if (v->rangeredfrm || (v->mv_mode == MV_PMODE_INTENSITY_COMP) >>> || s->h_edge_pos < 22 || v_edge_pos < 22 >>> || (unsigned)(src_x - s->mspel) > s->h_edge_pos - (mx&3) - 16 - >>> s->mspel * 3 >>> - || (unsigned)(src_y - s->mspel) > v_edge_pos - (my&3) - 16 - >>> s->mspel * 3) { >>> + || (unsigned)(src_y - 1) > v_edge_pos - (my&3) - 16 - >>> 3) { >> >> >> I'm slightly curious why this is only the case for the vertical >> dimension, but not the horizontal. Is that intentional, or an >> oversight? > > > This thread contains my earlier discussion on a rejected patch which tried > to fix the same bug: > > http://patches.libav.org/patch/26240/
OK so it's not because of pullback per se, but because of field adjustment, then it makes sense. Ronald _______________________________________________ libav-devel mailing list libav-devel@libav.org https://lists.libav.org/mailman/listinfo/libav-devel