2004-09-06 Roland McGrath <roland@frob.com>
[glibc.git] / rt / tst-aio4.c
blob847974d502bf43d096ca293487c927cecce7f3c2
1 /* Test for completion signal handling.
2 Copyright (C) 2000,01,02 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, write to the Free
17 Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18 02111-1307 USA. */
20 #include <aio.h>
21 #include <signal.h>
22 #include <stdio.h>
23 #include <stdlib.h>
24 #include <unistd.h>
25 #include <errno.h>
27 /* We might need a bit longer timeout. */
28 #define TIMEOUT 10 /* sec */
30 int my_signo;
32 volatile sig_atomic_t flag;
35 static void
36 sighandler (const int signo)
38 flag = signo;
41 static int
42 wait_flag (void)
44 while (flag == 0)
46 puts ("Sleeping...");
47 sleep (1);
50 if (flag != my_signo)
52 printf ("signal handler received wrong signal, flag is %d\n", flag);
53 return 1;
56 return 0;
59 #ifndef SIGRTMIN
60 # define SIGRTMIN -1
61 # define SIGRTMAX -1
62 #endif
64 static int
65 do_test (int argc, char *argv[])
67 char name[] = "/tmp/aio4.XXXXXX";
68 int fd;
69 struct aiocb *arr[1];
70 struct aiocb cb;
71 static const char buf[] = "Hello World\n";
72 struct aioinit init = {10, 20, 0};
73 struct sigaction sa;
74 struct sigevent ev;
76 if (SIGRTMIN == -1)
78 printf ("RT signals not supported.\n");
79 return 0;
82 /* Select a signal from the middle of the available choices... */
83 my_signo = (SIGRTMAX + SIGRTMIN) / 2;
85 fd = mkstemp (name);
86 if (fd == -1)
88 printf ("cannot open temp name: %m\n");
89 return 1;
92 unlink (name);
94 /* Test also aio_init. */
95 aio_init (&init);
97 arr[0] = &cb;
99 cb.aio_fildes = fd;
100 cb.aio_lio_opcode = LIO_WRITE;
101 cb.aio_reqprio = 0;
102 cb.aio_buf = (void *) buf;
103 cb.aio_nbytes = sizeof (buf) - 1;
104 cb.aio_offset = 0;
105 cb.aio_sigevent.sigev_notify = SIGEV_SIGNAL;
106 cb.aio_sigevent.sigev_notify_function = NULL;
107 cb.aio_sigevent.sigev_notify_attributes = NULL;
108 cb.aio_sigevent.sigev_signo = my_signo;
109 cb.aio_sigevent.sigev_value.sival_ptr = NULL;
111 ev.sigev_notify = SIGEV_SIGNAL;
112 ev.sigev_notify_function = NULL;
113 ev.sigev_notify_attributes = NULL;
114 ev.sigev_signo = my_signo;
116 sa.sa_handler = sighandler;
117 sigemptyset (&sa.sa_mask);
118 sa.sa_flags = SA_RESTART;
120 if (sigaction (my_signo, &sa, NULL) < 0)
122 printf ("sigaction failed: %m\n");
123 return 1;
126 flag = 0;
127 /* First use aio_write. */
128 if (aio_write (arr[0]) < 0)
130 if (errno == ENOSYS)
132 puts ("no aio support in this configuration");
133 return 0;
135 printf ("aio_write failed: %m\n");
136 return 1;
139 if (wait_flag ())
140 return 1;
142 puts ("aio_write OK");
144 flag = 0;
145 /* Again with lio_listio. */
146 if (lio_listio (LIO_NOWAIT, arr, 1, &ev) < 0)
148 printf ("lio_listio failed: %m\n");
149 return 1;
152 if (wait_flag ())
153 return 1;
155 puts ("all OK");
157 return 0;
160 #include "../test-skeleton.c"