blob: c67e81e09cda9a1d765b247fe9b266ebfdbb113a [file] [log] [blame]
Stephen Hines6a211c52014-07-21 00:49:56 -07001// RUN: %clangxx_tsan -O1 %s -o %t && %deflake %run %t | FileCheck %s
Stephen Hines86277eb2015-03-23 12:06:32 -07002#include "test.h"
Stephen Hines2d1fdb22014-05-28 23:58:16 -07003
4void *Thread1(void *x) {
5 int *p = (int*)x;
6 p[0] = 1;
Stephen Hines86277eb2015-03-23 12:06:32 -07007 barrier_wait(&barrier);
Stephen Hines2d1fdb22014-05-28 23:58:16 -07008 return NULL;
9}
10
11void *Thread2(void *x) {
Stephen Hines86277eb2015-03-23 12:06:32 -070012 barrier_wait(&barrier);
Stephen Hines2d1fdb22014-05-28 23:58:16 -070013 char *p = (char*)x;
14 p[2] = 1;
15 return NULL;
16}
17
18int main() {
Stephen Hines86277eb2015-03-23 12:06:32 -070019 barrier_init(&barrier, 2);
Stephen Hines2d1fdb22014-05-28 23:58:16 -070020 int *data = new int(42);
21 fprintf(stderr, "ptr1=%p\n", data);
22 fprintf(stderr, "ptr2=%p\n", (char*)data + 2);
23 pthread_t t[2];
24 pthread_create(&t[0], NULL, Thread1, data);
25 pthread_create(&t[1], NULL, Thread2, data);
26 pthread_join(t[0], NULL);
27 pthread_join(t[1], NULL);
28 delete data;
29}
30
31// CHECK: ptr1=[[PTR1:0x[0-9,a-f]+]]
32// CHECK: ptr2=[[PTR2:0x[0-9,a-f]+]]
33// CHECK: WARNING: ThreadSanitizer: data race
34// CHECK: Write of size 1 at [[PTR2]] by thread T2:
35// CHECK: Previous write of size 4 at [[PTR1]] by thread T1: