vgdb: Handle EAGAIN in read_buf
[valgrind.git] / none / tests / syscall-restart1.c
blobd44e14e1b5a141e3ae7041b972a24ea0b738922b
1 #include <stdio.h>
2 #include <unistd.h>
3 #include <signal.h>
4 #include <errno.h>
5 #include <sys/wait.h>
6 #include <string.h>
8 /* Make sure that a blocking syscall returns EINTR if hit by a signal,
9 and there's no SA_RESTART */
11 static void handler(int s)
15 int main()
17 int pid;
18 int fds[2];
20 if (pipe(fds) == -1) {
21 perror("FAIL: pipe\n");
22 return 1;
25 pid = fork();
27 if (pid == -1) {
28 perror("fork failed");
29 return 1;
32 if (pid == 0) {
33 char ch = '?';
34 int ret;
35 struct sigaction sa;
37 sa.sa_handler = handler;
38 sigfillset(&sa.sa_mask);
39 sa.sa_flags = 0; /* no SA_RESTART */
41 sigaction(SIGUSR1, &sa, NULL);
43 close(fds[1]);
44 ret = read(fds[0], &ch, 1);
46 if (ret != -1 || errno != EINTR)
47 fprintf(stderr, "FAIL: expected EINTR, not %d/%s/%c\n",
48 ret, strerror(errno), ch);
49 } else {
50 signal(SIGPIPE, SIG_IGN);
52 close(fds[0]);
53 sleep(1);
54 kill(pid, SIGUSR1);
55 sleep(1);
56 if (write(fds[1], "x", 1) != -1 || errno != EPIPE)
57 fprintf(stderr, "FAIL: expected write to fail with EPIPE, not %d\n", errno);
59 waitpid(pid, NULL, 0);
62 return 0;