]> git.sesse.net Git - x264/blobdiff - encoder/macroblock.h
r810 borked hpel_filter_sse2 on unaligned buffers
[x264] / encoder / macroblock.h
index 9f8f661cef6db77d9d529434f419357b304a0103..ee69d40795f62da7c83495d0b7f1f57abffb968d 100644 (file)
@@ -26,6 +26,8 @@
 
 #include "common/macroblock.h"
 
+void x264_rdo_init( );
+
 int x264_macroblock_probe_skip( x264_t *h, int b_bidir );
 
 static inline int x264_macroblock_probe_pskip( x264_t *h )
@@ -37,17 +39,33 @@ void x264_macroblock_encode      ( x264_t *h );
 void x264_macroblock_write_cabac ( x264_t *h, x264_cabac_t *cb );
 void x264_macroblock_write_cavlc ( x264_t *h, bs_t *s );
 
+void x264_macroblock_encode_p8x8( x264_t *h, int i8 );
+void x264_mb_encode_i4x4( x264_t *h, int idx, int i_qscale );
+void x264_mb_encode_i8x8( x264_t *h, int idx, int i_qscale );
+void x264_mb_encode_8x8_chroma( x264_t *h, int b_inter, int i_qscale );
+
 void x264_cabac_mb_skip( x264_t *h, int b_skip );
 
-static inline int array_non_zero( int *v, int i_count )
+void x264_quant_4x4_trellis( x264_t *h, int16_t dct[4][4], int i_quant_cat,
+                             int i_qp, int i_ctxBlockCat, int b_intra );
+void x264_quant_8x8_trellis( x264_t *h, int16_t dct[8][8], int i_quant_cat,
+                             int i_qp, int b_intra );
+
+void x264_noise_reduction_update( x264_t *h );
+void x264_denoise_dct( x264_t *h, int16_t *dct );
+
+#define array_non_zero(a) array_non_zero_int(a, sizeof(a))
+static inline int array_non_zero_int( void *v, int i_count )
 {
     int i;
+    uint64_t *x = v;
+    i_count /= sizeof(uint64_t);
     for( i = 0; i < i_count; i++ )
-        if( v[i] ) return 1;
+        if( x[i] ) return 1;
     return 0;
 }
 
-static inline int array_non_zero_count( int *v, int i_count )
+static inline int array_non_zero_count( int16_t *v, int i_count )
 {
     int i;
     int i_nz;