xref: /openbsd-src/regress/sys/kern/kqueue/kqueue-signal.c (revision bd35765dfde630203782d36f741b7bde1f9f8a3e)
1*bd35765dSbluhm /*	$OpenBSD: kqueue-signal.c,v 1.3 2016/09/20 23:05:27 bluhm Exp $	*/
26897c9b5Sguenther /*
36897c9b5Sguenther  *	Written by Philip Guenther <guenther@openbsd.org> 2011 Public Domain
46897c9b5Sguenther  */
56897c9b5Sguenther 
66897c9b5Sguenther #include <sys/types.h>
76897c9b5Sguenther #include <sys/event.h>
86897c9b5Sguenther #include <sys/socket.h>
96897c9b5Sguenther #include <sys/un.h>
106897c9b5Sguenther #include <sys/wait.h>
116897c9b5Sguenther 
126897c9b5Sguenther #include <err.h>
136897c9b5Sguenther #include <errno.h>
146897c9b5Sguenther #include <signal.h>
15*bd35765dSbluhm #include <stdio.h>
16*bd35765dSbluhm #include <stdlib.h>
17*bd35765dSbluhm #include <string.h>
18*bd35765dSbluhm #include <unistd.h>
196897c9b5Sguenther 
20*bd35765dSbluhm #include "main.h"
216897c9b5Sguenther 
226897c9b5Sguenther volatile sig_atomic_t saw_usr1 = 0;
236897c9b5Sguenther volatile sig_atomic_t result = 0;
246897c9b5Sguenther int kq;
256897c9b5Sguenther 
266897c9b5Sguenther int
sigtest(int signum,int catch)276897c9b5Sguenther sigtest(int signum, int catch)
286897c9b5Sguenther {
296897c9b5Sguenther 	struct kevent ke;
306897c9b5Sguenther 	struct timespec ts;
316897c9b5Sguenther 
326897c9b5Sguenther 	ts.tv_sec = 10;
336897c9b5Sguenther 	ts.tv_nsec = 0;
346897c9b5Sguenther 
356897c9b5Sguenther 	ASS(kevent(kq, NULL, 0, &ke, 1, &ts) == 1,
366897c9b5Sguenther 	    warn("can't fetch event on kqueue"));
376897c9b5Sguenther 	ASSX(ke.filter == EVFILT_SIGNAL);
386897c9b5Sguenther 	ASSX(ke.ident == signum);
396897c9b5Sguenther 	ASSX(ke.data == catch);
406897c9b5Sguenther 	return (0);
416897c9b5Sguenther }
426897c9b5Sguenther 
436897c9b5Sguenther void
usr1handler(int signum)446897c9b5Sguenther usr1handler(int signum)
456897c9b5Sguenther {
466897c9b5Sguenther 	saw_usr1 = 1;
476897c9b5Sguenther 	result = sigtest(SIGUSR1, 1);
486897c9b5Sguenther }
496897c9b5Sguenther 
506897c9b5Sguenther int
do_signal(void)516897c9b5Sguenther do_signal(void)
526897c9b5Sguenther {
536897c9b5Sguenther 	struct kevent ke;
546897c9b5Sguenther 	pid_t pid = getpid();
556897c9b5Sguenther 	sigset_t mask;
566897c9b5Sguenther 
576897c9b5Sguenther 	ASS((kq = kqueue()) >= 0, warn("kqueue"));
586897c9b5Sguenther 
596897c9b5Sguenther 	signal(SIGUSR1, usr1handler);
606897c9b5Sguenther 	signal(SIGUSR2, SIG_IGN);
616897c9b5Sguenther 
626897c9b5Sguenther 	EV_SET(&ke, SIGUSR1, EVFILT_SIGNAL, EV_ADD|EV_ENABLE, 0, 0, NULL);
636897c9b5Sguenther 	ASS(kevent(kq, &ke, 1, NULL, 0, NULL) == 0,
646897c9b5Sguenther 	    warn("can't register events on kqueue"));
656897c9b5Sguenther 	EV_SET(&ke, SIGUSR2, EVFILT_SIGNAL, EV_ADD|EV_ENABLE, 0, 0, NULL);
666897c9b5Sguenther 	ASS(kevent(kq, &ke, 1, NULL, 0, NULL) == 0,
676897c9b5Sguenther 	    warn("can't register events on kqueue"));
686897c9b5Sguenther 
69b261876bSguenther 	EV_SET(&ke, 10000, EVFILT_SIGNAL, EV_ADD|EV_ENABLE, 0, 0, NULL);
70b261876bSguenther 	ASS(kevent(kq, &ke, 1, NULL, 0, NULL) != 0,
71b261876bSguenther 	    warnx("registered bogus signal on kqueue"));
72b261876bSguenther 	ASS(errno == EINVAL,
73b261876bSguenther 	    warn("registering bogus signal on kqueue returned wrong error"));
74b261876bSguenther 
756897c9b5Sguenther 	ASSX(saw_usr1 == 0);
766897c9b5Sguenther 	kill(pid, SIGUSR1);
776897c9b5Sguenther 	ASSX(saw_usr1 == 1);
786897c9b5Sguenther 
796897c9b5Sguenther 	kill(pid, SIGUSR2);
80*bd35765dSbluhm 	ASSX(sigtest(SIGUSR2, 1) == 0);
816897c9b5Sguenther 	kill(pid, SIGUSR2);
826897c9b5Sguenther 	kill(pid, SIGUSR2);
83*bd35765dSbluhm 	ASSX(sigtest(SIGUSR2, 2) == 0);
846897c9b5Sguenther 
856897c9b5Sguenther 	sigemptyset(&mask);
866897c9b5Sguenther 	sigaddset(&mask, SIGUSR1);
876897c9b5Sguenther 	sigaddset(&mask, SIGUSR2);
886897c9b5Sguenther 	sigprocmask(SIG_BLOCK, &mask, NULL);
896897c9b5Sguenther 
906897c9b5Sguenther 	signal(SIGUSR1, SIG_DFL);
916897c9b5Sguenther 	kill(pid, SIGUSR1);
926897c9b5Sguenther 	kill(pid, SIGUSR2);
936897c9b5Sguenther 
946897c9b5Sguenther 	close(kq);
956897c9b5Sguenther 
966897c9b5Sguenther 	return (0);
976897c9b5Sguenther }
98