From 5e5fe7dab556caa354363cd5135ac405eb25f891 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Reimar=20D=C3=B6ffinger?= Date: Sun, 31 May 2009 10:26:58 +0000 Subject: [PATCH] Use srcptr_end variable to avoid having to update both srcptr and srclen. Originally committed as revision 19048 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavcodec/lcldec.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/libavcodec/lcldec.c b/libavcodec/lcldec.c index 9ad731e56a..1a695dc4a4 100644 --- a/libavcodec/lcldec.c +++ b/libavcodec/lcldec.c @@ -75,22 +75,21 @@ static unsigned int mszh_decomp(unsigned char * srcptr, int srclen, unsigned cha { unsigned char *destptr_bak = destptr; unsigned char *destptr_end = destptr + destsize; + unsigned char *srcptr_end = srcptr + srclen; unsigned char mask = 0; unsigned char maskbit = 0; unsigned int ofs, cnt; - while (srclen > 0 && destptr < destptr_end) { + while (srcptr < srcptr_end && destptr < destptr_end) { if (maskbit == 0) { mask = *srcptr++; maskbit = 8; - srclen--; continue; } if ((mask & (1 << (--maskbit))) == 0) { if (destptr_end - destptr < 4) break; memcpy(destptr, srcptr, 4); - srclen -= 4; destptr += 4; srcptr += 4; } else { @@ -99,7 +98,6 @@ static unsigned int mszh_decomp(unsigned char * srcptr, int srclen, unsigned cha ofs += cnt * 256; cnt = ((cnt >> 3) & 0x1f) + 1; ofs &= 0x7ff; - srclen -= 2; cnt *= 4; if (destptr_end - destptr < cnt) { cnt = destptr_end - destptr;