]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/llvm-project/compiler-rt/lib/sanitizer_common/sanitizer_hash.h
Merge llvm, clang, compiler-rt, libc++, libunwind, lld, lldb and openmp
[FreeBSD/FreeBSD.git] / contrib / llvm-project / compiler-rt / lib / sanitizer_common / sanitizer_hash.h
1 //===-- sanitizer_common.h --------------------------------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This file implements a simple hash function.
10 //===----------------------------------------------------------------------===//
11
12 #ifndef SANITIZER_HASH_H
13 #define SANITIZER_HASH_H
14
15 #include "sanitizer_internal_defs.h"
16
17 namespace __sanitizer {
18 class MurMur2HashBuilder {
19   static const u32 m = 0x5bd1e995;
20   static const u32 seed = 0x9747b28c;
21   static const u32 r = 24;
22   u32 h;
23
24  public:
25   explicit MurMur2HashBuilder(u32 init = 0) { h = seed ^ init; }
26   void add(u32 k) {
27     k *= m;
28     k ^= k >> r;
29     k *= m;
30     h *= m;
31     h ^= k;
32   }
33   u32 get() {
34     u32 x = h;
35     x ^= x >> 13;
36     x *= m;
37     x ^= x >> 15;
38     return x;
39   }
40 };
41 }  //namespace __sanitizer
42
43 #endif  // SANITIZER_HASH_H