annotate compiler-rt/test/tsan/race_with_finished_thread.cpp @ 150:1d019706d866

LLVM10
author anatofuz
date Thu, 13 Feb 2020 15:10:13 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: %clangxx_tsan -O1 %s -o %t && %deflake %run %t | FileCheck %s
anatofuz
parents:
diff changeset
2 #include "test.h"
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 // Ensure that we can restore a stack of a finished thread.
anatofuz
parents:
diff changeset
5
anatofuz
parents:
diff changeset
6 int g_data;
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 void __attribute__((noinline)) foobar(int *p) {
anatofuz
parents:
diff changeset
9 *p = 42;
anatofuz
parents:
diff changeset
10 }
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 void *Thread1(void *x) {
anatofuz
parents:
diff changeset
13 foobar(&g_data);
anatofuz
parents:
diff changeset
14 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
15 return NULL;
anatofuz
parents:
diff changeset
16 }
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 void *Thread2(void *x) {
anatofuz
parents:
diff changeset
19 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
20 sleep(1); // let the thread finish and exit
anatofuz
parents:
diff changeset
21 g_data = 43;
anatofuz
parents:
diff changeset
22 return NULL;
anatofuz
parents:
diff changeset
23 }
anatofuz
parents:
diff changeset
24
anatofuz
parents:
diff changeset
25 int main() {
anatofuz
parents:
diff changeset
26 barrier_init(&barrier, 2);
anatofuz
parents:
diff changeset
27 pthread_t t[2];
anatofuz
parents:
diff changeset
28 pthread_create(&t[0], NULL, Thread1, NULL);
anatofuz
parents:
diff changeset
29 pthread_create(&t[1], NULL, Thread2, NULL);
anatofuz
parents:
diff changeset
30 pthread_join(t[0], NULL);
anatofuz
parents:
diff changeset
31 pthread_join(t[1], NULL);
anatofuz
parents:
diff changeset
32 return 0;
anatofuz
parents:
diff changeset
33 }
anatofuz
parents:
diff changeset
34
anatofuz
parents:
diff changeset
35 // CHECK: WARNING: ThreadSanitizer: data race
anatofuz
parents:
diff changeset
36 // CHECK: Write of size 4 at {{.*}} by thread T2:
anatofuz
parents:
diff changeset
37 // CHECK: Previous write of size 4 at {{.*}} by thread T1:
anatofuz
parents:
diff changeset
38 // CHECK: #0 foobar
anatofuz
parents:
diff changeset
39 // CHECK: #1 Thread1
anatofuz
parents:
diff changeset
40 // CHECK: Thread T1 (tid={{.*}}, finished) created by main thread at:
anatofuz
parents:
diff changeset
41 // CHECK: #0 pthread_create
anatofuz
parents:
diff changeset
42 // CHECK: #1 main