summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitry Vyukov <dvyukov@google.com>2017-07-12 12:23:31 +0000
committerDmitry Vyukov <dvyukov@google.com>2017-07-12 12:23:31 +0000
commit9cd8edacd314ca4374ab2e45ea61202f7cd9768b (patch)
tree827a9582a0142f61331a9b860b669691e0b7cd71
parenteb2931a5414c5d8644b904dd83f9f719ebd40cb0 (diff)
downloadcompiler-rt-9cd8edacd314ca4374ab2e45ea61202f7cd9768b.tar.gz
tsan: add test for __tsan_java_find
The test should have been added in 289682 "tsan: allow Java VM iterate over allocated objects" but I forgot to avn add. Author: Alexander Smundak (asmundak) Reviewed in https://reviews.llvm.org/D27720 git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@307776 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--test/tsan/java_find.cc69
1 files changed, 69 insertions, 0 deletions
diff --git a/test/tsan/java_find.cc b/test/tsan/java_find.cc
new file mode 100644
index 000000000..078aac520
--- /dev/null
+++ b/test/tsan/java_find.cc
@@ -0,0 +1,69 @@
+// RUN: %clangxx_tsan -O1 %s -o %t && %run %t 2>&1 | FileCheck %s
+#include "java.h"
+
+int const kHeapSize = 1024 * 1024;
+
+static void verify_find(jptr from, jptr to, jptr expected_addr,
+ jptr expected_size) {
+ jptr addr = from;
+ jptr size = __tsan_java_find(&addr, to);
+ if (expected_size) {
+ if (!size) {
+ fprintf(stderr, "FAILED: range: [%p..%p): found nothing\n", (void *)from,
+ (void *)to);
+ return;
+ } else if (expected_size != size) {
+ fprintf(stderr, "FAILED: range: [%p..%p): wrong size, %lu instead of %lu\n",
+ (void *)from, (void *)to, size, expected_size);
+ return;
+ }
+ } else if (size) {
+ fprintf(stderr,
+ "FAILED: range [%p..%p): did not expect to find anything here\n",
+ (void *)from, (void *)to);
+ return;
+ } else {
+ return;
+ }
+ if (expected_addr != addr) {
+ fprintf(
+ stderr,
+ "FAILED: range [%p..%p): expected to find object at %p, found at %p\n",
+ (void *)from, (void *)to, (void *)expected_addr, (void *)addr);
+ }
+}
+
+int main() {
+ const jptr jheap = (jptr)malloc(kHeapSize + 8) + 8;
+ const jptr jheap_end = jheap + kHeapSize;
+ __tsan_java_init(jheap, kHeapSize);
+ const jptr addr1 = jheap;
+ const int size1 = 16;
+ __tsan_java_alloc(jheap, size1);
+
+ const jptr addr2 = addr1 + size1;
+ const int size2 = 32;
+ __tsan_java_alloc(jheap + size1, size2);
+
+ const jptr addr3 = addr2 + size2;
+ const int size3 = 1024;
+ __tsan_java_alloc(jheap + size1 + size2, size3);
+
+ const jptr addr4 = addr3 + size3;
+
+ verify_find(jheap, jheap_end, addr1, size1);
+ verify_find(jheap + 8, jheap_end, addr2, size2);
+ verify_find(addr2 + 8, jheap_end, addr3, size3);
+ verify_find(addr3 + 8, jheap_end, 0, 0);
+
+ __tsan_java_move(addr2, addr4, size2);
+ verify_find(jheap + 8, jheap_end, addr3, size3);
+ verify_find(addr3 + 8, jheap_end, addr4, size2);
+ verify_find(addr4 + 8, jheap_end, 0, 0);
+
+ fprintf(stderr, "DONE\n");
+ return 0;
+}
+
+// CHECK-NOT: FAILED
+// CHECK: DONE