From: Joakim Tjernlund Date: Wed, 10 Mar 2010 23:23:57 +0000 (-0800) Subject: inflate_fast: sout is already a short so ptr arith was off by one. X-Git-Tag: v2.6.34-rc2~77 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=51ea3f6a4571e9283e2ff79b74bcedfc2986dbe2;p=profile%2Fivi%2Fkernel-x86-ivi.git inflate_fast: sout is already a short so ptr arith was off by one. inflate_fast() can do either POST INC or PRE INC on its pointers walking the memory to decompress. Default is PRE INC. The sout pointer offset was miscalculated in one case as the calculation assumed sout was a char * This breaks inflate_fast() iff configured to do POST INC. Signed-off-by: Joakim Tjernlund Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds --- diff --git a/lib/zlib_inflate/inffast.c b/lib/zlib_inflate/inffast.c index fa62fc7a94f..2c13ecc5bb2 100644 --- a/lib/zlib_inflate/inffast.c +++ b/lib/zlib_inflate/inffast.c @@ -286,7 +286,7 @@ void inflate_fast(z_streamp strm, unsigned start) } else { /* dist == 1 or dist == 2 */ unsigned short pat16; - pat16 = *(sout-2+2*OFF); + pat16 = *(sout-1+OFF); if (dist == 1) { union uu mm; /* copy one char pattern to both bytes */