diff options
Diffstat (limited to 'lib/crc32.c')
-rw-r--r-- | lib/crc32.c | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/lib/crc32.c b/lib/crc32.c index 02e3b31b3a79..bc5b936e9142 100644 --- a/lib/crc32.c +++ b/lib/crc32.c | |||
@@ -25,16 +25,19 @@ | |||
25 | #include <linux/module.h> | 25 | #include <linux/module.h> |
26 | #include <linux/compiler.h> | 26 | #include <linux/compiler.h> |
27 | #include <linux/types.h> | 27 | #include <linux/types.h> |
28 | #include <linux/slab.h> | ||
29 | #include <linux/init.h> | 28 | #include <linux/init.h> |
30 | #include <asm/atomic.h> | 29 | #include <asm/atomic.h> |
31 | #include "crc32defs.h" | 30 | #include "crc32defs.h" |
32 | #if CRC_LE_BITS == 8 | 31 | #if CRC_LE_BITS == 8 |
33 | #define tole(x) __constant_cpu_to_le32(x) | 32 | # define tole(x) __constant_cpu_to_le32(x) |
34 | #define tobe(x) __constant_cpu_to_be32(x) | ||
35 | #else | 33 | #else |
36 | #define tole(x) (x) | 34 | # define tole(x) (x) |
37 | #define tobe(x) (x) | 35 | #endif |
36 | |||
37 | #if CRC_BE_BITS == 8 | ||
38 | # define tobe(x) __constant_cpu_to_be32(x) | ||
39 | #else | ||
40 | # define tobe(x) (x) | ||
38 | #endif | 41 | #endif |
39 | #include "crc32table.h" | 42 | #include "crc32table.h" |
40 | 43 | ||
@@ -52,20 +55,19 @@ crc32_body(u32 crc, unsigned char const *buf, size_t len, const u32 *tab) | |||
52 | # else | 55 | # else |
53 | # define DO_CRC(x) crc = tab[((crc >> 24) ^ (x)) & 255] ^ (crc << 8) | 56 | # define DO_CRC(x) crc = tab[((crc >> 24) ^ (x)) & 255] ^ (crc << 8) |
54 | # endif | 57 | # endif |
55 | const u32 *b = (const u32 *)buf; | 58 | const u32 *b; |
56 | size_t rem_len; | 59 | size_t rem_len; |
57 | 60 | ||
58 | /* Align it */ | 61 | /* Align it */ |
59 | if (unlikely((long)b & 3 && len)) { | 62 | if (unlikely((long)buf & 3 && len)) { |
60 | u8 *p = (u8 *)b; | ||
61 | do { | 63 | do { |
62 | DO_CRC(*p++); | 64 | DO_CRC(*buf++); |
63 | } while ((--len) && ((long)p)&3); | 65 | } while ((--len) && ((long)buf)&3); |
64 | b = (u32 *)p; | ||
65 | } | 66 | } |
66 | rem_len = len & 3; | 67 | rem_len = len & 3; |
67 | /* load data 32 bits wide, xor data 32 bits wide. */ | 68 | /* load data 32 bits wide, xor data 32 bits wide. */ |
68 | len = len >> 2; | 69 | len = len >> 2; |
70 | b = (const u32 *)buf; | ||
69 | for (--b; len; --len) { | 71 | for (--b; len; --len) { |
70 | crc ^= *++b; /* use pre increment for speed */ | 72 | crc ^= *++b; /* use pre increment for speed */ |
71 | DO_CRC(0); | 73 | DO_CRC(0); |
@@ -82,6 +84,7 @@ crc32_body(u32 crc, unsigned char const *buf, size_t len, const u32 *tab) | |||
82 | } while (--len); | 84 | } while (--len); |
83 | } | 85 | } |
84 | return crc; | 86 | return crc; |
87 | #undef DO_CRC | ||
85 | } | 88 | } |
86 | #endif | 89 | #endif |
87 | /** | 90 | /** |
@@ -119,9 +122,6 @@ u32 __pure crc32_le(u32 crc, unsigned char const *p, size_t len) | |||
119 | crc = __cpu_to_le32(crc); | 122 | crc = __cpu_to_le32(crc); |
120 | crc = crc32_body(crc, p, len, tab); | 123 | crc = crc32_body(crc, p, len, tab); |
121 | return __le32_to_cpu(crc); | 124 | return __le32_to_cpu(crc); |
122 | #undef ENDIAN_SHIFT | ||
123 | #undef DO_CRC | ||
124 | |||
125 | # elif CRC_LE_BITS == 4 | 125 | # elif CRC_LE_BITS == 4 |
126 | while (len--) { | 126 | while (len--) { |
127 | crc ^= *p++; | 127 | crc ^= *p++; |
@@ -179,9 +179,6 @@ u32 __pure crc32_be(u32 crc, unsigned char const *p, size_t len) | |||
179 | crc = __cpu_to_be32(crc); | 179 | crc = __cpu_to_be32(crc); |
180 | crc = crc32_body(crc, p, len, tab); | 180 | crc = crc32_body(crc, p, len, tab); |
181 | return __be32_to_cpu(crc); | 181 | return __be32_to_cpu(crc); |
182 | #undef ENDIAN_SHIFT | ||
183 | #undef DO_CRC | ||
184 | |||
185 | # elif CRC_BE_BITS == 4 | 182 | # elif CRC_BE_BITS == 4 |
186 | while (len--) { | 183 | while (len--) { |
187 | crc ^= *p++ << 24; | 184 | crc ^= *p++ << 24; |