From: Kostya Serebryany Date: Thu, 10 Sep 2015 18:48:38 +0000 (+0000) Subject: [libFuzzer] refactor the code to allow building libFuzzer on platforms that don't... X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=8eaf34eed852caa406bfb0dca689cef9a7959c02;p=oota-llvm.git [libFuzzer] refactor the code to allow building libFuzzer on platforms that don't have dfsan and don't support weak functions git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@247321 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Fuzzer/FuzzerDFSan.h b/lib/Fuzzer/FuzzerDFSan.h new file mode 100644 index 00000000000..6398575e695 --- /dev/null +++ b/lib/Fuzzer/FuzzerDFSan.h @@ -0,0 +1,51 @@ +//===- FuzzerDFSan.h - Internal header for the Fuzzer -----------*- C++ -* ===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// DFSan interface. +//===----------------------------------------------------------------------===// + +#ifndef LLVM_FUZZER_DFSAN_H +#define LLVM_FUZZER_DFSAN_H + +#ifndef LLVM_FUZZER_SUPPORTS_DFSAN +# if defined(__linux__) +# define LLVM_FUZZER_SUPPORTS_DFSAN 1 +# else +# define LLVM_FUZZER_SUPPORTS_DFSAN 0 +# endif // __linux__ +#endif // LLVM_FUZZER_SUPPORTS_DFSAN + +#include +#if LLVM_FUZZER_SUPPORTS_DFSAN + +extern "C" { +__attribute__((weak)) +dfsan_label dfsan_create_label(const char *desc, void *userdata); +__attribute__((weak)) +void dfsan_set_label(dfsan_label label, void *addr, size_t size); +__attribute__((weak)) +void dfsan_add_label(dfsan_label label, void *addr, size_t size); +__attribute__((weak)) +const struct dfsan_label_info *dfsan_get_label_info(dfsan_label label); +__attribute__((weak)) +dfsan_label dfsan_read_label(const void *addr, size_t size); +} // extern "C" + +namespace fuzzer { +static bool ReallyHaveDFSan() { + return &dfsan_create_label != nullptr; +} +} // namespace fuzzer +#else +namespace fuzzer { +static bool ReallyHaveDFSan() { return false; } +} // namespace fuzzer + +#endif + +#endif // LLVM_FUZZER_DFSAN_H diff --git a/lib/Fuzzer/FuzzerTraceState.cpp b/lib/Fuzzer/FuzzerTraceState.cpp index 34a98d1a20b..a3934c14365 100644 --- a/lib/Fuzzer/FuzzerTraceState.cpp +++ b/lib/Fuzzer/FuzzerTraceState.cpp @@ -67,37 +67,34 @@ clang -fPIC -c -g -O2 -std=c++11 Fuzzer*.cpp clang++ -O0 -std=c++11 -fsanitize-coverage=edge,trace-cmp \ -fsanitize=dataflow \ - test/dfsan/DFSanSimpleCmpTest.cpp Fuzzer*.o - ./a.out + test/SimpleCmpTest.cpp Fuzzer*.o + ./a.out -use_traces=1 ) */ +#include "FuzzerDFSan.h" #include "FuzzerInternal.h" -#include #include #include #include +#if !LLVM_FUZZER_SUPPORTS_DFSAN +// Stubs for dfsan for platforms where dfsan does not exist and weak +// functions don't work. extern "C" { -__attribute__((weak)) -dfsan_label dfsan_create_label(const char *desc, void *userdata); -__attribute__((weak)) -void dfsan_set_label(dfsan_label label, void *addr, size_t size); -__attribute__((weak)) -void dfsan_add_label(dfsan_label label, void *addr, size_t size); -__attribute__((weak)) -const struct dfsan_label_info *dfsan_get_label_info(dfsan_label label); -__attribute__((weak)) -dfsan_label dfsan_read_label(const void *addr, size_t size); +dfsan_label dfsan_create_label(const char *desc, void *userdata) { return 0; } +void dfsan_set_label(dfsan_label label, void *addr, size_t size) {} +void dfsan_add_label(dfsan_label label, void *addr, size_t size) {} +const struct dfsan_label_info *dfsan_get_label_info(dfsan_label label) { + return nullptr; +} +dfsan_label dfsan_read_label(const void *addr, size_t size) { return 0; } } // extern "C" +#endif // !LLVM_FUZZER_SUPPORTS_DFSAN namespace fuzzer { -static bool ReallyHaveDFSan() { - return &dfsan_create_label != nullptr; -} - // These values are copied from include/llvm/IR/InstrTypes.h. // We do not include the LLVM headers here to remain independent. // If these values ever change, an assertion in ComputeCmp will fail.