2 +----------------------------------------------------------------------+
4 +----------------------------------------------------------------------+
5 | Copyright (c) 2010-present Facebook, Inc. (http://www.facebook.com) |
6 +----------------------------------------------------------------------+
7 | This source file is subject to version 3.01 of the PHP license, |
8 | that is bundled with this package in the file LICENSE, and is |
9 | available through the world-wide-web at the following url: |
10 | http://www.php.net/license/3_01.txt |
11 | If you did not receive a copy of the PHP license and are unable to |
12 | obtain it through the world-wide-web, please send a note to |
13 | license@php.net so we can mail you a copy immediately. |
14 +----------------------------------------------------------------------+
16 #include "hphp/util/hash.h"
18 #include "hphp/util/assertions.h"
20 #include <folly/CpuId.h>
26 bool IsHWHashSupported() {
28 #if defined __SSE4_2__
31 static folly::CpuId cpuid
;
39 #if !defined(USE_HWCRC) || !(defined(__SSE4_2__) || \
40 defined(ENABLE_AARCH64_CRC))
42 strhash_t
hash_string_cs_fallback(const char *arKey
, uint32_t nKeyLength
) {
44 if (IsHWHashSupported()) {
45 return hash_string_cs_unaligned_crc(arKey
, nKeyLength
);
49 MurmurHash3::hash128
<true>(arKey
, nKeyLength
, 0, h
);
50 return strhash_t(h
[0] & STRHASH_MASK
);
54 strhash_t
hash_string_i_fallback(const char *arKey
, uint32_t nKeyLength
) {
56 if (IsHWHashSupported()) {
57 return hash_string_i_unaligned_crc(arKey
, nKeyLength
);
61 MurmurHash3::hash128
<false>(arKey
, nKeyLength
, 0, h
);
62 return strhash_t(h
[0] & STRHASH_MASK
);
67 ///////////////////////////////////////////////////////////////////////////////
69 // This hash is based on "A Fast, Minimal Memory, Consistent Hash
70 // Algorithm" by John Lamping and Eric Veach.
71 size_t consistent_hash(int64_t key
, size_t buckets
, int64_t salt
) {
73 assertx(buckets
< std::numeric_limits
<size_t>::max());
74 std::seed_seq seed
{key
, salt
};
75 std::minstd_rand gen
{seed
};
81 std::generate_canonical
<double, std::numeric_limits
<double>::digits
>(gen
);
82 j
= std::floor((b
+ 1) / r
);
83 } while (j
< buckets
);
87 ///////////////////////////////////////////////////////////////////////////////