Home | History | Annotate | Line # | Download | only in kqueue
t_ioctl.c revision 1.2.2.1
      1  1.2.2.1  pgoyette /* $NetBSD: t_ioctl.c,v 1.2.2.1 2017/03/20 06:57:57 pgoyette Exp $ */
      2      1.1      jmmv 
      3      1.1      jmmv /*-
      4      1.1      jmmv  * Copyright (c) 2002, 2008 The NetBSD Foundation, Inc.
      5      1.1      jmmv  * All rights reserved.
      6      1.1      jmmv  *
      7      1.1      jmmv  * This code is derived from software contributed to The NetBSD Foundation
      8      1.1      jmmv  * by Luke Mewburn.
      9      1.1      jmmv  *
     10      1.1      jmmv  * Redistribution and use in source and binary forms, with or without
     11      1.1      jmmv  * modification, are permitted provided that the following conditions
     12      1.1      jmmv  * are met:
     13      1.1      jmmv  * 1. Redistributions of source code must retain the above copyright
     14      1.1      jmmv  *    notice, this list of conditions and the following disclaimer.
     15      1.1      jmmv  * 2. Redistributions in binary form must reproduce the above copyright
     16      1.1      jmmv  *    notice, this list of conditions and the following disclaimer in the
     17      1.1      jmmv  *    documentation and/or other materials provided with the distribution.
     18      1.1      jmmv  *
     19      1.1      jmmv  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20      1.1      jmmv  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21      1.1      jmmv  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22      1.1      jmmv  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23      1.1      jmmv  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24      1.1      jmmv  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25      1.1      jmmv  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26      1.1      jmmv  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27      1.1      jmmv  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28      1.1      jmmv  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29      1.1      jmmv  * POSSIBILITY OF SUCH DAMAGE.
     30      1.1      jmmv  */
     31      1.1      jmmv 
     32      1.1      jmmv #include <sys/cdefs.h>
     33      1.1      jmmv __COPYRIGHT("@(#) Copyright (c) 2008\
     34      1.1      jmmv  The NetBSD Foundation, inc. All rights reserved.");
     35  1.2.2.1  pgoyette __RCSID("$NetBSD: t_ioctl.c,v 1.2.2.1 2017/03/20 06:57:57 pgoyette Exp $");
     36      1.1      jmmv 
     37      1.1      jmmv #include <sys/event.h>
     38      1.1      jmmv #include <sys/ioctl.h>
     39      1.1      jmmv 
     40      1.1      jmmv #include <stdio.h>
     41      1.1      jmmv #include <string.h>
     42      1.1      jmmv 
     43      1.1      jmmv #include <atf-c.h>
     44      1.1      jmmv 
     45  1.2.2.1  pgoyette #include "h_macros.h"
     46      1.1      jmmv 
     47      1.1      jmmv ATF_TC(kfilter_byfilter);
     48      1.1      jmmv ATF_TC_HEAD(kfilter_byfilter, tc)
     49      1.1      jmmv {
     50      1.1      jmmv 	atf_tc_set_md_var(tc, "descr", "Checks KFILTER_BYFILTER ioctl");
     51      1.1      jmmv }
     52      1.1      jmmv ATF_TC_BODY(kfilter_byfilter, tc)
     53      1.1      jmmv {
     54      1.1      jmmv 	char buf[32];
     55      1.1      jmmv 	struct kfilter_mapping km;
     56      1.2  christos 	int kq;
     57      1.2  christos 	uint32_t i;
     58      1.1      jmmv 
     59      1.1      jmmv 	RL(kq = kqueue());
     60      1.1      jmmv 
     61      1.1      jmmv 	km.name = buf;
     62      1.1      jmmv 	km.len = sizeof(buf) - 1;
     63      1.1      jmmv 
     64      1.1      jmmv 	for (i = 0; i < 7; ++i) {
     65      1.1      jmmv 		km.filter = i;
     66      1.1      jmmv 		RL(ioctl(kq, KFILTER_BYFILTER, &km));
     67      1.1      jmmv 		(void)printf("  map %d -> %s\n", km.filter, km.name);
     68      1.1      jmmv 	}
     69      1.1      jmmv 
     70      1.1      jmmv 	km.filter = 7;
     71      1.1      jmmv 	ATF_REQUIRE_EQ(ioctl(kq, KFILTER_BYFILTER, &km), -1);
     72      1.1      jmmv }
     73      1.1      jmmv 
     74      1.1      jmmv ATF_TC(kfilter_byname);
     75      1.1      jmmv ATF_TC_HEAD(kfilter_byname, tc)
     76      1.1      jmmv {
     77      1.1      jmmv 	atf_tc_set_md_var(tc, "descr", "Checks KFILTER_BYNAME ioctl");
     78      1.1      jmmv }
     79      1.1      jmmv ATF_TC_BODY(kfilter_byname, tc)
     80      1.1      jmmv {
     81      1.1      jmmv 	const char *tests[] = {
     82      1.1      jmmv 		"EVFILT_READ",
     83      1.1      jmmv 		"EVFILT_WRITE",
     84      1.1      jmmv 		"EVFILT_AIO",
     85      1.1      jmmv 		"EVFILT_VNODE",
     86      1.1      jmmv 		"EVFILT_PROC",
     87      1.1      jmmv 		"EVFILT_SIGNAL",
     88      1.1      jmmv 		"EVFILT_TIMER",
     89      1.1      jmmv 		NULL
     90      1.1      jmmv 	};
     91      1.1      jmmv 	char buf[32];
     92      1.1      jmmv 	struct kfilter_mapping km;
     93      1.1      jmmv 	const char **test;
     94      1.1      jmmv 	int kq;
     95      1.1      jmmv 
     96      1.1      jmmv 	RL(kq = kqueue());
     97      1.1      jmmv 
     98      1.1      jmmv 	km.name = buf;
     99      1.1      jmmv 
    100      1.1      jmmv 	for (test = &tests[0]; *test != NULL; ++test) {
    101      1.1      jmmv 		(void)strlcpy(buf, *test, sizeof(buf));
    102      1.1      jmmv 		RL(ioctl(kq, KFILTER_BYNAME, &km));
    103      1.1      jmmv 		(void)printf("  map %s -> %d\n", km.name, km.filter);
    104      1.1      jmmv 	}
    105      1.1      jmmv 
    106      1.1      jmmv 	(void)strlcpy(buf, "NOTREG_FILTER", sizeof(buf));
    107      1.1      jmmv 	ATF_REQUIRE_EQ(ioctl(kq, KFILTER_BYNAME, &km), -1);
    108      1.1      jmmv }
    109      1.1      jmmv 
    110      1.1      jmmv ATF_TP_ADD_TCS(tp)
    111      1.1      jmmv {
    112      1.1      jmmv 	ATF_TP_ADD_TC(tp, kfilter_byfilter);
    113      1.1      jmmv 	ATF_TP_ADD_TC(tp, kfilter_byname);
    114      1.1      jmmv 
    115      1.1      jmmv 	return atf_no_error();
    116      1.1      jmmv }
    117