changeset 11137:510950eafba5 libavcodec

Special case for spatial direct MV predictor being 0. a little less than 200 cpu cycles faster with the cathedral sample.
author michael
date Sat, 13 Feb 2010 02:47:41 +0000
parents a0c52e951a29
children 76b57b8e2a9a
files h264_direct.c
diffstat 1 files changed, 7 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/h264_direct.c	Sat Feb 13 02:20:56 2010 +0000
+++ b/h264_direct.c	Sat Feb 13 02:47:41 2010 +0000
@@ -265,7 +265,13 @@
             sub_mb_type |= MB_TYPE_L0L1;
         }
 
-        if(IS_INTERLACED(*mb_type) != IS_INTERLACED(mb_type_col[0])){
+        if(!is_b8x8 && (mv[0]|mv[1]) == 0){
+            fill_rectangle(&h->ref_cache[0][scan8[0]], 4, 4, 8, (uint8_t)ref[0], 1);
+            fill_rectangle(&h->ref_cache[1][scan8[0]], 4, 4, 8, (uint8_t)ref[1], 1);
+            fill_rectangle(&h->mv_cache[0][scan8[0]], 4, 4, 8, 0, 4);
+            fill_rectangle(&h->mv_cache[1][scan8[0]], 4, 4, 8, 0, 4);
+            *mb_type= (*mb_type & ~(MB_TYPE_8x8|MB_TYPE_16x8|MB_TYPE_8x16|MB_TYPE_P1L0|MB_TYPE_P1L1))|MB_TYPE_16x16|MB_TYPE_DIRECT2;
+        }else if(IS_INTERLACED(*mb_type) != IS_INTERLACED(mb_type_col[0])){
             int n=0;
             for(i8=0; i8<4; i8++){
                 int x8 = i8&1;