annotate compiler-rt/test/tsan/sleep_sync.cpp @ 266:00f31e85ec16 default tip

Added tag current for changeset 31d058e83c98
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 14 Oct 2023 10:13:55 +0900
parents 2e18cbf3894f
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 int X = 0;
anatofuz
parents:
diff changeset
5
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
6 __attribute__((noinline)) void MySleep() {
150
anatofuz
parents:
diff changeset
7 sleep(1); // the sleep that must appear in the report
anatofuz
parents:
diff changeset
8 }
anatofuz
parents:
diff changeset
9
anatofuz
parents:
diff changeset
10 void *Thread(void *p) {
anatofuz
parents:
diff changeset
11 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
12 MySleep(); // Assume the main thread has done the write.
anatofuz
parents:
diff changeset
13 X = 42;
anatofuz
parents:
diff changeset
14 return 0;
anatofuz
parents:
diff changeset
15 }
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 int main() {
anatofuz
parents:
diff changeset
18 barrier_init(&barrier, 2);
anatofuz
parents:
diff changeset
19 pthread_t t;
anatofuz
parents:
diff changeset
20 pthread_create(&t, 0, Thread, 0);
anatofuz
parents:
diff changeset
21 X = 43;
anatofuz
parents:
diff changeset
22 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
23 pthread_join(t, 0);
anatofuz
parents:
diff changeset
24 return 0;
anatofuz
parents:
diff changeset
25 }
anatofuz
parents:
diff changeset
26
anatofuz
parents:
diff changeset
27 // CHECK: WARNING: ThreadSanitizer: data race
anatofuz
parents:
diff changeset
28 // ...
anatofuz
parents:
diff changeset
29 // CHECK: As if synchronized via sleep:
anatofuz
parents:
diff changeset
30 // CHECK-NEXT: #0 sleep
anatofuz
parents:
diff changeset
31 // CHECK-NEXT: #1 MySleep
anatofuz
parents:
diff changeset
32 // CHECK-NEXT: #2 Thread