diff options
author | Ren Zibei <31380016+renzibei@users.noreply.github.com> | 2022-03-29 04:12:44 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-03-28 16:12:44 -0400 |
commit | 0c6302fe427963ec5c471d3ee660120682ab15f7 (patch) | |
tree | 06d4807b460faebcd1665b589bd61b92fd70c939 | |
parent | ca80034f59f43eddb6c4c72314572c0e212bf98f (diff) |
Replace the implementation of the Mix function in arm64 back to 128bit multiplication (#1094)
-rw-r--r-- | absl/hash/internal/hash.h | 9 |
1 files changed, 2 insertions, 7 deletions
diff --git a/absl/hash/internal/hash.h b/absl/hash/internal/hash.h index f8103334..45dfdd46 100644 --- a/absl/hash/internal/hash.h +++ b/absl/hash/internal/hash.h @@ -1090,15 +1090,10 @@ class ABSL_DLL MixingHashState : public HashStateBase<MixingHashState> { } ABSL_ATTRIBUTE_ALWAYS_INLINE static uint64_t Mix(uint64_t state, uint64_t v) { -#if defined(__aarch64__) - // On AArch64, calculating a 128-bit product is inefficient, because it - // requires a sequence of two instructions to calculate the upper and lower - // halves of the result. - using MultType = uint64_t; -#else + // Though the 128-bit product on AArch64 needs two instructions, it is + // still a good balance between speed and hash quality. using MultType = absl::conditional_t<sizeof(size_t) == 4, uint64_t, uint128>; -#endif // We do the addition in 64-bit space to make sure the 128-bit // multiplication is fast. If we were to do it as MultType the compiler has // to assume that the high word is non-zero and needs to perform 2 |