|  |  | @@ -358,8 +358,12 @@ typedef struct H264Context{ | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | uint8_t zigzag_scan[16]; | 
		
	
		
			
			|  |  |  | uint8_t field_scan[16]; | 
		
	
		
			
			|  |  |  | uint8_t zigzag_scan8x8[64]; | 
		
	
		
			
			|  |  |  | uint8_t zigzag_scan8x8_cavlc[64]; | 
		
	
		
			
			|  |  |  | const uint8_t *zigzag_scan_q0; | 
		
	
		
			
			|  |  |  | const uint8_t *field_scan_q0; | 
		
	
		
			
			|  |  |  | const uint8_t *zigzag_scan8x8_q0; | 
		
	
		
			
			|  |  |  | const uint8_t *zigzag_scan8x8_cavlc_q0; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | int x264_build; | 
		
	
		
			
			|  |  |  | }H264Context; | 
		
	
	
		
			
				|  |  | @@ -2953,6 +2957,7 @@ static void free_tables(H264Context *h){ | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | static void init_dequant8_coeff_table(H264Context *h){ | 
		
	
		
			
			|  |  |  | int i,q,x; | 
		
	
		
			
			|  |  |  | const int transpose = (h->s.dsp.h264_idct8_add != ff_h264_idct8_add_c); //FIXME ugly | 
		
	
		
			
			|  |  |  | h->dequant8_coeff[0] = h->dequant8_buffer[0]; | 
		
	
		
			
			|  |  |  | h->dequant8_coeff[1] = h->dequant8_buffer[1]; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
	
		
			
				|  |  | @@ -2966,8 +2971,9 @@ static void init_dequant8_coeff_table(H264Context *h){ | 
		
	
		
			
			|  |  |  | int shift = div6[q]; | 
		
	
		
			
			|  |  |  | int idx = rem6[q]; | 
		
	
		
			
			|  |  |  | for(x=0; x<64; x++) | 
		
	
		
			
			|  |  |  | h->dequant8_coeff[i][q][x] = ((uint32_t)dequant8_coeff_init[idx][ | 
		
	
		
			
			|  |  |  | dequant8_coeff_init_scan[((x>>1)&12) | (x&3)] ] * h->pps.scaling_matrix8[i][x]) << shift; | 
		
	
		
			
			|  |  |  | h->dequant8_coeff[i][q][transpose ? (x>>3)|((x&7)<<3) : x] = | 
		
	
		
			
			|  |  |  | ((uint32_t)dequant8_coeff_init[idx][ dequant8_coeff_init_scan[((x>>1)&12) | (x&3)] ] * | 
		
	
		
			
			|  |  |  | h->pps.scaling_matrix8[i][x]) << shift; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | } | 
		
	
	
		
			
				|  |  | @@ -4317,14 +4323,31 @@ static int decode_slice_header(H264Context *h){ | 
		
	
		
			
			|  |  |  | #define T(x) (x>>2) | ((x<<2) & 0xF) | 
		
	
		
			
			|  |  |  | h->zigzag_scan[i] = T(zigzag_scan[i]); | 
		
	
		
			
			|  |  |  | h-> field_scan[i] = T( field_scan[i]); | 
		
	
		
			
			|  |  |  | #undef T | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | if(s->dsp.h264_idct8_add == ff_h264_idct8_add_c){ | 
		
	
		
			
			|  |  |  | memcpy(h->zigzag_scan8x8, zigzag_scan8x8, 64*sizeof(uint8_t)); | 
		
	
		
			
			|  |  |  | memcpy(h->zigzag_scan8x8_cavlc, zigzag_scan8x8_cavlc, 64*sizeof(uint8_t)); | 
		
	
		
			
			|  |  |  | }else{ | 
		
	
		
			
			|  |  |  | int i; | 
		
	
		
			
			|  |  |  | for(i=0; i<64; i++){ | 
		
	
		
			
			|  |  |  | #define T(x) (x>>3) | ((x&7)<<3) | 
		
	
		
			
			|  |  |  | h->zigzag_scan8x8[i] = T(zigzag_scan8x8[i]); | 
		
	
		
			
			|  |  |  | h->zigzag_scan8x8_cavlc[i] = T(zigzag_scan8x8_cavlc[i]); | 
		
	
		
			
			|  |  |  | #undef T | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | if(h->sps.transform_bypass){ //FIXME same ugly | 
		
	
		
			
			|  |  |  | h->zigzag_scan_q0 = zigzag_scan; | 
		
	
		
			
			|  |  |  | h->field_scan_q0 = field_scan; | 
		
	
		
			
			|  |  |  | h->zigzag_scan8x8_q0 = zigzag_scan8x8; | 
		
	
		
			
			|  |  |  | h->zigzag_scan8x8_cavlc_q0 = zigzag_scan8x8_cavlc; | 
		
	
		
			
			|  |  |  | }else{ | 
		
	
		
			
			|  |  |  | h->zigzag_scan_q0 = h->zigzag_scan; | 
		
	
		
			
			|  |  |  | h->field_scan_q0 = h->field_scan; | 
		
	
		
			
			|  |  |  | h->zigzag_scan8x8_q0 = h->zigzag_scan8x8; | 
		
	
		
			
			|  |  |  | h->zigzag_scan8x8_cavlc_q0 = h->zigzag_scan8x8_cavlc; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | alloc_tables(h); | 
		
	
	
		
			
				|  |  | @@ -5101,7 +5124,7 @@ decode_intra_mb: | 
		
	
		
			
			|  |  |  | int i8x8, i4x4, chroma_idx; | 
		
	
		
			
			|  |  |  | int chroma_qp, dquant; | 
		
	
		
			
			|  |  |  | GetBitContext *gb= IS_INTRA(mb_type) ? h->intra_gb_ptr : h->inter_gb_ptr; | 
		
	
		
			
			|  |  |  | const uint8_t *scan, *dc_scan; | 
		
	
		
			
			|  |  |  | const uint8_t *scan, *scan8x8, *dc_scan; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | //        fill_non_zero_count_cache(h); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
	
		
			
				|  |  | @@ -5112,6 +5135,7 @@ decode_intra_mb: | 
		
	
		
			
			|  |  |  | scan= s->qscale ? h->zigzag_scan : h->zigzag_scan_q0; | 
		
	
		
			
			|  |  |  | dc_scan= luma_dc_zigzag_scan; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | scan8x8= s->qscale ? h->zigzag_scan8x8_cavlc : h->zigzag_scan8x8_cavlc_q0; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | dquant= get_se_golomb(&s->gb); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
	
		
			
				|  |  | @@ -5153,7 +5177,7 @@ decode_intra_mb: | 
		
	
		
			
			|  |  |  | DCTELEM *buf = &h->mb[64*i8x8]; | 
		
	
		
			
			|  |  |  | uint8_t *nnz; | 
		
	
		
			
			|  |  |  | for(i4x4=0; i4x4<4; i4x4++){ | 
		
	
		
			
			|  |  |  | if( decode_residual(h, gb, buf, i4x4+4*i8x8, zigzag_scan8x8_cavlc+16*i4x4, | 
		
	
		
			
			|  |  |  | if( decode_residual(h, gb, buf, i4x4+4*i8x8, scan8x8+16*i4x4, | 
		
	
		
			
			|  |  |  | h->dequant8_coeff[IS_INTRA( mb_type ) ? 0:1][s->qscale], 16) <0 ) | 
		
	
		
			
			|  |  |  | return -1; | 
		
	
		
			
			|  |  |  | } | 
		
	
	
		
			
				|  |  | @@ -6144,7 +6168,7 @@ decode_intra_mb: | 
		
	
		
			
			|  |  |  | s->current_picture.mb_type[mb_xy]= mb_type; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | if( cbp || IS_INTRA16x16( mb_type ) ) { | 
		
	
		
			
			|  |  |  | const uint8_t *scan, *dc_scan; | 
		
	
		
			
			|  |  |  | const uint8_t *scan, *scan8x8, *dc_scan; | 
		
	
		
			
			|  |  |  | int dqp; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | if(IS_INTERLACED(mb_type)){ | 
		
	
	
		
			
				|  |  | @@ -6154,6 +6178,7 @@ decode_intra_mb: | 
		
	
		
			
			|  |  |  | scan= s->qscale ? h->zigzag_scan : h->zigzag_scan_q0; | 
		
	
		
			
			|  |  |  | dc_scan= luma_dc_zigzag_scan; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | scan8x8= s->qscale ? h->zigzag_scan8x8 : h->zigzag_scan8x8_q0; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | h->last_qscale_diff = dqp = decode_cabac_mb_dqp( h ); | 
		
	
		
			
			|  |  |  | if( dqp == INT_MIN ){ | 
		
	
	
		
			
				|  |  | @@ -6187,7 +6212,7 @@ decode_intra_mb: | 
		
	
		
			
			|  |  |  | if( cbp & (1<<i8x8) ) { | 
		
	
		
			
			|  |  |  | if( IS_8x8DCT(mb_type) ) { | 
		
	
		
			
			|  |  |  | if( decode_cabac_residual(h, h->mb + 64*i8x8, 5, 4*i8x8, | 
		
	
		
			
			|  |  |  | zigzag_scan8x8, h->dequant8_coeff[IS_INTRA( mb_type ) ? 0:1][s->qscale], 64) < 0 ) | 
		
	
		
			
			|  |  |  | scan8x8, h->dequant8_coeff[IS_INTRA( mb_type ) ? 0:1][s->qscale], 64) < 0 ) | 
		
	
		
			
			|  |  |  | return -1; | 
		
	
		
			
			|  |  |  | } else | 
		
	
		
			
			|  |  |  | for( i4x4 = 0; i4x4 < 4; i4x4++ ) { | 
		
	
	
		
			
				|  |  | 
 |