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

LLVM10
author anatofuz
date Thu, 13 Feb 2020 15:10:13 +0900
parents
children 0572611fdcc8
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 #include <string.h>
anatofuz
parents:
diff changeset
4
anatofuz
parents:
diff changeset
5 char *data0 = new char[10];
anatofuz
parents:
diff changeset
6 char *data1 = new char[10];
anatofuz
parents:
diff changeset
7 char *data2 = new char[10];
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 void *Thread1(void *x) {
anatofuz
parents:
diff changeset
10 static volatile int size = 1;
anatofuz
parents:
diff changeset
11 static volatile int sink;
anatofuz
parents:
diff changeset
12 sink = memcmp(data0+5, data1, size);
anatofuz
parents:
diff changeset
13 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
14 return NULL;
anatofuz
parents:
diff changeset
15 }
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 void *Thread2(void *x) {
anatofuz
parents:
diff changeset
18 static volatile int size = 4;
anatofuz
parents:
diff changeset
19 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
20 memcpy(data0+5, data2, size);
anatofuz
parents:
diff changeset
21 return NULL;
anatofuz
parents:
diff changeset
22 }
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 int main() {
anatofuz
parents:
diff changeset
25 barrier_init(&barrier, 2);
anatofuz
parents:
diff changeset
26 print_address("addr=", 1, &data0[5]);
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: addr=[[ADDR:0x[0-9,a-f]+]]
anatofuz
parents:
diff changeset
36 // CHECK: WARNING: ThreadSanitizer: data race
anatofuz
parents:
diff changeset
37 // CHECK: Write of size 1 at [[ADDR]] by thread T2:
anatofuz
parents:
diff changeset
38 // CHECK: #0 {{(memcpy|memmove)}}
anatofuz
parents:
diff changeset
39 // CHECK: #1 Thread2
anatofuz
parents:
diff changeset
40 // CHECK: Previous read of size 1 at [[ADDR]] by thread T1:
anatofuz
parents:
diff changeset
41 // CHECK: #0 memcmp
anatofuz
parents:
diff changeset
42 // CHECK: #1 Thread1