Files
clang-p2996/compiler-rt/test/fuzzer/Reject.cpp
Kostya Serebryany 92fb310151 [libFuzzer] Extend the fuzz target intarface to allow -1 return value.
With this change, fuzz targets may choose to return -1
to indicate that the input should not be added to the corpus
regardless of the coverage it generated.

Reviewed By: morehouse

Differential Revision: https://reviews.llvm.org/D128749
2022-06-30 13:21:27 -07:00

24 lines
699 B
C++

// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
// Tests how the fuzzer rejects inputs if the target returns -1.
#include <cstddef>
#include <cstdint>
static volatile int Sink;
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
if (Size != 3)
return -1; // Reject anyting that's not 3 bytes long.
// Reject 'rej'.
if (Data[0] == 'r' && Data[1] == 'e' && Data[2] == 'j')
return -1;
// Accept 'acc'.
if (Data[0] == 'a' && Data[1] == 'c' && Data[2] == 'c') {
Sink = 1;
return 0;
}
return 0;
}