mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-17 12:16:52 +00:00

Currently, we only print how threads involved in data race are created from their parent threads. Add a runtime flag 'print_full_thread_history' to print thread creation stacks for the threads involved in the data race and their ancestors up to the main thread. Reviewed By: dvyukov Differential Revision: https://reviews.llvm.org/D122131
41 lines
941 B
C++
41 lines
941 B
C++
// RUN: %clangxx_tsan -O1 %s -o %t && %env_tsan_opts=print_full_thread_history=true %deflake %run %t 2>&1 | FileCheck %s
|
|
|
|
#include "test.h"
|
|
|
|
int Global;
|
|
|
|
void *Thread2(void *x) {
|
|
barrier_wait(&barrier);
|
|
Global++;
|
|
return NULL;
|
|
}
|
|
|
|
void *Thread3(void *x) {
|
|
Global--;
|
|
barrier_wait(&barrier);
|
|
return NULL;
|
|
}
|
|
|
|
void *Thread1(void *x) {
|
|
pthread_t t[2];
|
|
pthread_create(&t[0], NULL, Thread2, NULL);
|
|
pthread_create(&t[1], NULL, Thread3, NULL);
|
|
pthread_join(t[0], NULL);
|
|
pthread_join(t[1], NULL);
|
|
return NULL;
|
|
}
|
|
|
|
int main() {
|
|
barrier_init(&barrier, 2);
|
|
pthread_t t;
|
|
pthread_create(&t, NULL, Thread1, NULL);
|
|
pthread_join(t, NULL);
|
|
return 0;
|
|
}
|
|
|
|
// CHECK: WARNING: ThreadSanitizer: data race
|
|
// CHECK: Thread T2 {{.*}} created by thread T1 at
|
|
// CHECK: Thread T3 {{.*}} created by thread T1 at:
|
|
// CHECK: Thread T1 {{.*}} created by main thread at:
|
|
// CHECK: SUMMARY: ThreadSanitizer: data race{{.*}}
|