diff options
author | Matt Morehouse <mascasa@google.com> | 2019-10-02 20:13:21 +0000 |
---|---|---|
committer | Matt Morehouse <mascasa@google.com> | 2019-10-02 20:13:21 +0000 |
commit | e55c442b1b65a20c6fece42d4860a5148326a13e (patch) | |
tree | 1adeaf6910996975c5a88d842249f508eb238b9d | |
parent | 925d9d2e1443e49f2e4b7a4a674bb7bfe29609b0 (diff) | |
download | bcm5719-llvm-e55c442b1b65a20c6fece42d4860a5148326a13e.tar.gz bcm5719-llvm-e55c442b1b65a20c6fece42d4860a5148326a13e.zip |
[sanitizer_common] Rename OnPrint to __sanitizer_on_print.
Summary:
https://reviews.llvm.org/D28596 exposed OnPrint in the global namespace,
which can cause collisions with user-defined OnPrint() functions.
Reviewers: vitalybuka, dvyukov
Reviewed By: vitalybuka, dvyukov
Subscribers: llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D67987
llvm-svn: 373518
-rw-r--r-- | compiler-rt/lib/sanitizer_common/sanitizer_printf.cpp | 8 | ||||
-rw-r--r-- | compiler-rt/test/sanitizer_common/TestCases/onprint.cpp | 31 |
2 files changed, 38 insertions, 1 deletions
diff --git a/compiler-rt/lib/sanitizer_common/sanitizer_printf.cpp b/compiler-rt/lib/sanitizer_common/sanitizer_printf.cpp index 9d1c544786d..7063de257a9 100644 --- a/compiler-rt/lib/sanitizer_common/sanitizer_printf.cpp +++ b/compiler-rt/lib/sanitizer_common/sanitizer_printf.cpp @@ -229,15 +229,21 @@ void SetPrintfAndReportCallback(void (*callback)(const char *)) { // Can be overriden in frontend. #if SANITIZER_GO && defined(TSAN_EXTERNAL_HOOKS) // Implementation must be defined in frontend. +// TODO(morehouse): Remove OnPrint after migrating Go to __sanitizer_on_print. extern "C" void OnPrint(const char *str); +extern "C" void __sanitizer_on_print(const char *str); #else -SANITIZER_INTERFACE_WEAK_DEF(void, OnPrint, const char *str) { +SANITIZER_INTERFACE_WEAK_DEF(void, __sanitizer_on_print, const char *str) { (void)str; } #endif static void CallPrintfAndReportCallback(const char *str) { +#if SANITIZER_GO && defined(TSAN_EXTERNAL_HOOKS) + // TODO(morehouse): Remove OnPrint after migrating Go to __sanitizer_on_print. OnPrint(str); +#endif + __sanitizer_on_print(str); if (PrintfAndReportCallback) PrintfAndReportCallback(str); } diff --git a/compiler-rt/test/sanitizer_common/TestCases/onprint.cpp b/compiler-rt/test/sanitizer_common/TestCases/onprint.cpp new file mode 100644 index 00000000000..4b3f31e7bfc --- /dev/null +++ b/compiler-rt/test/sanitizer_common/TestCases/onprint.cpp @@ -0,0 +1,31 @@ +// Checks that the __sanitizer_on_print hook gets the exact same sanitizer +// report as what is printed to stderr. +// +// RUN: %clangxx %s -o %t +// RUN: %run %t %t-onprint.txt 2>%t-stderr.txt || true +// RUN: diff %t-onprint.txt %t-stderr.txt + +#include <cassert> +#include <cstdio> +#include <cstdlib> + +FILE *f; +volatile void *buf; +volatile char sink; + +extern "C" void __sanitizer_on_print(const char *str) { + fprintf(f, "%s", str); + fflush(f); +} + +int main(int argc, char *argv[]) { + assert(argc >= 2); + f = fopen(argv[1], "w"); + + // Use-after-free to trigger ASan/TSan reports. + void *ptr = malloc(1); + buf = ptr; + free(ptr); + sink = *static_cast<char *>(ptr); + return 0; +} |