From: Michael Niedermayer Date: Fri, 26 Dec 2008 13:46:11 +0000 (+0000) Subject: Fix (rewrite) find_group3_syncmarker(). X-Git-Tag: v0.5~1466 X-Git-Url: https://git.libav.org/?p=libav.git;a=commitdiff_plain;h=eb12536a31897c67d5a930e5f5c2f129d721412f;ds=sidebyside Fix (rewrite) find_group3_syncmarker(). Originally committed as revision 16325 to svn://svn.ffmpeg.org/ffmpeg/trunk --- diff --git a/libavcodec/faxcompr.c b/libavcodec/faxcompr.c index 940444647f..9f1da4d279 100644 --- a/libavcodec/faxcompr.c +++ b/libavcodec/faxcompr.c @@ -251,14 +251,14 @@ static void put_line(uint8_t *dst, int size, int width, const int *runs) static int find_group3_syncmarker(GetBitContext *gb, int srcsize) { - int state = get_bits(gb, 12); - int rem = srcsize - get_bits_count(gb); - while((state & 0xFFF) != 1){ - state = (state << 1) | get_bits1(gb); - if(--rem <= 0) - return -1; + unsigned int state = -1; + srcsize -= get_bits_count(gb); + while(srcsize-- > 0){ + state+= state + get_bits1(gb); + if((state & 0xFFF) != 1) + return 0; } - return 0; + return -1; } int ff_ccitt_unpack_1d(AVCodecContext *avctx,