|
|
@ -685,9 +685,7 @@ static inline int pred_intra_mode(H264Context *h, int n){ |
|
|
|
const int top = h->intra4x4_pred_mode_cache[index8 - 8]; |
|
|
|
const int top = h->intra4x4_pred_mode_cache[index8 - 8]; |
|
|
|
const int min= FFMIN(left, top); |
|
|
|
const int min= FFMIN(left, top); |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("mode:%d %d min:%d\n", left ,top, min); |
|
|
|
printf("mode:%d %d min:%d\n", left ,top, min); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(min<0) return DC_PRED; |
|
|
|
if(min<0) return DC_PRED; |
|
|
|
else return min; |
|
|
|
else return min; |
|
|
@ -726,9 +724,7 @@ static inline int pred_non_zero_count(H264Context *h, int n){ |
|
|
|
|
|
|
|
|
|
|
|
if(i<64) i= (i+1)>>1; |
|
|
|
if(i<64) i= (i+1)>>1; |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("pred_nnz L%X T%X n%d s%d P%X\n", left, top, n, scan8[n], i&31); |
|
|
|
printf("pred_nnz L%X T%X n%d s%d P%X\n", left, top, n, scan8[n], i&31); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return i&31; |
|
|
|
return i&31; |
|
|
|
} |
|
|
|
} |
|
|
@ -740,9 +736,8 @@ static inline int fetch_diagonal_mv(H264Context *h, const int16_t **C, int i, in |
|
|
|
*C= h->mv_cache[list][ i - 8 + part_width ]; |
|
|
|
*C= h->mv_cache[list][ i - 8 + part_width ]; |
|
|
|
return topright_ref; |
|
|
|
return topright_ref; |
|
|
|
}else{ |
|
|
|
}else{ |
|
|
|
#ifdef TRACE |
|
|
|
tprintf("topright MV not available\n"); |
|
|
|
printf("topright MV not available\n"); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
*C= h->mv_cache[list][ i - 8 - 1 ]; |
|
|
|
*C= h->mv_cache[list][ i - 8 - 1 ]; |
|
|
|
return h->ref_cache[list][ i - 8 - 1 ]; |
|
|
|
return h->ref_cache[list][ i - 8 - 1 ]; |
|
|
|
} |
|
|
|
} |
|
|
@ -802,9 +797,7 @@ static inline void pred_motion(H264Context * const h, int n, int part_width, int |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("pred_motion (%2d %2d %2d) (%2d %2d %2d) (%2d %2d %2d) -> (%2d %2d %2d) at %2d %2d %d list %d\n", top_ref, B[0], B[1], diagonal_ref, C[0], C[1], left_ref, A[0], A[1], ref, *mx, *my, s->mb_x, s->mb_y, n, list); |
|
|
|
printf("pred_motion (%2d %2d %2d) (%2d %2d %2d) (%2d %2d %2d) -> (%2d %2d %2d) at %2d %2d %d list %d\n", top_ref, B[0], B[1], diagonal_ref, C[0], C[1], left_ref, A[0], A[1], ref, *mx, *my, s->mb_x, s->mb_y, n, list); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
@ -819,9 +812,7 @@ static inline void pred_16x8_motion(H264Context * const h, int n, int list, int |
|
|
|
const int top_ref= h->ref_cache[list][ scan8[0] - 8 ]; |
|
|
|
const int top_ref= h->ref_cache[list][ scan8[0] - 8 ]; |
|
|
|
const int16_t * const B= h->mv_cache[list][ scan8[0] - 8 ]; |
|
|
|
const int16_t * const B= h->mv_cache[list][ scan8[0] - 8 ]; |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("pred_16x8: (%2d %2d %2d) at %2d %2d %d list %d", top_ref, B[0], B[1], s->mb_x, s->mb_y, n, list); |
|
|
|
printf("pred_16x8: (%2d %2d %2d) at %2d %2d %d list %d", top_ref, B[0], B[1], s->mb_x, s->mb_y, n, list); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(top_ref == ref){ |
|
|
|
if(top_ref == ref){ |
|
|
|
*mx= B[0]; |
|
|
|
*mx= B[0]; |
|
|
@ -832,9 +823,7 @@ printf("pred_16x8: (%2d %2d %2d) at %2d %2d %d list %d", top_ref, B[0], B[1], s- |
|
|
|
const int left_ref= h->ref_cache[list][ scan8[8] - 1 ]; |
|
|
|
const int left_ref= h->ref_cache[list][ scan8[8] - 1 ]; |
|
|
|
const int16_t * const A= h->mv_cache[list][ scan8[8] - 1 ]; |
|
|
|
const int16_t * const A= h->mv_cache[list][ scan8[8] - 1 ]; |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("pred_16x8: (%2d %2d %2d) at %2d %2d %d list %d", left_ref, A[0], A[1], s->mb_x, s->mb_y, n, list); |
|
|
|
printf("pred_16x8: (%2d %2d %2d) at %2d %2d %d list %d", left_ref, A[0], A[1], s->mb_x, s->mb_y, n, list); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(left_ref == ref){ |
|
|
|
if(left_ref == ref){ |
|
|
|
*mx= A[0]; |
|
|
|
*mx= A[0]; |
|
|
@ -859,9 +848,7 @@ static inline void pred_8x16_motion(H264Context * const h, int n, int list, int |
|
|
|
const int left_ref= h->ref_cache[list][ scan8[0] - 1 ]; |
|
|
|
const int left_ref= h->ref_cache[list][ scan8[0] - 1 ]; |
|
|
|
const int16_t * const A= h->mv_cache[list][ scan8[0] - 1 ]; |
|
|
|
const int16_t * const A= h->mv_cache[list][ scan8[0] - 1 ]; |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("pred_8x16: (%2d %2d %2d) at %2d %2d %d list %d", left_ref, A[0], A[1], s->mb_x, s->mb_y, n, list); |
|
|
|
printf("pred_8x16: (%2d %2d %2d) at %2d %2d %d list %d", left_ref, A[0], A[1], s->mb_x, s->mb_y, n, list); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(left_ref == ref){ |
|
|
|
if(left_ref == ref){ |
|
|
|
*mx= A[0]; |
|
|
|
*mx= A[0]; |
|
|
@ -874,9 +861,7 @@ printf("pred_8x16: (%2d %2d %2d) at %2d %2d %d list %d", left_ref, A[0], A[1], s |
|
|
|
|
|
|
|
|
|
|
|
diagonal_ref= fetch_diagonal_mv(h, &C, scan8[4], list, 2); |
|
|
|
diagonal_ref= fetch_diagonal_mv(h, &C, scan8[4], list, 2); |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("pred_8x16: (%2d %2d %2d) at %2d %2d %d list %d", diagonal_ref, C[0], C[1], s->mb_x, s->mb_y, n, list); |
|
|
|
printf("pred_8x16: (%2d %2d %2d) at %2d %2d %d list %d", diagonal_ref, C[0], C[1], s->mb_x, s->mb_y, n, list); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(diagonal_ref == ref){
|
|
|
|
if(diagonal_ref == ref){
|
|
|
|
*mx= C[0]; |
|
|
|
*mx= C[0]; |
|
|
@ -894,9 +879,7 @@ static inline void pred_pskip_motion(H264Context * const h, int * const mx, int |
|
|
|
const int top_ref = h->ref_cache[0][ scan8[0] - 8 ]; |
|
|
|
const int top_ref = h->ref_cache[0][ scan8[0] - 8 ]; |
|
|
|
const int left_ref= h->ref_cache[0][ scan8[0] - 1 ]; |
|
|
|
const int left_ref= h->ref_cache[0][ scan8[0] - 1 ]; |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("pred_pskip: (%d) (%d) at %2d %2d", top_ref, left_ref, s->mb_x, s->mb_y); |
|
|
|
printf("pred_pskip: (%d) (%d) at %2d %2d", top_ref, left_ref, s->mb_x, s->mb_y); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(top_ref == PART_NOT_AVAILABLE || left_ref == PART_NOT_AVAILABLE |
|
|
|
if(top_ref == PART_NOT_AVAILABLE || left_ref == PART_NOT_AVAILABLE |
|
|
|
|| (top_ref == 0 && *(uint32_t*)h->mv_cache[0][ scan8[0] - 8 ] == 0) |
|
|
|
|| (top_ref == 0 && *(uint32_t*)h->mv_cache[0][ scan8[0] - 8 ] == 0) |
|
|
@ -1088,9 +1071,7 @@ static int decode_rbsp_trailing(uint8_t *src){ |
|
|
|
int v= *src; |
|
|
|
int v= *src; |
|
|
|
int r; |
|
|
|
int r; |
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("rbsp trailing %X\n", v); |
|
|
|
printf("rbsp trailing %X\n", v); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for(r=1; r<9; r++){ |
|
|
|
for(r=1; r<9; r++){ |
|
|
|
if(v&1) return r; |
|
|
|
if(v&1) return r; |
|
|
@ -3073,9 +3054,7 @@ static int decode_residual(H264Context *h, GetBitContext *gb, DCTELEM *block, in |
|
|
|
return 0; |
|
|
|
return 0; |
|
|
|
|
|
|
|
|
|
|
|
trailing_ones= coeff_token&3; |
|
|
|
trailing_ones= coeff_token&3; |
|
|
|
#ifdef TRACE |
|
|
|
tprintf("trailing:%d, total:%d\n", trailing_ones, total_coeff); |
|
|
|
printf("trailing:%d, total:%d\n", trailing_ones, total_coeff); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
assert(total_coeff<=16); |
|
|
|
assert(total_coeff<=16); |
|
|
|
|
|
|
|
|
|
|
|
for(i=0; i<trailing_ones; i++){ |
|
|
|
for(i=0; i<trailing_ones; i++){ |
|
|
@ -3119,9 +3098,7 @@ static int decode_residual(H264Context *h, GetBitContext *gb, DCTELEM *block, in |
|
|
|
if((2+level_code)>>1) > (3<<(suffix_length-1)) && suffix_length<6) suffix_length++; |
|
|
|
if((2+level_code)>>1) > (3<<(suffix_length-1)) && suffix_length<6) suffix_length++; |
|
|
|
? == prefix > 2 or sth |
|
|
|
? == prefix > 2 or sth |
|
|
|
#endif |
|
|
|
#endif |
|
|
|
#ifdef TRACE |
|
|
|
tprintf("level: %d suffix_length:%d\n", level[i], suffix_length); |
|
|
|
printf("level: %d suffix_length:%d\n", level[i], suffix_length); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if(total_coeff == max_coeff) |
|
|
|
if(total_coeff == max_coeff) |
|
|
@ -3190,9 +3167,7 @@ static int decode_mb(H264Context *h){ |
|
|
|
|
|
|
|
|
|
|
|
memset(h->mb, 0, sizeof(int16_t)*24*16); //FIXME avoid if allready clear (move after skip handlong?
|
|
|
|
memset(h->mb, 0, sizeof(int16_t)*24*16); //FIXME avoid if allready clear (move after skip handlong?
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef TRACE |
|
|
|
tprintf("pic:%d mb:%d/%d\n", h->frame_num, s->mb_x, s->mb_y); |
|
|
|
printf("pic:%d mb:%d/%d\n", h->frame_num, s->mb_x, s->mb_y); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(h->slice_type != I_TYPE && h->slice_type != SI_TYPE){ |
|
|
|
if(h->slice_type != I_TYPE && h->slice_type != SI_TYPE){ |
|
|
|
if(s->mb_skip_run==-1) |
|
|
|
if(s->mb_skip_run==-1) |
|
|
@ -3410,9 +3385,8 @@ decode_intra_mb: |
|
|
|
pred_motion(h, index, block_width, list, h->ref_cache[list][ scan8[index] ], &mx, &my); |
|
|
|
pred_motion(h, index, block_width, list, h->ref_cache[list][ scan8[index] ], &mx, &my); |
|
|
|
mx += get_se_golomb(&s->gb); |
|
|
|
mx += get_se_golomb(&s->gb); |
|
|
|
my += get_se_golomb(&s->gb); |
|
|
|
my += get_se_golomb(&s->gb); |
|
|
|
#ifdef TRACE |
|
|
|
tprintf("final mv:%d %d\n", mx, my); |
|
|
|
printf("final mv:%d %d\n", mx, my); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
if(IS_SUB_8X8(sub_mb_type)){ |
|
|
|
if(IS_SUB_8X8(sub_mb_type)){ |
|
|
|
mv_cache[ 0 ][0]= mv_cache[ 1 ][0]=
|
|
|
|
mv_cache[ 0 ][0]= mv_cache[ 1 ][0]=
|
|
|
|
mv_cache[ 8 ][0]= mv_cache[ 9 ][0]= mx; |
|
|
|
mv_cache[ 8 ][0]= mv_cache[ 9 ][0]= mx; |
|
|
@ -3454,9 +3428,8 @@ printf("final mv:%d %d\n", mx, my); |
|
|
|
pred_motion(h, 0, 4, list, h->ref_cache[list][ scan8[0] ], &mx, &my); |
|
|
|
pred_motion(h, 0, 4, list, h->ref_cache[list][ scan8[0] ], &mx, &my); |
|
|
|
mx += get_se_golomb(&s->gb); |
|
|
|
mx += get_se_golomb(&s->gb); |
|
|
|
my += get_se_golomb(&s->gb); |
|
|
|
my += get_se_golomb(&s->gb); |
|
|
|
#ifdef TRACE |
|
|
|
tprintf("final mv:%d %d\n", mx, my); |
|
|
|
printf("final mv:%d %d\n", mx, my); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
fill_rectangle(h->mv_cache[list][ scan8[0] ], 4, 4, 8, (mx&0xFFFF) + (my<<16), 4); |
|
|
|
fill_rectangle(h->mv_cache[list][ scan8[0] ], 4, 4, 8, (mx&0xFFFF) + (my<<16), 4); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -3478,9 +3451,8 @@ printf("final mv:%d %d\n", mx, my); |
|
|
|
pred_16x8_motion(h, 8*i, list, h->ref_cache[list][scan8[0] + 16*i], &mx, &my); |
|
|
|
pred_16x8_motion(h, 8*i, list, h->ref_cache[list][scan8[0] + 16*i], &mx, &my); |
|
|
|
mx += get_se_golomb(&s->gb); |
|
|
|
mx += get_se_golomb(&s->gb); |
|
|
|
my += get_se_golomb(&s->gb); |
|
|
|
my += get_se_golomb(&s->gb); |
|
|
|
#ifdef TRACE |
|
|
|
tprintf("final mv:%d %d\n", mx, my); |
|
|
|
printf("final mv:%d %d\n", mx, my); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
fill_rectangle(h->mv_cache[list][ scan8[0] + 16*i ], 4, 2, 8, (mx&0xFFFF) + (my<<16), 4); |
|
|
|
fill_rectangle(h->mv_cache[list][ scan8[0] + 16*i ], 4, 2, 8, (mx&0xFFFF) + (my<<16), 4); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -3503,9 +3475,8 @@ printf("final mv:%d %d\n", mx, my); |
|
|
|
pred_8x16_motion(h, i*4, list, h->ref_cache[list][ scan8[0] + 2*i ], &mx, &my); |
|
|
|
pred_8x16_motion(h, i*4, list, h->ref_cache[list][ scan8[0] + 2*i ], &mx, &my); |
|
|
|
mx += get_se_golomb(&s->gb); |
|
|
|
mx += get_se_golomb(&s->gb); |
|
|
|
my += get_se_golomb(&s->gb); |
|
|
|
my += get_se_golomb(&s->gb); |
|
|
|
#ifdef TRACE |
|
|
|
tprintf("final mv:%d %d\n", mx, my); |
|
|
|
printf("final mv:%d %d\n", mx, my); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
fill_rectangle(h->mv_cache[list][ scan8[0] + 2*i ], 2, 4, 8, (mx&0xFFFF) + (my<<16), 4); |
|
|
|
fill_rectangle(h->mv_cache[list][ scan8[0] + 2*i ], 2, 4, 8, (mx&0xFFFF) + (my<<16), 4); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -3655,9 +3626,8 @@ static int decode_slice(H264Context *h){ |
|
|
|
s->mb_x=0; |
|
|
|
s->mb_x=0; |
|
|
|
ff_draw_horiz_band(s, 16*s->mb_y, 16); |
|
|
|
ff_draw_horiz_band(s, 16*s->mb_y, 16); |
|
|
|
if(++s->mb_y >= s->mb_height){ |
|
|
|
if(++s->mb_y >= s->mb_height){ |
|
|
|
#ifdef TRACE |
|
|
|
tprintf("slice end %d %d\n", get_bits_count(&s->gb), s->gb.size_in_bits); |
|
|
|
printf("slice end %d %d\n", get_bits_count(&s->gb), s->gb.size_in_bits); |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
if(get_bits_count(&s->gb) == s->gb.size_in_bits){ |
|
|
|
if(get_bits_count(&s->gb) == s->gb.size_in_bits){ |
|
|
|
ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x-1, s->mb_y, (AC_END|DC_END|MV_END)&part_mask); |
|
|
|
ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x-1, s->mb_y, (AC_END|DC_END|MV_END)&part_mask); |
|
|
|
|
|
|
|
|
|
|
|