changeset 10926:42cff5346e53 libavcodec

Dont init chroma elements of non_zero_count_cache for deblock.
author michael
date Mon, 18 Jan 2010 23:30:21 +0000
parents cf608664f7bf
children bb774f0bc2b6
files h264.h
diffstat 1 files changed, 13 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/h264.h	Mon Jan 18 23:27:53 2010 +0000
+++ b/h264.h	Mon Jan 18 23:30:21 2010 +0000
@@ -959,14 +959,17 @@
 //FIXME constraint_intra_pred & partitioning & nnz (let us hope this is just a typo in the spec)
     if(top_type){
         *(uint32_t*)&h->non_zero_count_cache[4+8*0]= *(uint32_t*)&h->non_zero_count[top_xy][4+3*8];
-
+        if(!for_deblock){
         h->non_zero_count_cache[1+8*0]= h->non_zero_count[top_xy][1+1*8];
         h->non_zero_count_cache[2+8*0]= h->non_zero_count[top_xy][2+1*8];
 
         h->non_zero_count_cache[1+8*3]= h->non_zero_count[top_xy][1+2*8];
         h->non_zero_count_cache[2+8*3]= h->non_zero_count[top_xy][2+2*8];
-
+        }
     }else{
+        if(for_deblock){
+            *(uint32_t*)&h->non_zero_count_cache[4+8*0]= 0;
+        }else{
         h->non_zero_count_cache[4+8*0]=
         h->non_zero_count_cache[5+8*0]=
         h->non_zero_count_cache[6+8*0]=
@@ -977,6 +980,7 @@
 
         h->non_zero_count_cache[1+8*3]=
         h->non_zero_count_cache[2+8*3]= CABAC && !IS_INTRA(mb_type) ? 0 : 64;
+        }
 
     }
 
@@ -984,13 +988,20 @@
         if(left_type[i]){
             h->non_zero_count_cache[3+8*1 + 2*8*i]= h->non_zero_count[left_xy[i]][left_block[8+0+2*i]];
             h->non_zero_count_cache[3+8*2 + 2*8*i]= h->non_zero_count[left_xy[i]][left_block[8+1+2*i]];
+            if(!for_deblock){
             h->non_zero_count_cache[0+8*1 +   8*i]= h->non_zero_count[left_xy[i]][left_block[8+4+2*i]];
             h->non_zero_count_cache[0+8*4 +   8*i]= h->non_zero_count[left_xy[i]][left_block[8+5+2*i]];
+            }
         }else{
+            if(for_deblock){
+                h->non_zero_count_cache[3+8*1 + 2*8*i]=
+                h->non_zero_count_cache[3+8*2 + 2*8*i]= 0;
+            }else{
             h->non_zero_count_cache[3+8*1 + 2*8*i]=
             h->non_zero_count_cache[3+8*2 + 2*8*i]=
             h->non_zero_count_cache[0+8*1 +   8*i]=
             h->non_zero_count_cache[0+8*4 +   8*i]= CABAC && !IS_INTRA(mb_type) ? 0 : 64;
+            }
         }
     }