mutex_double_lock.cpp 837 Bytes
// RUN: %clangxx_tsan -O1 %s -o %t && %deflake %run %t | FileCheck %s
#include <pthread.h>
#include <unistd.h>

extern "C" void AnnotateRWLockAcquired(const char *f, int l, void *m, long rw);

void *ThreadFunc(void *m) {
  AnnotateRWLockAcquired(__FILE__, __LINE__, m, 1);
  return 0;
}

int main() {
  int m = 0;
  AnnotateRWLockAcquired(__FILE__, __LINE__, &m, 1);
  pthread_t th;
  pthread_create(&th, 0, ThreadFunc, &m);
  pthread_join(th, 0);
  return 0;
}

// CHECK: WARNING: ThreadSanitizer: double lock of a mutex
// CHECK:     #0 AnnotateRWLockAcquired
// CHECK:     #1 ThreadFunc
// CHECK: Location is stack of main thread.
// CHECK:   Mutex {{.*}} created at:
// CHECK:     #0 AnnotateRWLockAcquired
// CHECK:     #1 main
// CHECK: SUMMARY: ThreadSanitizer: double lock of a mutex {{.*}}mutex_double_lock.cpp{{.*}}ThreadFunc