From 315167339eb5f146040033b555c00ee0671ac72a Mon Sep 17 00:00:00 2001 From: Kostya Serebryany Date: Thu, 24 Mar 2016 01:32:08 +0000 Subject: [PATCH] [libFuzzer] don't report memory leaks if we are dying due to a timeout (just use _Exit instead of exit in the timeout callback) llvm-svn: 264237 --- llvm/lib/Fuzzer/FuzzerLoop.cpp | 2 +- llvm/lib/Fuzzer/test/CMakeLists.txt | 1 + llvm/lib/Fuzzer/test/LeakTimeoutTest.cpp | 14 ++++++++++++++ llvm/lib/Fuzzer/test/fuzzer-leak.test | 9 +++++++++ llvm/lib/Fuzzer/test/fuzzer.test | 4 ---- 5 files changed, 25 insertions(+), 5 deletions(-) create mode 100644 llvm/lib/Fuzzer/test/LeakTimeoutTest.cpp create mode 100644 llvm/lib/Fuzzer/test/fuzzer-leak.test diff --git a/llvm/lib/Fuzzer/FuzzerLoop.cpp b/llvm/lib/Fuzzer/FuzzerLoop.cpp index 7f3ffd0..f09ac05 100644 --- a/llvm/lib/Fuzzer/FuzzerLoop.cpp +++ b/llvm/lib/Fuzzer/FuzzerLoop.cpp @@ -164,7 +164,7 @@ void Fuzzer::AlarmCallback() { __sanitizer_print_stack_trace(); Printf("SUMMARY: libFuzzer: timeout\n"); PrintFinalStats(); - exit(Options.TimeoutExitCode); + _Exit(Options.TimeoutExitCode); // Stop right now. } } diff --git a/llvm/lib/Fuzzer/test/CMakeLists.txt b/llvm/lib/Fuzzer/test/CMakeLists.txt index 255be9c..3bda0a9 100644 --- a/llvm/lib/Fuzzer/test/CMakeLists.txt +++ b/llvm/lib/Fuzzer/test/CMakeLists.txt @@ -22,6 +22,7 @@ set(Tests InitializeTest MemcmpTest LeakTest + LeakTimeoutTest NullDerefTest NthRunCrashTest RepeatedMemcmp diff --git a/llvm/lib/Fuzzer/test/LeakTimeoutTest.cpp b/llvm/lib/Fuzzer/test/LeakTimeoutTest.cpp new file mode 100644 index 0000000..3aa56c4 --- /dev/null +++ b/llvm/lib/Fuzzer/test/LeakTimeoutTest.cpp @@ -0,0 +1,14 @@ +// Test with a leak. +#include +#include + +static volatile int *Sink; + +extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { + if (!Size) return 0; + Sink = new int; + Sink = new int; + while (Sink) *Sink = 0; // Infinite loop. + return 0; +} + diff --git a/llvm/lib/Fuzzer/test/fuzzer-leak.test b/llvm/lib/Fuzzer/test/fuzzer-leak.test new file mode 100644 index 0000000..3690068 --- /dev/null +++ b/llvm/lib/Fuzzer/test/fuzzer-leak.test @@ -0,0 +1,9 @@ +RUN: not LLVMFuzzer-LeakTest -runs=10 2>&1 | FileCheck %s --check-prefix=LEAK +LEAK: ERROR: LeakSanitizer: detected memory leaks +LEAK-NOT: DEATH: + +RUN: not LLVMFuzzer-LeakTimeoutTest -timeout=1 2>&1 | FileCheck %s --check-prefix=LEAK_TIMEOUT +LEAK_TIMEOUT: ERROR: libFuzzer: timeout after +LEAK_TIMEOUT-NOT: LeakSanitizer + + diff --git a/llvm/lib/Fuzzer/test/fuzzer.test b/llvm/lib/Fuzzer/test/fuzzer.test index 240209d..9aca950 100644 --- a/llvm/lib/Fuzzer/test/fuzzer.test +++ b/llvm/lib/Fuzzer/test/fuzzer.test @@ -69,10 +69,6 @@ RUN: LLVMFuzzer-SimpleTest %t/SUB1 -runs=0 2>&1 | FileCheck %s --check-prefix=SU SUBDIRS: READ units: 3 RUN: rm -rf %t/SUB1 -RUN: not LLVMFuzzer-LeakTest -runs=10 2>&1 | FileCheck %s --check-prefix=LEAK -LEAK: ERROR: LeakSanitizer: detected memory leaks -LEAK-NOT: DEATH: - RUN: mkdir -p %t RUN: echo abcd > %t/NthRunCrashTest.in RUN: LLVMFuzzer-NthRunCrashTest %t/NthRunCrashTest.in -- 2.7.4