diff options
| author | Alexey Samsonov <samsonov@google.com> | 2012-09-18 07:23:54 +0000 |
|---|---|---|
| committer | Alexey Samsonov <samsonov@google.com> | 2012-09-18 07:23:54 +0000 |
| commit | 341e5bcb45c9aeab3584d0aaa07a814282ebbefc (patch) | |
| tree | aa4c489f05f13095b7d68d15a1ec93c5da516eb8 /compiler-rt/lib/tsan/lit_tests/mutex_destroy_locked.cc | |
| parent | 7ecfa6d9603e09d5fa3eda0d25d72f07b568b47f (diff) | |
| download | bcm5719-llvm-341e5bcb45c9aeab3584d0aaa07a814282ebbefc.tar.gz bcm5719-llvm-341e5bcb45c9aeab3584d0aaa07a814282ebbefc.zip | |
[TSan] port all output tests to lit and move them to lit_tests directory. This makes 'make check-tsan' command test both unit and output TSan tests. Old custom makefiles for running TSan tests are still functional as well.
llvm-svn: 164110
Diffstat (limited to 'compiler-rt/lib/tsan/lit_tests/mutex_destroy_locked.cc')
| -rw-r--r-- | compiler-rt/lib/tsan/lit_tests/mutex_destroy_locked.cc | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/compiler-rt/lib/tsan/lit_tests/mutex_destroy_locked.cc b/compiler-rt/lib/tsan/lit_tests/mutex_destroy_locked.cc new file mode 100644 index 00000000000..427c64345b6 --- /dev/null +++ b/compiler-rt/lib/tsan/lit_tests/mutex_destroy_locked.cc @@ -0,0 +1,29 @@ +// RUN: %clangxx_tsan -O1 %s -o %t && %t 2>&1 | FileCheck %s +#include <pthread.h> +#include <unistd.h> + +void *Thread(void *p) { + pthread_mutex_lock((pthread_mutex_t*)p); + return 0; +} + +int main() { + pthread_mutex_t m; + pthread_mutex_init(&m, 0); + pthread_t t; + pthread_create(&t, 0, Thread, &m); + usleep(1000*1000); + pthread_mutex_destroy(&m); + pthread_join(t, 0); + return 0; +} + +// CHECK: WARNING: ThreadSanitizer: destroy of a locked mutex +// CHECK: #0 pthread_mutex_destroy +// CHECK: #1 main +// CHECK: and: +// CHECK: #0 pthread_mutex_lock +// CHECK: #1 Thread +// CHECK: Mutex {{.*}} created at: +// CHECK: #0 pthread_mutex_init +// CHECK: #1 main |

