Signed-off-by: Mans Rullgard <mans@mansr.com>tags/n0.9
| @@ -271,7 +271,7 @@ int ff_h263_resync(MpegEncContext *s){ | |||||
| int h263_decode_motion(MpegEncContext * s, int pred, int f_code) | int h263_decode_motion(MpegEncContext * s, int pred, int f_code) | ||||
| { | { | ||||
| int code, val, sign, shift, l; | |||||
| int code, val, sign, shift; | |||||
| code = get_vlc2(&s->gb, mv_vlc.table, MV_VLC_BITS, 2); | code = get_vlc2(&s->gb, mv_vlc.table, MV_VLC_BITS, 2); | ||||
| if (code == 0) | if (code == 0) | ||||
| @@ -293,8 +293,7 @@ int h263_decode_motion(MpegEncContext * s, int pred, int f_code) | |||||
| /* modulo decoding */ | /* modulo decoding */ | ||||
| if (!s->h263_long_vectors) { | if (!s->h263_long_vectors) { | ||||
| l = INT_BIT - 5 - f_code; | |||||
| val = (val<<l)>>l; | |||||
| val = sign_extend(val, 5 + f_code); | |||||
| } else { | } else { | ||||
| /* horrible h263 long vector mode */ | /* horrible h263 long vector mode */ | ||||
| if (pred < -31 && val < -63) | if (pred < -31 && val < -63) | ||||
| @@ -657,7 +657,7 @@ void h263_encode_mb(MpegEncContext * s, | |||||
| void ff_h263_encode_motion(MpegEncContext * s, int val, int f_code) | void ff_h263_encode_motion(MpegEncContext * s, int val, int f_code) | ||||
| { | { | ||||
| int range, l, bit_size, sign, code, bits; | |||||
| int range, bit_size, sign, code, bits; | |||||
| if (val == 0) { | if (val == 0) { | ||||
| /* zero vector */ | /* zero vector */ | ||||
| @@ -667,8 +667,7 @@ void ff_h263_encode_motion(MpegEncContext * s, int val, int f_code) | |||||
| bit_size = f_code - 1; | bit_size = f_code - 1; | ||||
| range = 1 << bit_size; | range = 1 << bit_size; | ||||
| /* modulo encoding */ | /* modulo encoding */ | ||||
| l= INT_BIT - 6 - bit_size; | |||||
| val = (val<<l)>>l; | |||||
| val = sign_extend(val, 6 + bit_size); | |||||
| sign = val>>31; | sign = val>>31; | ||||
| val= (val^sign)-sign; | val= (val^sign)-sign; | ||||
| sign&=1; | sign&=1; | ||||
| @@ -54,7 +54,7 @@ static VLC mv_vlc; | |||||
| /* as H.263, but only 17 codes */ | /* as H.263, but only 17 codes */ | ||||
| static int mpeg_decode_motion(MpegEncContext *s, int fcode, int pred) | static int mpeg_decode_motion(MpegEncContext *s, int fcode, int pred) | ||||
| { | { | ||||
| int code, sign, val, l, shift; | |||||
| int code, sign, val, shift; | |||||
| code = get_vlc2(&s->gb, mv_vlc.table, MV_VLC_BITS, 2); | code = get_vlc2(&s->gb, mv_vlc.table, MV_VLC_BITS, 2); | ||||
| if (code == 0) { | if (code == 0) { | ||||
| @@ -77,9 +77,7 @@ static int mpeg_decode_motion(MpegEncContext *s, int fcode, int pred) | |||||
| val += pred; | val += pred; | ||||
| /* modulo decoding */ | /* modulo decoding */ | ||||
| l = INT_BIT - 5 - shift; | |||||
| val = (val << l) >> l; | |||||
| return val; | |||||
| return sign_extend(val, 5 + shift); | |||||
| } | } | ||||
| static inline int mpeg1_decode_block_intra(MpegEncContext *s, DCTELEM *block, int n) | static inline int mpeg1_decode_block_intra(MpegEncContext *s, DCTELEM *block, int n) | ||||