lib/lzo/lzo1x_compress.c: fix alignment bug in lzo-rle
authorDave Rodgman <dave.rodgman@arm.com>
Wed, 25 Sep 2019 23:48:24 +0000 (16:48 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Thu, 26 Sep 2019 00:51:41 +0000 (17:51 -0700)
Fix an unaligned access which breaks on platforms where this is not
permitted (e.g., Sparc).

Link: http://lkml.kernel.org/r/20190912145502.35229-1-dave.rodgman@arm.com
Signed-off-by: Dave Rodgman <dave.rodgman@arm.com>
Cc: Dave Rodgman <dave.rodgman@arm.com>
Cc: Markus F.X.J. Oberhumer <markus@oberhumer.com>
Cc: Minchan Kim <minchan@kernel.org>
Cc: <stable@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
lib/lzo/lzo1x_compress.c

index ba16c08e8cb921c618dd876e5c8166f101ac6396..717c940112f9d71ecb1fab13008a2d2cdb31522c 100644 (file)
@@ -83,17 +83,19 @@ next:
                                        ALIGN((uintptr_t)ir, 4)) &&
                                        (ir < limit) && (*ir == 0))
                                ir++;
-                       for (; (ir + 4) <= limit; ir += 4) {
-                               dv = *((u32 *)ir);
-                               if (dv) {
+                       if (IS_ALIGNED((uintptr_t)ir, 4)) {
+                               for (; (ir + 4) <= limit; ir += 4) {
+                                       dv = *((u32 *)ir);
+                                       if (dv) {
 #  if defined(__LITTLE_ENDIAN)
-                                       ir += __builtin_ctz(dv) >> 3;
+                                               ir += __builtin_ctz(dv) >> 3;
 #  elif defined(__BIG_ENDIAN)
-                                       ir += __builtin_clz(dv) >> 3;
+                                               ir += __builtin_clz(dv) >> 3;
 #  else
 #    error "missing endian definition"
 #  endif
-                                       break;
+                                               break;
+                                       }
                                }
                        }
 #endif