[compiler-rt] r333796 - Add weak definitions of trace-cmp hooks to dfsan

Kostya Serebryany via llvm-commits llvm-commits at lists.llvm.org
Fri Jun 1 14:59:25 PDT 2018


Author: kcc
Date: Fri Jun  1 14:59:25 2018
New Revision: 333796

URL: http://llvm.org/viewvc/llvm-project?rev=333796&view=rev
Log:
Add weak definitions of trace-cmp hooks to dfsan

Summary:
This allows to build and link the code with e.g.
-fsanitize=dataflow -fsanitize-coverage=trace-pc-guard,pc-table,func,trace-cmp
w/o providing (all) the definitions of trace-cmp hooks.

This is similar to dummy hooks provided by asan/ubsan/msan for the same purpose,
except that some of the hooks need to have the __dfsw_ prefix
since we need dfsan to replace them.

Reviewers: pcc

Reviewed By: pcc

Subscribers: delcypher, #sanitizers, llvm-commits

Differential Revision: https://reviews.llvm.org/D47605

Added:
    compiler-rt/trunk/test/dfsan/trace-cmp.c
Modified:
    compiler-rt/trunk/lib/dfsan/dfsan_custom.cc
    compiler-rt/trunk/lib/dfsan/scripts/check_custom_wrappers.sh

Modified: compiler-rt/trunk/lib/dfsan/dfsan_custom.cc
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/dfsan/dfsan_custom.cc?rev=333796&r1=333795&r2=333796&view=diff
==============================================================================
--- compiler-rt/trunk/lib/dfsan/dfsan_custom.cc (original)
+++ compiler-rt/trunk/lib/dfsan/dfsan_custom.cc Fri Jun  1 14:59:25 2018
@@ -1132,4 +1132,26 @@ int __dfsw_snprintf(char *str, size_t si
   va_end(ap);
   return ret;
 }
-} // extern "C"
+
+// Default empty implementations (weak). Users should redefine them.
+SANITIZER_INTERFACE_WEAK_DEF(void, __sanitizer_cov_trace_pc_guard, u32 *) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __sanitizer_cov_trace_pc_guard_init, u32 *,
+                             u32 *) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __sanitizer_cov_pcs_init, void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __sanitizer_cov_trace_pc_indir, void) {}
+
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_cmp, void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_cmp1, void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_cmp2, void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_cmp4, void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_cmp8, void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_const_cmp1,
+                             void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_const_cmp2,
+                             void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_const_cmp4,
+                             void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_const_cmp8,
+                             void) {}
+SANITIZER_INTERFACE_WEAK_DEF(void, __dfsw___sanitizer_cov_trace_switch, void) {}
+}  // extern "C"

Modified: compiler-rt/trunk/lib/dfsan/scripts/check_custom_wrappers.sh
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/dfsan/scripts/check_custom_wrappers.sh?rev=333796&r1=333795&r2=333796&view=diff
==============================================================================
--- compiler-rt/trunk/lib/dfsan/scripts/check_custom_wrappers.sh (original)
+++ compiler-rt/trunk/lib/dfsan/scripts/check_custom_wrappers.sh Fri Jun  1 14:59:25 2018
@@ -23,6 +23,7 @@ grep -E "^fun:.*=custom" ${DFSAN_ABI_LIS
   | grep -v "dfsan_get_label\|__sanitizer_cov_trace" \
   | sed "s/^fun:\(.*\)=custom.*/\1/" | sort > $DIFF_A
 grep -E "__dfsw.*\(" ${DFSAN_CUSTOM_WRAPPERS} \
+  | grep -v "__sanitizer_cov_trace" \
   | sed "s/.*__dfsw_\(.*\)(.*/\1/" | sort > $DIFF_B
 diff -u $DIFF_A $DIFF_B > ${DIFFOUT}
 if [ $? -ne 0 ]
@@ -33,6 +34,7 @@ then
 fi
 
 grep -E __dfsw_ ${DFSAN_CUSTOM_WRAPPERS} \
+  | grep -v "__sanitizer_cov_trace" \
   | sed "s/.*__dfsw_\([^(]*\).*/\1/" | sort > $DIFF_A
 grep -E "^[[:space:]]*test_.*\(\);" ${DFSAN_CUSTOM_TESTS} \
   | sed "s/.*test_\(.*\)();/\1/" | sort > $DIFF_B

Added: compiler-rt/trunk/test/dfsan/trace-cmp.c
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/dfsan/trace-cmp.c?rev=333796&view=auto
==============================================================================
--- compiler-rt/trunk/test/dfsan/trace-cmp.c (added)
+++ compiler-rt/trunk/test/dfsan/trace-cmp.c Fri Jun  1 14:59:25 2018
@@ -0,0 +1,50 @@
+// Checks that dfsan works with trace-cmp instrumentation, even if some hooks
+// are not defined (relies on week hooks implemented in dfsan).
+//
+// RUN: %clang_dfsan -fsanitize-coverage=trace-pc-guard,pc-table,func,trace-cmp %s -o %t
+// RUN: %run %t 2>&1 | FileCheck %s
+
+#include <stdio.h>
+#include <stdint.h>
+#include <stdlib.h>
+
+#include <sanitizer/dfsan_interface.h>
+
+uint32_t a4, b4;
+uint64_t a8, b8;
+
+// Define just two hooks, and leave others undefined.
+void __dfsw___sanitizer_cov_trace_const_cmp4(uint8_t a, uint8_t b,
+                                             dfsan_label l1, dfsan_label l2) {
+  printf("const_cmp4 %d %d\n", a, b);
+}
+void __dfsw___sanitizer_cov_trace_cmp8(uint8_t a, uint8_t b, dfsan_label l1,
+                                       dfsan_label l2) {
+  printf("cmp8 %d %d\n", a, b);
+}
+
+int main(int argc, char **argv) {
+  printf("MAIN\n");
+  // CHECK: MAIN
+
+  if (a4 != b4) abort();
+  if (a4 == 42) abort();
+  // CHECK: const_cmp4 42 0
+  if (a8 != b8) abort();
+  // CHECK: cmp8 0 0
+  if (a8 == 66) abort();
+
+  switch (10 / (a4 + 2)) {
+    case 1: abort();
+    case 2: exit(1);
+    case 5:
+            printf("SWITCH OK\n");
+            break;
+  }
+  // CHECK: SWITCH OK
+
+
+  printf("DONE\n");
+  // CHECK: DONE
+  return 0;
+}




More information about the llvm-commits mailing list