Commit 1e638e32 authored by michael's avatar michael

cleanup


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@2562 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 0cc5b30e
...@@ -1236,7 +1236,7 @@ void h263_encode_mb(MpegEncContext * s, ...@@ -1236,7 +1236,7 @@ void h263_encode_mb(MpegEncContext * s,
} }
#endif #endif
int ff_h263_loop_filter(MpegEncContext * s){ void ff_h263_loop_filter(MpegEncContext * s){
int qp_c; int qp_c;
const int linesize = s->linesize; const int linesize = s->linesize;
const int uvlinesize= s->uvlinesize; const int uvlinesize= s->uvlinesize;
...@@ -3572,6 +3572,10 @@ static void preview_obmc(MpegEncContext *s){ ...@@ -3572,6 +3572,10 @@ static void preview_obmc(MpegEncContext *s){
}else{ }else{
get_vlc2(&s->gb, cbpy_vlc.table, CBPY_VLC_BITS, 1); get_vlc2(&s->gb, cbpy_vlc.table, CBPY_VLC_BITS, 1);
if (cbpc & 8) { if (cbpc & 8) {
if(s->modified_quant){
if(get_bits1(&s->gb)) skip_bits(&s->gb, 1);
else skip_bits(&s->gb, 5);
}else
skip_bits(&s->gb, 2); skip_bits(&s->gb, 2);
} }
...@@ -3624,12 +3628,24 @@ end: ...@@ -3624,12 +3628,24 @@ end:
s->gb= gb; s->gb= gb;
} }
static void h263_decode_dquant(MpegEncContext *s){
static const int8_t quant_tab[4] = { -1, -2, 1, 2 };
if(s->modified_quant){
if(get_bits1(&s->gb))
s->qscale= modified_quant_tab[get_bits1(&s->gb)][ s->qscale ];
else
s->qscale= get_bits(&s->gb, 5);
}else
s->qscale += quant_tab[get_bits(&s->gb, 2)];
ff_set_qscale(s, s->qscale);
}
int ff_h263_decode_mb(MpegEncContext *s, int ff_h263_decode_mb(MpegEncContext *s,
DCTELEM block[6][64]) DCTELEM block[6][64])
{ {
int cbpc, cbpy, i, cbp, pred_x, pred_y, mx, my, dquant; int cbpc, cbpy, i, cbp, pred_x, pred_y, mx, my, dquant;
int16_t *mot_val; int16_t *mot_val;
static int8_t quant_tab[4] = { -1, -2, 1, 2 };
const int xy= s->mb_x + s->mb_y * s->mb_stride; const int xy= s->mb_x + s->mb_y * s->mb_stride;
assert(!s->h263_pred); assert(!s->h263_pred);
...@@ -3668,14 +3684,7 @@ int ff_h263_decode_mb(MpegEncContext *s, ...@@ -3668,14 +3684,7 @@ int ff_h263_decode_mb(MpegEncContext *s,
cbp = (cbpc & 3) | (cbpy << 2); cbp = (cbpc & 3) | (cbpy << 2);
if (dquant) { if (dquant) {
if(s->modified_quant){ h263_decode_dquant(s);
if(get_bits1(&s->gb))
s->qscale= modified_quant_tab[get_bits1(&s->gb)][ s->qscale ];
else
s->qscale= get_bits(&s->gb, 5);
}else
s->qscale += quant_tab[get_bits(&s->gb, 2)];
ff_set_qscale(s, s->qscale);
} }
s->mv_dir = MV_DIR_FORWARD; s->mv_dir = MV_DIR_FORWARD;
...@@ -3783,14 +3792,7 @@ int ff_h263_decode_mb(MpegEncContext *s, ...@@ -3783,14 +3792,7 @@ int ff_h263_decode_mb(MpegEncContext *s,
assert(!s->mb_intra); assert(!s->mb_intra);
if(IS_QUANT(mb_type)){ if(IS_QUANT(mb_type)){
if(s->modified_quant){ //FIXME factorize h263_decode_dquant(s);
if(get_bits1(&s->gb))
s->qscale= modified_quant_tab[get_bits1(&s->gb)][ s->qscale ];
else
s->qscale= get_bits(&s->gb, 5);
}else
s->qscale += quant_tab[get_bits(&s->gb, 2)];
ff_set_qscale(s, s->qscale);
} }
if(IS_DIRECT(mb_type)){ if(IS_DIRECT(mb_type)){
...@@ -3857,14 +3859,7 @@ intra: ...@@ -3857,14 +3859,7 @@ intra:
} }
cbp = (cbpc & 3) | (cbpy << 2); cbp = (cbpc & 3) | (cbpy << 2);
if (dquant) { if (dquant) {
if(s->modified_quant){ h263_decode_dquant(s);
if(get_bits1(&s->gb))
s->qscale= modified_quant_tab[get_bits1(&s->gb)][ s->qscale ];
else
s->qscale= get_bits(&s->gb, 5);
}else
s->qscale += quant_tab[get_bits(&s->gb, 2)];
ff_set_qscale(s, s->qscale);
} }
} }
......
...@@ -857,7 +857,7 @@ int h263_decode_picture_header(MpegEncContext *s); ...@@ -857,7 +857,7 @@ int h263_decode_picture_header(MpegEncContext *s);
int ff_h263_decode_gob_header(MpegEncContext *s); int ff_h263_decode_gob_header(MpegEncContext *s);
int ff_mpeg4_decode_picture_header(MpegEncContext * s, GetBitContext *gb); int ff_mpeg4_decode_picture_header(MpegEncContext * s, GetBitContext *gb);
void ff_h263_update_motion_val(MpegEncContext * s); void ff_h263_update_motion_val(MpegEncContext * s);
int ff_h263_loop_filter(MpegEncContext * s); void ff_h263_loop_filter(MpegEncContext * s);
void ff_set_qscale(MpegEncContext * s, int qscale); void ff_set_qscale(MpegEncContext * s, int qscale);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment