1*57718be8SEnji Cooper /* $NetBSD: t_sig.c,v 1.2 2010/11/03 16:10:20 christos Exp $ */ 2*57718be8SEnji Cooper 3*57718be8SEnji Cooper /*- 4*57718be8SEnji Cooper * Copyright (c) 2002, 2008 The NetBSD Foundation, Inc. 5*57718be8SEnji Cooper * All rights reserved. 6*57718be8SEnji Cooper * 7*57718be8SEnji Cooper * This code is derived from software contributed to The NetBSD Foundation 8*57718be8SEnji Cooper * by Luke Mewburn and Jaromir Dolecek. 9*57718be8SEnji Cooper * 10*57718be8SEnji Cooper * Redistribution and use in source and binary forms, with or without 11*57718be8SEnji Cooper * modification, are permitted provided that the following conditions 12*57718be8SEnji Cooper * are met: 13*57718be8SEnji Cooper * 1. Redistributions of source code must retain the above copyright 14*57718be8SEnji Cooper * notice, this list of conditions and the following disclaimer. 15*57718be8SEnji Cooper * 2. Redistributions in binary form must reproduce the above copyright 16*57718be8SEnji Cooper * notice, this list of conditions and the following disclaimer in the 17*57718be8SEnji Cooper * documentation and/or other materials provided with the distribution. 18*57718be8SEnji Cooper * 19*57718be8SEnji Cooper * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20*57718be8SEnji Cooper * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21*57718be8SEnji Cooper * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22*57718be8SEnji Cooper * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23*57718be8SEnji Cooper * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24*57718be8SEnji Cooper * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25*57718be8SEnji Cooper * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26*57718be8SEnji Cooper * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27*57718be8SEnji Cooper * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28*57718be8SEnji Cooper * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29*57718be8SEnji Cooper * POSSIBILITY OF SUCH DAMAGE. 30*57718be8SEnji Cooper */ 31*57718be8SEnji Cooper 32*57718be8SEnji Cooper #include <sys/cdefs.h> 33*57718be8SEnji Cooper __COPYRIGHT("@(#) Copyright (c) 2008\ 34*57718be8SEnji Cooper The NetBSD Foundation, inc. All rights reserved."); 35*57718be8SEnji Cooper __RCSID("$NetBSD: t_sig.c,v 1.2 2010/11/03 16:10:20 christos Exp $"); 36*57718be8SEnji Cooper 37*57718be8SEnji Cooper #include <sys/event.h> 38*57718be8SEnji Cooper #include <sys/ioctl.h> 39*57718be8SEnji Cooper #include <sys/param.h> 40*57718be8SEnji Cooper #include <sys/time.h> 41*57718be8SEnji Cooper #include <sys/wait.h> 42*57718be8SEnji Cooper 43*57718be8SEnji Cooper #include <inttypes.h> 44*57718be8SEnji Cooper #include <signal.h> 45*57718be8SEnji Cooper #include <stdio.h> 46*57718be8SEnji Cooper #include <stdlib.h> 47*57718be8SEnji Cooper #include <unistd.h> 48*57718be8SEnji Cooper 49*57718be8SEnji Cooper #include <atf-c.h> 50*57718be8SEnji Cooper 51*57718be8SEnji Cooper #include "../../h_macros.h" 52*57718be8SEnji Cooper 53*57718be8SEnji Cooper #define NSIGNALS 5 54*57718be8SEnji Cooper 55*57718be8SEnji Cooper ATF_TC(sig); 56*57718be8SEnji Cooper ATF_TC_HEAD(sig, tc) 57*57718be8SEnji Cooper { 58*57718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "Checks EVFILT_SIGNAL"); 59*57718be8SEnji Cooper } 60*57718be8SEnji Cooper ATF_TC_BODY(sig, tc) 61*57718be8SEnji Cooper { 62*57718be8SEnji Cooper struct timespec timeout; 63*57718be8SEnji Cooper struct kfilter_mapping km; 64*57718be8SEnji Cooper struct kevent event[1]; 65*57718be8SEnji Cooper char namebuf[32]; 66*57718be8SEnji Cooper pid_t pid, child; 67*57718be8SEnji Cooper int kq, n, num, status; 68*57718be8SEnji Cooper 69*57718be8SEnji Cooper pid = getpid(); 70*57718be8SEnji Cooper (void)printf("my pid: %d\n", pid); 71*57718be8SEnji Cooper 72*57718be8SEnji Cooper /* fork a child to send signals */ 73*57718be8SEnji Cooper RL(child = fork()); 74*57718be8SEnji Cooper if (child == 0) { 75*57718be8SEnji Cooper int i; 76*57718be8SEnji Cooper (void)sleep(2); 77*57718be8SEnji Cooper for(i = 0; i < NSIGNALS; ++i) { 78*57718be8SEnji Cooper (void)kill(pid, SIGUSR1); 79*57718be8SEnji Cooper (void)sleep(2); 80*57718be8SEnji Cooper } 81*57718be8SEnji Cooper _exit(0); 82*57718be8SEnji Cooper /* NOTREACHED */ 83*57718be8SEnji Cooper } 84*57718be8SEnji Cooper 85*57718be8SEnji Cooper RL(kq = kqueue()); 86*57718be8SEnji Cooper 87*57718be8SEnji Cooper (void)strlcpy(namebuf, "EVFILT_SIGNAL", sizeof(namebuf)); 88*57718be8SEnji Cooper km.name = namebuf; 89*57718be8SEnji Cooper RL(ioctl(kq, KFILTER_BYNAME, &km)); 90*57718be8SEnji Cooper (void)printf("got %d as filter number for `%s'.\n", km.filter, km.name); 91*57718be8SEnji Cooper 92*57718be8SEnji Cooper /* ignore the signal to avoid taking it for real */ 93*57718be8SEnji Cooper REQUIRE_LIBC(signal(SIGUSR1, SIG_IGN), SIG_ERR); 94*57718be8SEnji Cooper 95*57718be8SEnji Cooper event[0].ident = SIGUSR1; 96*57718be8SEnji Cooper event[0].filter = km.filter; 97*57718be8SEnji Cooper event[0].flags = EV_ADD | EV_ENABLE; 98*57718be8SEnji Cooper 99*57718be8SEnji Cooper RL(kevent(kq, event, 1, NULL, 0, NULL)); 100*57718be8SEnji Cooper 101*57718be8SEnji Cooper (void)sleep(1); 102*57718be8SEnji Cooper 103*57718be8SEnji Cooper timeout.tv_sec = 1; 104*57718be8SEnji Cooper timeout.tv_nsec = 0; 105*57718be8SEnji Cooper 106*57718be8SEnji Cooper for (num = 0; num < NSIGNALS; num += n) { 107*57718be8SEnji Cooper struct timeval then, now, diff; 108*57718be8SEnji Cooper 109*57718be8SEnji Cooper RL(gettimeofday(&then, NULL)); 110*57718be8SEnji Cooper RL(n = kevent(kq, NULL, 0, event, 1, &timeout)); 111*57718be8SEnji Cooper RL(gettimeofday(&now, NULL)); 112*57718be8SEnji Cooper timersub(&now, &then, &diff); 113*57718be8SEnji Cooper 114*57718be8SEnji Cooper (void)printf("sig: kevent returned %d in %lld.%06ld\n", 115*57718be8SEnji Cooper n, (long long)diff.tv_sec, (long)diff.tv_usec); 116*57718be8SEnji Cooper 117*57718be8SEnji Cooper if (n == 0) 118*57718be8SEnji Cooper continue; 119*57718be8SEnji Cooper 120*57718be8SEnji Cooper (void)printf("sig: kevent flags: 0x%x, data: %" PRId64 " (# " 121*57718be8SEnji Cooper "times signal posted)\n", event[0].flags, event[0].data); 122*57718be8SEnji Cooper } 123*57718be8SEnji Cooper 124*57718be8SEnji Cooper (void)waitpid(child, &status, 0); 125*57718be8SEnji Cooper (void)printf("sig: finished successfully\n"); 126*57718be8SEnji Cooper } 127*57718be8SEnji Cooper 128*57718be8SEnji Cooper ATF_TP_ADD_TCS(tp) 129*57718be8SEnji Cooper { 130*57718be8SEnji Cooper ATF_TP_ADD_TC(tp, sig); 131*57718be8SEnji Cooper 132*57718be8SEnji Cooper return atf_no_error(); 133*57718be8SEnji Cooper } 134