aboutsummaryrefslogtreecommitdiff
path: root/lib/Fuzzer/test/ThreadedLeakTest.cpp
blob: 7511071108712aea04abdc5d1354f3158d1df847 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.

// The fuzzer should find a leak in a non-main thread.
#include <cstdint>
#include <cstddef>
#include <thread>

static volatile int *Sink;

extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
  if (Size == 0) return 0;
  if (Data[0] != 'F') return 0;
  std::thread T([&] { Sink = new int; });
  T.join();
  return 0;
}