2014-05-30 22:08:51 +08:00
|
|
|
// RUN: %clangxx_tsan -O1 %s -o %t && %deflake %run %t | FileCheck %s
|
2012-05-10 22:18:22 +08:00
|
|
|
#include <pthread.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
// Ensure that we can restore a stack of a finished thread.
|
|
|
|
|
|
|
|
int g_data;
|
|
|
|
|
|
|
|
void __attribute__((noinline)) foobar(int *p) {
|
|
|
|
*p = 42;
|
|
|
|
}
|
|
|
|
|
|
|
|
void *Thread1(void *x) {
|
|
|
|
foobar(&g_data);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
void *Thread2(void *x) {
|
2012-12-07 17:24:57 +08:00
|
|
|
sleep(1);
|
2012-05-10 22:18:22 +08:00
|
|
|
g_data = 43;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
pthread_t t[2];
|
|
|
|
pthread_create(&t[0], NULL, Thread1, NULL);
|
|
|
|
pthread_create(&t[1], NULL, Thread2, NULL);
|
|
|
|
pthread_join(t[0], NULL);
|
|
|
|
pthread_join(t[1], NULL);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK: WARNING: ThreadSanitizer: data race
|
2012-12-06 20:16:15 +08:00
|
|
|
// CHECK: Write of size 4 at {{.*}} by thread T2:
|
|
|
|
// CHECK: Previous write of size 4 at {{.*}} by thread T1:
|
2012-05-10 22:18:22 +08:00
|
|
|
// CHECK: #0 foobar
|
|
|
|
// CHECK: #1 Thread1
|
2012-12-18 00:28:15 +08:00
|
|
|
// CHECK: Thread T1 (tid={{.*}}, finished) created by main thread at:
|
2012-05-10 22:18:22 +08:00
|
|
|
// CHECK: #0 pthread_create
|
|
|
|
// CHECK: #1 main
|