[PATCH] D67987: [sanitizer_common] Rename OnPrint to __sanitizer_on_print.

Matt Morehouse via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Wed Oct 2 13:11:45 PDT 2019


This revision was automatically updated to reflect the committed changes.
Closed by commit rL373518: [sanitizer_common] Rename OnPrint to __sanitizer_on_print. (authored by morehouse, committed by ).
Herald added a subscriber: delcypher.

Changed prior to commit:
  https://reviews.llvm.org/D67987?vs=222679&id=222897#toc

Repository:
  rL LLVM

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D67987/new/

https://reviews.llvm.org/D67987

Files:
  compiler-rt/trunk/lib/sanitizer_common/sanitizer_printf.cpp
  compiler-rt/trunk/test/sanitizer_common/TestCases/onprint.cpp


Index: compiler-rt/trunk/test/sanitizer_common/TestCases/onprint.cpp
===================================================================
--- compiler-rt/trunk/test/sanitizer_common/TestCases/onprint.cpp
+++ compiler-rt/trunk/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;
+}
Index: compiler-rt/trunk/lib/sanitizer_common/sanitizer_printf.cpp
===================================================================
--- compiler-rt/trunk/lib/sanitizer_common/sanitizer_printf.cpp
+++ compiler-rt/trunk/lib/sanitizer_common/sanitizer_printf.cpp
@@ -229,15 +229,21 @@
 // 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);
 }


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D67987.222897.patch
Type: text/x-patch
Size: 2086 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20191002/d9af937a/attachment.bin>


More information about the llvm-commits mailing list