{
u32 v = 0;
-#if __x86_64__
+#if defined(__x86_64__)
for (; len >= 8; len -= 8, s += 8)
v = _mm_crc32_u64 (v, *((u64 *) s));
#else
/* workaround weird GCC bug when using _mm_crc32_u32
which happens with -O2 optimization */
- volatile ("":::"memory");
+#if !defined (__i686__)
+ asm volatile ("":::"memory");
+#endif
#endif
for (; len >= 4; len -= 4, s += 4)