aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/mumhash
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-06-10 14:49:13 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-06-10 14:49:13 +0100
commit363cbd0b04f6bbcaa12a0f8bd156bd0ebfaff926 (patch)
tree3bbef1f0b6fb3e0d6d40c5a7bb68a2aeb35c74fb /contrib/mumhash
parenta3efc2848155f4764bfa7ef70db13c5000d5ca6a (diff)
downloadrspamd-363cbd0b04f6bbcaa12a0f8bd156bd0ebfaff926.tar.gz
rspamd-363cbd0b04f6bbcaa12a0f8bd156bd0ebfaff926.zip
[Feature] Update mumhash
Diffstat (limited to 'contrib/mumhash')
-rw-r--r--contrib/mumhash/mum.h37
1 files changed, 18 insertions, 19 deletions
diff --git a/contrib/mumhash/mum.h b/contrib/mumhash/mum.h
index 161c5390e..ae6eec16c 100644
--- a/contrib/mumhash/mum.h
+++ b/contrib/mumhash/mum.h
@@ -56,21 +56,6 @@ typedef unsigned __int64 uint64_t;
#include <stdint.h>
#endif
-#ifdef __GNUC__
-#define _MUM_ATTRIBUTE_UNUSED __attribute__((unused))
-#ifndef __clang__
-#define _MUM_OPTIMIZE(opts) __attribute__((__optimize__ (opts)))
-#define _MUM_TARGET(opts) __attribute__((__target__ (opts)))
-#else
-#define _MUM_OPTIMIZE(opts)
-#define _MUM_TARGET(opts)
-#endif
-#else
-#define _MUM_ATTRIBUTE_UNUSED
-#define _MUM_OPTIMIZE(opts)
-#define _MUM_TARGET(opts)
-#endif
-
/* Macro saying to use 128-bit integers implemented by GCC for some
targets. */
#ifndef _MUM_USE_INT128
@@ -84,6 +69,20 @@ typedef unsigned __int64 uint64_t;
#endif
#endif
+#if defined(__GNUC__) && ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 9) || (__GNUC__ > 4))
+#define _MUM_FRESH_GCC
+#endif
+
+#if defined(__GNUC__) && !defined(__llvm__)
+#define _MUM_ATTRIBUTE_UNUSED __attribute__((unused))
+#define _MUM_OPTIMIZE(opts) __attribute__((__optimize__ (opts)))
+#define _MUM_TARGET(opts) __attribute__((__target__ (opts)))
+#else
+#define _MUM_ATTRIBUTE_UNUSED
+#define _MUM_OPTIMIZE(opts)
+#define _MUM_TARGET(opts)
+#endif
+
/* Here are different primes randomly generated with the equal
probability of their bit values. They are used to randomize input
@@ -236,7 +235,7 @@ _mum_hash_aligned (uint64_t start, const void *key, size_t len) {
result = _mum (result, _mum_unroll_prime);
}
n = len / sizeof (uint64_t);
- for (i = 0; i < n; i++)
+ for (i = 0; i < (int)n; i++)
result ^= _mum (_mum_le (((uint64_t *) str)[i]), _mum_primes[i]);
len -= n * sizeof (uint64_t); str += n * sizeof (uint64_t);
switch (len) {
@@ -282,7 +281,7 @@ _mum_final (uint64_t h) {
return h;
}
-#if defined(__x86_64__) && defined(__GNUC__) && (__GNUC__ >= 4) && (__GNUC_MINOR__ >= 9) && !defined(__clang__)
+#if defined(__x86_64__) && defined(_MUM_FRESH_GCC)
/* We want to use AVX2 insn MULX instead of generic x86-64 MULQ where
it is possible. Although on modern Intel processors MULQ takes
@@ -366,7 +365,7 @@ mum_hash_randomize (uint64_t seed) {
_mum_block_start_prime = _mum_next_factor ();
_mum_unroll_prime = _mum_next_factor ();
_mum_tail_prime = _mum_next_factor ();
- for (i = 0; i < sizeof (_mum_primes) / sizeof (uint64_t); i++)
+ for (i = 0; i < (int)(sizeof (_mum_primes) / sizeof (uint64_t)); i++)
_mum_primes[i] = _mum_next_factor ();
}
@@ -400,7 +399,7 @@ mum_hash64 (uint64_t key, uint64_t seed) {
target endianess and the unroll factor. */
static inline uint64_t
mum_hash (const void *key, size_t len, uint64_t seed) {
-#if defined(__x86_64__) && defined(__GNUC__) && (__GNUC__ >= 4) && (__GNUC_MINOR__ >= 9) && !defined(__clang__)
+#if defined(__x86_64__) && defined(_MUM_FRESH_GCC)
static int avx2_support = 0;
if (avx2_support > 0)