# HG changeset patch # User michael # Date 1230299171 0 # Node ID 3700af1c1f4f09f83afc4a77314429f060caed0b # Parent a11f1002f6b0f5d10c651a951d9a866352215971 Fix (rewrite) find_group3_syncmarker(). diff -r a11f1002f6b0 -r 3700af1c1f4f faxcompr.c --- a/faxcompr.c Fri Dec 26 13:39:19 2008 +0000 +++ b/faxcompr.c Fri Dec 26 13:46:11 2008 +0000 @@ -251,14 +251,14 @@ 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,