summaryrefslogtreecommitdiffstats
path: root/gnu/llvm/lib/Fuzzer/test/SimpleHashTest.cpp
diff options
context:
space:
mode:
authorpatrick <patrick@openbsd.org>2018-04-06 15:04:10 +0000
committerpatrick <patrick@openbsd.org>2018-04-06 15:04:10 +0000
commit4cabce93708ac7b290eacd7f90928878c4df8681 (patch)
treebe804aa491dea48ffa74b1a5dc60e90f8a1687aa /gnu/llvm/lib/Fuzzer/test/SimpleHashTest.cpp
parentPatch binutils 2.17 so that it passes option -Wno-null-pointer-arithmetic (diff)
downloadwireguard-openbsd-4cabce93708ac7b290eacd7f90928878c4df8681.tar.xz
wireguard-openbsd-4cabce93708ac7b290eacd7f90928878c4df8681.zip
Tedu files that got removed in LLVM 6.0.0.
Diffstat (limited to 'gnu/llvm/lib/Fuzzer/test/SimpleHashTest.cpp')
-rw-r--r--gnu/llvm/lib/Fuzzer/test/SimpleHashTest.cpp40
1 files changed, 0 insertions, 40 deletions
diff --git a/gnu/llvm/lib/Fuzzer/test/SimpleHashTest.cpp b/gnu/llvm/lib/Fuzzer/test/SimpleHashTest.cpp
deleted file mode 100644
index a3f4211ebee..00000000000
--- a/gnu/llvm/lib/Fuzzer/test/SimpleHashTest.cpp
+++ /dev/null
@@ -1,40 +0,0 @@
-// This file is distributed under the University of Illinois Open Source
-// License. See LICENSE.TXT for details.
-
-// This test computes a checksum of the data (all but the last 4 bytes),
-// and then compares the last 4 bytes with the computed value.
-// A fuzzer with cmp traces is expected to defeat this check.
-#include <cstdint>
-#include <cstdio>
-#include <cstdlib>
-#include <cstring>
-
-// A modified jenkins_one_at_a_time_hash initialized by non-zero,
-// so that simple_hash(0) != 0. See also
-// https://en.wikipedia.org/wiki/Jenkins_hash_function
-static uint32_t simple_hash(const uint8_t *Data, size_t Size) {
- uint32_t Hash = 0x12039854;
- for (uint32_t i = 0; i < Size; i++) {
- Hash += Data[i];
- Hash += (Hash << 10);
- Hash ^= (Hash >> 6);
- }
- Hash += (Hash << 3);
- Hash ^= (Hash >> 11);
- Hash += (Hash << 15);
- return Hash;
-}
-
-extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
- if (Size < 14 || Size > 64)
- return 0;
-
- uint32_t Hash = simple_hash(&Data[0], Size - 4);
- uint32_t Want = reinterpret_cast<const uint32_t *>(&Data[Size - 4])[0];
- if (Hash != Want)
- return 0;
- fprintf(stderr, "BINGO; simple_hash defeated: %x == %x\n", (unsigned int)Hash,
- (unsigned int)Want);
- exit(1);
- return 0;
-}