Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/tests/net/bpf Add tests for several bpf ioctls



details:   https://anonhg.NetBSD.org/src/rev/209f8500553c
branches:  trunk
changeset: 351295:209f8500553c
user:      ozaki-r <ozaki-r%NetBSD.org@localhost>
date:      Thu Feb 09 02:18:13 2017 +0000

description:
Add tests for several bpf ioctls

diffstat:

 tests/net/bpf/t_bpf.c |  141 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 139 insertions(+), 2 deletions(-)

diffs (175 lines):

diff -r b284064a95b2 -r 209f8500553c tests/net/bpf/t_bpf.c
--- a/tests/net/bpf/t_bpf.c     Thu Feb 09 01:55:41 2017 +0000
+++ b/tests/net/bpf/t_bpf.c     Thu Feb 09 02:18:13 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: t_bpf.c,v 1.7 2017/02/01 08:04:49 ozaki-r Exp $        */
+/*     $NetBSD: t_bpf.c,v 1.8 2017/02/09 02:18:13 ozaki-r Exp $        */
 
 /*-
  * Copyright (c) 2010 Antti Kantee.  All Rights Reserved.
@@ -25,7 +25,7 @@
  * SUCH DAMAGE.
  */
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: t_bpf.c,v 1.7 2017/02/01 08:04:49 ozaki-r Exp $");
+__RCSID("$NetBSD: t_bpf.c,v 1.8 2017/02/09 02:18:13 ozaki-r Exp $");
 
 #include <sys/param.h>
 #include <sys/ioctl.h>
@@ -37,6 +37,7 @@
 
 #include <net/if.h>
 #include <net/bpf.h>
+#include <net/dlt.h>
 
 #include <fcntl.h>
 #include <stdio.h>
@@ -199,6 +200,138 @@
            "Don't allow to change buflen after binding bpf to an interface");
 }
 
+ATF_TC(bpf_ioctl_PROMISC);
+ATF_TC_HEAD(bpf_ioctl_PROMISC, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "Checks behaviors of BIOCPROMISC");
+}
+
+ATF_TC_BODY(bpf_ioctl_PROMISC, tc)
+{
+       struct ifreq ifr;
+       int ifnum, bpfd;
+
+       RZ(rump_init());
+       RZ(rump_pub_shmif_create(NULL, &ifnum));
+       sprintf(ifr.ifr_name, "shmif%d", ifnum);
+
+       RL(bpfd = rump_sys_open("/dev/bpf", O_RDWR));
+
+       ATF_REQUIRE_EQ_MSG(rump_sys_ioctl(bpfd, BIOCPROMISC, NULL), -1,
+           "Don't allow to call ioctl(BIOCPROMISC) without interface");
+
+       RL(rump_sys_ioctl(bpfd, BIOCSETIF, &ifr));
+
+       RL(rump_sys_ioctl(bpfd, BIOCPROMISC, NULL));
+       /* TODO check if_flags */
+}
+
+ATF_TC(bpf_ioctl_SETIF);
+ATF_TC_HEAD(bpf_ioctl_SETIF, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "Checks behaviors of BIOCSETIF");
+}
+
+ATF_TC_BODY(bpf_ioctl_SETIF, tc)
+{
+       struct ifreq ifr;
+       int ifnum, bpfd;
+
+       RZ(rump_init());
+
+       RL(bpfd = rump_sys_open("/dev/bpf", O_RDWR));
+
+       RZ(rump_pub_shmif_create(NULL, &ifnum));
+       sprintf(ifr.ifr_name, "shmif%d", ifnum);
+       RL(rump_sys_ioctl(bpfd, BIOCSETIF, &ifr));
+
+       /* Change the listening interface */
+       RZ(rump_pub_shmif_create(NULL, &ifnum));
+       sprintf(ifr.ifr_name, "shmif%d", ifnum);
+       RL(rump_sys_ioctl(bpfd, BIOCSETIF, &ifr));
+}
+
+ATF_TC(bpf_ioctl_DLT);
+ATF_TC_HEAD(bpf_ioctl_DLT, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "Checks behaviors of BIOCGDLT and "
+           "BIOCSDLT");
+}
+
+ATF_TC_BODY(bpf_ioctl_DLT, tc)
+{
+       struct ifreq ifr;
+       int ifnum, bpfd;
+       u_int dlt;
+
+       RZ(rump_init());
+       RL(bpfd = rump_sys_open("/dev/bpf", O_RDWR));
+       RZ(rump_pub_shmif_create(NULL, &ifnum));
+       sprintf(ifr.ifr_name, "shmif%d", ifnum);
+
+       ATF_REQUIRE_EQ_MSG(rump_sys_ioctl(bpfd, BIOCGDLT, &dlt), -1,
+           "Don't allow to get a DLT without interfaces");
+
+       RL(rump_sys_ioctl(bpfd, BIOCSETIF, &ifr));
+
+       RL(rump_sys_ioctl(bpfd, BIOCGDLT, &dlt));
+       ATF_REQUIRE(dlt == DLT_EN10MB);
+
+       dlt = DLT_NULL;
+       ATF_REQUIRE_EQ_MSG(rump_sys_ioctl(bpfd, BIOCSDLT, &dlt), -1,
+           "Don't allow to set a DLT that doesn't match any listening "
+           "interfaces");
+}
+
+ATF_TC(bpf_ioctl_GDLTLIST);
+ATF_TC_HEAD(bpf_ioctl_GDLTLIST, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "Checks behaviors of BIOCGDLTLIST");
+}
+
+ATF_TC_BODY(bpf_ioctl_GDLTLIST, tc)
+{
+       struct ifreq ifr;
+       int ifnum, bpfd;
+       struct bpf_dltlist dltlist;
+
+       RZ(rump_init());
+       RL(bpfd = rump_sys_open("/dev/bpf", O_RDWR));
+       RZ(rump_pub_shmif_create(NULL, &ifnum));
+       sprintf(ifr.ifr_name, "shmif%d", ifnum);
+
+       dltlist.bfl_len = 0;
+       dltlist.bfl_list = NULL;
+       ATF_REQUIRE_EQ_MSG(rump_sys_ioctl(bpfd, BIOCGDLTLIST, &dltlist), -1,
+           "Don't allow to get a DLT list without interfaces");
+
+       RL(rump_sys_ioctl(bpfd, BIOCSETIF, &ifr));
+
+       /* Get the size of an avaiable DLT list */
+       dltlist.bfl_len = 0;
+       dltlist.bfl_list = NULL;
+       RL(rump_sys_ioctl(bpfd, BIOCGDLTLIST, &dltlist));
+       ATF_REQUIRE(dltlist.bfl_len == 1);
+
+       /* Get an avaiable DLT list */
+       dltlist.bfl_list = calloc(sizeof(u_int), 1);
+       dltlist.bfl_len = 1;
+       RL(rump_sys_ioctl(bpfd, BIOCGDLTLIST, &dltlist));
+       ATF_REQUIRE(dltlist.bfl_len == 1);
+       ATF_REQUIRE(dltlist.bfl_list[0] == DLT_EN10MB);
+
+       /* Get an avaiable DLT list with a less buffer (fake with bfl_len) */
+       dltlist.bfl_len = 0;
+       ATF_REQUIRE_EQ_MSG(rump_sys_ioctl(bpfd, BIOCGDLTLIST, &dltlist), -1,
+           "This should fail with ENOMEM");
+
+       free(dltlist.bfl_list);
+}
+
 ATF_TP_ADD_TCS(tp)
 {
 
@@ -207,5 +340,9 @@
        ATF_TP_ADD_TC(tp, bpfwritetrunc);
 #endif
        ATF_TP_ADD_TC(tp, bpf_ioctl_BLEN);
+       ATF_TP_ADD_TC(tp, bpf_ioctl_PROMISC);
+       ATF_TP_ADD_TC(tp, bpf_ioctl_SETIF);
+       ATF_TP_ADD_TC(tp, bpf_ioctl_DLT);
+       ATF_TP_ADD_TC(tp, bpf_ioctl_GDLTLIST);
        return atf_no_error();
 }



Home | Main Index | Thread Index | Old Index