]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - lib/lzo/lzodefs.h
lib/lzo: Update LZO compression to current upstream version
[karo-tx-linux.git] / lib / lzo / lzodefs.h
index b6d482c492efa5a0d2a8e5bf764864552d0698f2..6710b83ce72ed094113a23fab890b94e43fe1151 100644 (file)
@@ -1,19 +1,37 @@
 /*
  *  lzodefs.h -- architecture, OS and compiler specific defines
  *
- *  Copyright (C) 1996-2005 Markus F.X.J. Oberhumer <markus@oberhumer.com>
+ *  Copyright (C) 1996-2012 Markus F.X.J. Oberhumer <markus@oberhumer.com>
  *
  *  The full LZO package can be found at:
  *  http://www.oberhumer.com/opensource/lzo/
  *
- *  Changed for kernel use by:
+ *  Changed for Linux kernel use by:
  *  Nitin Gupta <nitingupta910@gmail.com>
  *  Richard Purdie <rpurdie@openedhand.com>
  */
 
-#define LZO_VERSION            0x2020
-#define LZO_VERSION_STRING     "2.02"
-#define LZO_VERSION_DATE       "Oct 17 2005"
+
+#define COPY4(dst, src)        \
+               put_unaligned(get_unaligned((const u32 *)(src)), (u32 *)(dst))
+#if defined(__x86_64__)
+#define COPY8(dst, src)        \
+               put_unaligned(get_unaligned((const u64 *)(src)), (u64 *)(dst))
+#else
+#define COPY8(dst, src)        \
+               COPY4(dst, src); COPY4((dst) + 4, (src) + 4)
+#endif
+
+#if defined(__BIG_ENDIAN) && defined(__LITTLE_ENDIAN)
+#error "conflicting endian definitions"
+#elif defined(__x86_64__)
+#define LZO_USE_CTZ64  1
+#define LZO_USE_CTZ32  1
+#elif defined(__i386__) || defined(__powerpc__)
+#define LZO_USE_CTZ32  1
+#elif defined(__arm__) && (__LINUX_ARM_ARCH__ >= 5)
+#define LZO_USE_CTZ32  1
+#endif
 
 #define M1_MAX_OFFSET  0x0400
 #define M2_MAX_OFFSET  0x0800
 #define M3_MARKER      32
 #define M4_MARKER      16
 
-#define D_BITS         14
-#define D_MASK         ((1u << D_BITS) - 1)
+#define lzo_dict_t      unsigned short
+#define D_BITS         13
+#define D_SIZE         (1u << D_BITS)
+#define D_MASK         (D_SIZE - 1)
 #define D_HIGH         ((D_MASK >> 1) + 1)
-
-#define DX2(p, s1, s2) (((((size_t)((p)[2]) << (s2)) ^ (p)[1]) \
-                                                       << (s1)) ^ (p)[0])
-#define DX3(p, s1, s2, s3)     ((DX2((p)+1, s2, s3) << (s1)) ^ (p)[0])