summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorMatt Morehouse <mascasa@google.com>2018-07-06 17:10:51 +0000
committerMatt Morehouse <mascasa@google.com>2018-07-06 17:10:51 +0000
commit711b418e467ddd86fed8cc22ae5ec7e311281376 (patch)
treebebebbb771d0e4574555a25deefb9c7324757842 /test
parentb89b5a6ea136eec77af5da51ce4f2f9b7e933ec6 (diff)
[MSan] Add functions to enable/disable interceptor checks.
Summary: The motivation for this change is to make libFuzzer+MSan possible without instrumenting libFuzzer. See https://github.com/google/sanitizers/issues/958. Reviewers: eugenis Reviewed By: eugenis Subscribers: llvm-commits, kcc Differential Revision: https://reviews.llvm.org/D48890 git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@336447 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test')
-rw-r--r--test/msan/scoped-interceptors.cc52
1 files changed, 52 insertions, 0 deletions
diff --git a/test/msan/scoped-interceptors.cc b/test/msan/scoped-interceptors.cc
new file mode 100644
index 000000000..fc7d45784
--- /dev/null
+++ b/test/msan/scoped-interceptors.cc
@@ -0,0 +1,52 @@
+// RUN: %clangxx_msan %s -o %t
+// RUN: %run %t --disable-checks 0 2>&1 | FileCheck --check-prefix=DISABLED --allow-empty %s
+// RUN: %run %t --disable-checks 1 2>&1 | FileCheck --check-prefix=DISABLED --allow-empty %s
+// RUN: %run %t --disable-checks 2 2>&1 | FileCheck --check-prefix=DISABLED --allow-empty %s
+// RUN: %run %t --disable-checks 3 2>&1 | FileCheck --check-prefix=DISABLED --allow-empty %s
+// RUN: not %run %t --reenable-checks 0 2>&1 | FileCheck --check-prefix=CASE-0 %s
+// RUN: not %run %t --reenable-checks 1 2>&1 | FileCheck --check-prefix=CASE-1 %s
+// RUN: not %run %t --reenable-checks 2 2>&1 | FileCheck --check-prefix=CASE-2 %s
+// RUN: not %run %t --reenable-checks 3 2>&1 | FileCheck --check-prefix=CASE-3 %s
+
+#include <assert.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sanitizer/msan_interface.h>
+
+int main(int argc, char *argv[]) {
+ assert(argc == 3);
+ __msan_scoped_disable_interceptor_checks();
+ if (strcmp(argv[1], "--reenable-checks") == 0)
+ __msan_scoped_enable_interceptor_checks();
+
+ char uninit[7];
+ switch (argv[2][0]) {
+ case '0': {
+ char *copy = strndup(uninit, sizeof(uninit)); // BOOM
+ free(copy);
+ break;
+ // CASE-0: Uninitialized bytes in __interceptor_strndup
+ }
+ case '1': {
+ puts(uninit); // BOOM
+ puts(uninit); // Ensure previous call did not enable interceptor checks.
+ break;
+ // CASE-1: Uninitialized bytes in __interceptor_puts
+ }
+ case '2': {
+ int cmp = memcmp(uninit, uninit, sizeof(uninit)); // BOOM
+ break;
+ // CASE-2: Uninitialized bytes in __interceptor_memcmp
+ }
+ case '3': {
+ size_t len = strlen(uninit); // BOOM
+ break;
+ // CASE-3: Uninitialized bytes in __interceptor_strlen
+ }
+ default: assert(0);
+ }
+ // DISABLED-NOT: Uninitialized bytes
+ return 0;
+}
+