Source-Changes-HG archive

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

[src/trunk]: src/tests/net/if_vlan Make the test program run in background af...



details:   https://anonhg.NetBSD.org/src/rev/146c3df7bbd2
branches:  trunk
changeset: 985309:146c3df7bbd2
user:      yamaguchi <yamaguchi%NetBSD.org@localhost>
date:      Thu Aug 19 03:27:05 2021 +0000

description:
Make the test program run in background after doing BIOCPROMISC

t_vlan has rarely failed by checking IFF_PROMISC before the
test program do BIOCPROMISC. To solve this, BIOCPROMISC is
done in the foreground.

fixes PR/56357

diffstat:

 tests/net/if_vlan/Makefile  |    4 +-
 tests/net/if_vlan/bpfopen.c |  196 +++++++++++++++++++++++++++++++++----------
 tests/net/if_vlan/t_vlan.sh |   15 +-
 3 files changed, 162 insertions(+), 53 deletions(-)

diffs (truncated from 340 to 300 lines):

diff -r bf0b5a182752 -r 146c3df7bbd2 tests/net/if_vlan/Makefile
--- a/tests/net/if_vlan/Makefile        Thu Aug 19 02:05:34 2021 +0000
+++ b/tests/net/if_vlan/Makefile        Thu Aug 19 03:27:05 2021 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.3 2021/07/09 05:54:11 yamaguchi Exp $
+# $NetBSD: Makefile,v 1.4 2021/08/19 03:27:05 yamaguchi Exp $
 #
 
 .include <bsd.own.mk>
@@ -17,5 +17,7 @@
 PROGS+=                        bpfopen
 MAN.bpfopen=   #empty
 BINDIR.bpfopen=        ${TESTSDIR}
+DPADD.bpfopen+=        ${LIBUTIL}
+LDADD.bpfopen+=        -lutil
 
 .include <bsd.test.mk>
diff -r bf0b5a182752 -r 146c3df7bbd2 tests/net/if_vlan/bpfopen.c
--- a/tests/net/if_vlan/bpfopen.c       Thu Aug 19 02:05:34 2021 +0000
+++ b/tests/net/if_vlan/bpfopen.c       Thu Aug 19 03:27:05 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: bpfopen.c,v 1.1 2021/07/09 05:54:11 yamaguchi Exp $    */
+/*     $NetBSD: bpfopen.c,v 1.2 2021/08/19 03:27:05 yamaguchi Exp $    */
 
 /*
  * Copyright (c) 2021 Internet Initiative Japan Inc.
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: bpfopen.c,v 1.1 2021/07/09 05:54:11 yamaguchi Exp $");
+__RCSID("$NetBSD: bpfopen.c,v 1.2 2021/08/19 03:27:05 yamaguchi Exp $");
 
 #include <sys/param.h>
 #include <sys/ioctl.h>
@@ -45,6 +45,8 @@
 #include <signal.h>
 #include <unistd.h>
 
+#include <util.h>
+
 enum {
        ARG_PROG = 0,
        ARG_HOST,
@@ -58,16 +60,25 @@
 };
 
 static void    sighandler(int);
+static void    log_debug(const char *, ...) __printflike(1, 2);
+static int     bpf_open(void);
+static void    bpf_close(int);
+static void    bpf_read(int);
 
-static sig_atomic_t quit;
+static sig_atomic_t     quit;
+static bool             daemonize = false;
+static int              verbose = 0;
+static const char      *path_pid = "/var/run/bpfopen.pid";
+static const char      *path_bpf = "/dev/bpf";
+static const char      *ifname = NULL;
 
 static void
 usage(void)
 {
 
-       fprintf(stderr, "%s {-r|-h} <ifname>\n"
-           "\t-r: rump_server\n"
-           "\t-h: host\n",
+       fprintf(stderr, "%s [-vd] [-p pidfile] [-b devbpf ] <ifname>\n"
+           "\t-v: verbose\n"
+           "\t-d: daemon mode\n",
            getprogname());
        exit(1);
 }
@@ -75,42 +86,146 @@
 int
 main(int argc, char *argv[])
 {
-       struct ifreq ifr;
-       struct pollfd pfd[PFD_NUM];
-       const char *bpf_path;
-       int n, bpfd, nfds;
-       size_t bufsiz;
-       char *buf;
+       int bpfd;
+       int ch;
 
-       if (argc != ARG_NUM)
+       while ((ch = getopt(argc, argv, "b:dp:v")) != -1) {
+               switch (ch) {
+               case 'b':
+                       path_bpf = optarg;
+                       break;
+               case 'd':
+                       daemonize = true;
+                       break;
+               case 'p':
+                       path_pid = optarg;
+                       break;
+               case 'v':
+                       verbose++;
+                       break;
+               default:
+                       usage();
+               }
+       }
+
+       argc -= optind;
+       argv += optind;
+
+       if (argc != 1)
                usage();
 
-       if (strcmp(argv[ARG_HOST], "-h") == 0) {
-               bpf_path = "/dev/bpf";
-       } else if (strcmp(argv[ARG_HOST], "-r") == 0){
-               bpf_path = "/rump/dev/bpf";
-       } else {
-               errx(1, "-r or -h");
+       ifname = argv[0];
+
+       bpfd = bpf_open();
+       if (bpfd < 0)
+               err(1, "bpf_open");
+       log_debug("bpf opened");
+
+       if (daemonize) {
+               if (daemon(1, 1) != 0) {
+                       bpf_close(bpfd);
+                       err(1, "daemon");
+               }
+               log_debug("daemonized");
+
+               if (pidfile(path_pid) != 0) {
+                       bpf_close(bpfd);
+                       err(1, "pidfile");
+               }
        }
 
-       bpfd = open(bpf_path, O_RDONLY);
-       if (bpfd < 0)
-               err(1, "open %s", bpf_path);
+       bpf_read(bpfd);
+       bpf_close(bpfd);
+       if (daemonize)
+               pidfile_clean();
+
+       return 0;
+}
+
+static void
+sighandler(int signo)
+{
+
+       quit = 1;
+}
+
+static void
+log_debug(const char *fmt, ...)
+{
+       va_list ap;
+
+       if (verbose <= 0)
+               return;
+
+       va_start(ap, fmt);
+       vfprintf(stderr, fmt, ap);
+       va_end(ap);
+
+       fprintf(stderr, "\n");
+}
+
+static int
+bpf_open(void)
+{
+       struct ifreq ifr;
+       int bpfd;
+
+       bpfd = open(path_bpf, O_RDONLY);
+       if (bpfd < 0) {
+               log_debug("open: %s", strerror(errno));
+               return -1;
+       }
 
        memset(&ifr, 0, sizeof(ifr));
-       strlcpy(ifr.ifr_name, argv[ARG_IFNAME],
-           sizeof(ifr.ifr_name));
-       if (ioctl(bpfd, BIOCSETIF, &ifr) != 0)
-               err(1, "BIOCSETIF");
-       if (ioctl(bpfd, BIOCPROMISC, NULL) != 0)
-               err(1, "BIOCPROMISC");
-       if (ioctl(bpfd, BIOCGBLEN, &bufsiz) != 0)
-               err(1, "BIOCGBLEN");
+       strlcpy(ifr.ifr_name, ifname, sizeof(ifr.ifr_name));
+
+       if (ioctl(bpfd, BIOCSETIF, &ifr) != 0) {
+               log_debug("BIOCSETIF: %s", strerror(errno));
+               goto close_bpfd;
+       }
+
+       if (ioctl(bpfd, BIOCPROMISC, NULL) != 0) {
+               log_debug("BIOCPROMISC: %s", strerror(errno));
+               goto close_bpfd;
+       }
+
+       return bpfd;
+
+close_bpfd:
+       close(bpfd);
+
+       return -1;
+}
+
+static void
+bpf_close(int bpfd)
+{
+
+       close(bpfd);
+}
+
+static void
+bpf_read(int bpfd)
+{
+       struct pollfd pfd[PFD_NUM];
+       int nfds;
+       char *buf;
+       u_int bufsiz;
+       ssize_t n;
+
+       if (ioctl(bpfd, BIOCGBLEN, &bufsiz) != 0) {
+               bufsiz = BPF_DFLTBUFSIZE;
+               log_debug("BIOCGBLEN: %s, use default size %u",
+                   strerror(errno), bufsiz);
+       }
+
        bufsiz = MIN(bufsiz, BPF_DFLTBUFSIZE * 4);
 
        buf = malloc(bufsiz);
-       if (buf == NULL)
-               err(1, "malloc");
+       if (buf == NULL) {
+               log_debug("malloc: %s", strerror(errno));
+               return;
+       }
 
        quit = 0;
        signal(SIGTERM, sighandler);
@@ -118,7 +233,8 @@
        signal(SIGINT, sighandler);
        signal(SIGHUP, sighandler);
 
-       fprintf(stderr, "bpf open %s\n", ifr.ifr_name);
+       log_debug("start reading %s, bufsiz=%u", ifname, bufsiz);
+
        while (quit == 0) {
                pfd[PFD_BPF].fd = bpfd;
                pfd[PFD_BPF].events = POLLIN;
@@ -131,23 +247,13 @@
 
                if (nfds > 0 && (pfd[PFD_BPF].revents & POLLIN)) {
                        /* read & drop */
-                       memset(buf, 0, sizeof(bufsiz));
+                       memset(buf, 0, bufsiz);
                        n = read(pfd[PFD_BPF].fd, buf, bufsiz);
                        if (n < 0)
                                quit = 1;
                }
        }
 
-       close(bpfd);
+       log_debug("finish reading %s", ifname);
        free(buf);
-       fprintf(stderr, "closed\n");
-
-       return 0;
 }
-
-static void
-sighandler(int signo)
-{
-
-       quit = 1;
-}
diff -r bf0b5a182752 -r 146c3df7bbd2 tests/net/if_vlan/t_vlan.sh
--- a/tests/net/if_vlan/t_vlan.sh       Thu Aug 19 02:05:34 2021 +0000
+++ b/tests/net/if_vlan/t_vlan.sh       Thu Aug 19 03:27:05 2021 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: t_vlan.sh,v 1.23 2021/07/14 08:51:51 yamaguchi Exp $
+#      $NetBSD: t_vlan.sh,v 1.24 2021/08/19 03:27:05 yamaguchi Exp $
 #
 # Copyright (c) 2016 Internet Initiative Japan Inc.
 # All rights reserved.
@@ -929,6 +929,8 @@
        local atf_brconfig="atf_check -s exit:0 $HIJACKING /sbin/brconfig"
        local atf_arp="atf_check -s exit:0 rump.arp"
        local bpfopen="$HIJACKING $(atf_get_srcdir)/bpfopen"
+       bpfopen="$bpfopen -dv -b /rump/dev/bpf"
+       local pidfile="./bpfopen.pid"
        local macaddr=""
 



Home | Main Index | Thread Index | Old Index