summaryrefslogtreecommitdiffstats
path: root/compiler-rt/test/tsan/java_lock.cc
diff options
context:
space:
mode:
authorDmitry Vyukov <dvyukov@google.com>2014-07-08 20:01:12 +0000
committerDmitry Vyukov <dvyukov@google.com>2014-07-08 20:01:12 +0000
commit3f5ad1a98e211216be9612a60ca30644e0f4073d (patch)
tree82a73f2dc557fd6cbca90e076ba2c7072c4832f6 /compiler-rt/test/tsan/java_lock.cc
parent7a88ec9ac05c4f9e4cc03bd9e84af9e6da73c8b9 (diff)
downloadbcm5719-llvm-3f5ad1a98e211216be9612a60ca30644e0f4073d.tar.gz
bcm5719-llvm-3f5ad1a98e211216be9612a60ca30644e0f4073d.zip
tsan: allow memory overlap in __tsan_java_move
JVM actually moves memory between overlapping ranges. llvm-svn: 212560
Diffstat (limited to 'compiler-rt/test/tsan/java_lock.cc')
-rw-r--r--compiler-rt/test/tsan/java_lock.cc15
1 files changed, 8 insertions, 7 deletions
diff --git a/compiler-rt/test/tsan/java_lock.cc b/compiler-rt/test/tsan/java_lock.cc
index e5513cd2d6f..36a0f8b7bff 100644
--- a/compiler-rt/test/tsan/java_lock.cc
+++ b/compiler-rt/test/tsan/java_lock.cc
@@ -15,21 +15,22 @@ void *Thread(void *p) {
int main() {
int const kHeapSize = 1024 * 1024;
- void *jheap = malloc(kHeapSize);
- __tsan_java_init((jptr)jheap, kHeapSize);
+ jptr jheap = (jptr)malloc(kHeapSize + 8) + 8;
+ __tsan_java_init(jheap, kHeapSize);
const int kBlockSize = 16;
- __tsan_java_alloc((jptr)jheap, kBlockSize);
- varaddr = (jptr)jheap;
- lockaddr = (jptr)jheap + 8;
+ __tsan_java_alloc(jheap, kBlockSize);
+ varaddr = jheap;
+ lockaddr = jheap + 8;
pthread_t th;
pthread_create(&th, 0, Thread, 0);
__tsan_java_mutex_lock(lockaddr);
*(int*)varaddr = 43;
__tsan_java_mutex_unlock(lockaddr);
pthread_join(th, 0);
- __tsan_java_free((jptr)jheap, kBlockSize);
- printf("OK\n");
+ __tsan_java_free(jheap, kBlockSize);
+ fprintf(stderr, "DONE\n");
return __tsan_java_fini();
}
// CHECK-NOT: WARNING: ThreadSanitizer: data race
+// CHECK: DONE
OpenPOWER on IntegriCloud