getline_nohang.cpp
1006 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// RUN: %clangxx_tsan -O1 %s -o %t && %run %t
// Data race randomly triggered.
// UNSUPPORTED: netbsd
// Make sure TSan doesn't deadlock on a file stream lock at program shutdown.
// See https://github.com/google/sanitizers/issues/454
#ifdef __FreeBSD__
#define _WITH_GETLINE // to declare getline()
#endif
#include <pthread.h>
#include <stdio.h>
#include <unistd.h>
void *thread(void *unused) {
char *line = NULL;
size_t size;
int fd[2];
pipe(fd);
// Forge a non-standard stream to make sure it's not closed.
FILE *stream = fdopen(fd[0], "r");
while (1) {
volatile int res = getline(&line, &size, stream);
(void)res;
}
return NULL;
}
int main() {
pthread_t t;
pthread_attr_t a;
pthread_attr_init(&a);
pthread_attr_setdetachstate(&a, PTHREAD_CREATE_DETACHED);
pthread_create(&t, &a, thread, NULL);
pthread_attr_destroy(&a);
fprintf(stderr, "DONE\n");
return 0;
// ThreadSanitizer used to hang here because of a deadlock on a file stream.
}
// CHECK: DONE