Bug 260439 - net/vether-kmod: Update to g20211215
Summary: net/vether-kmod: Update to g20211215
Status: Closed FIXED
Alias: None
Product: Ports & Packages
Classification: Unclassified
Component: Individual Port(s) (show other bugs)
Version: Latest
Hardware: Any Any
: --- Affects Only Me
Assignee: freebsd-ports-bugs (Nobody)
URL: http://github.com/hmatyschok/if_vether
Keywords: needs-qa
Depends on:
Blocks:
 
Reported: 2021-12-15 16:02 UTC by henning.matyschok
Modified: 2021-12-18 00:19 UTC (History)
10 users (show)

See Also:
koobs: merge-quarterly?


Attachments
Patch against distinfo and Makefile, g20211214 (1.47 KB, patch)
2021-12-15 16:02 UTC, henning.matyschok
henning.matyschok: maintainer-approval+
Details | Diff

Note You need to log in before you can comment on or make changes to this bug.
Description henning.matyschok 2021-12-15 16:02:36 UTC
Created attachment 230141 [details]
Patch against distinfo and Makefile, g20211214

Therfore, update to g20211215, reason:

Index: sys/net/if_vether.c
===================================================================
--- sys/net/if_vether.c (nonexistent)
+++ sys/net/if_vether.c (working copy)
@@ -0,0 +1,449 @@
+/*
+ * Copyright (c) 2009 Theo de Raadt
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+/*
+ * Copyright (c) 2018, 2021 Henning Andersen Matyschok, DARPA/AFRL
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
+ * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+
+__FBSDID("$FreeBSD$");
+
+#include <sys/param.h>
+#include <sys/kernel.h>
+#include <sys/module.h>
+#include <sys/socket.h>
+#include <sys/sockio.h>
+
+#include <net/if.h>
+#include <net/if_var.h>
+#include <net/if_clone.h>
+#include <net/if_dl.h>
+#include <net/if_media.h>
+#include <net/netisr.h>
+#include <net/if_types.h>
+#include <net/bpf.h>
+#include <net/ethernet.h>
+#include <net/if_bridgevar.h>
+#include <net/vnet.h>
+
+/*
+ * Virtual Ethernet interface, ported from OpenBSD. This interface
+ * operates in conjunction with if_bridge(4).
+ */
+
+struct vether_softc {
+    struct ifmedia  sc_ifm;     /* fake media information */
+    struct ifnet    *sc_ifp;    /* network interface. */
+};
+#define VETHER_IF_FLAGS     (IFF_SIMPLEX|IFF_BROADCAST|IFF_MULTICAST)
+#define VETHER_IFCAP_FLAGS  (IFCAP_VLAN_MTU|IFCAP_JUMBO_MTU)
+#define VETHER_IFM_FLAGS    (IFM_ETHER|IFM_AUTO)
+
+/*
+ * XXX
+ *  The set of protocol-numbers index-set
+ *  against <net/netisr.h> maps-to set
+ *  over (enum), e. g.:
+ *
+ *      typedef enum netisr_proto {
+ *          netisr_ip = NETISR_IP,
+ *          netisr_igmp = NETISR_IGMP,
+ *          netisr_route = NETISR_ROUTE,
+ *          netisr_arp = NETISR_ARP,
+ *          netisr_ether = NETISR_ETHER,
+ *          netisr_ipv6 = NETISR_IPV6,
+ *          netisr_epair = NETISR_EPAIR,
+ *          netisr_ip_direct = NETISR_IP_DIRECT,
+ *          netisr_ipv6_direct = NETISR_IPV6_DIRECT,
+ *          netisr_vether = NETISR_VETHER_FWD,
+ *      } netisr_proto_t;
+ */
+#define NETISR_VETHER_FWD   11
+
+typedef enum vether_netisr_component {
+    vether_netisr_fwd = NETISR_VETHER_FWD,
+} vether_netisr_component_t;
+
+static void     vether_ifaddr_init(struct ifnet *, struct ether_addr *);
+static void     vether_encap(struct mbuf *);
+static void     vether_texeof(struct ifnet *);
+
+static void     vether_init(void *);
+static void     vether_stop(struct ifnet *);
+static void     vether_start(struct ifnet *);
+
+static int  vether_ifmedia_upd(struct ifnet *);
+static void     vether_ifmedia_req(struct ifnet *, struct ifmediareq *);
+static int  vether_ioctl(struct ifnet *, u_long, caddr_t);
+
+static int  vether_clone_create(struct if_clone *, int, caddr_t);
+static void     vether_clone_destroy(struct ifnet *);
+
+static struct netisr_handler vether_nh_fwd = {
+    .nh_name = "Softintr. for if_vether(4)",
+    .nh_handler = vether_encap,
+    .nh_proto = vether_netisr_fwd,
+    .nh_policy = NETISR_POLICY_FLOW,
+};
+static const char vether_name[] = "vether";
+
+VNET_DEFINE(struct if_clone *, vether_cloner);
+#define V_vether_cloner VNET(vether_cloner)
+
+static int
+vether_clone_create(struct if_clone *ifc, int unit, caddr_t data)
+{
+    struct vether_softc *sc;
+    struct ifnet *ifp;
+    struct ether_addr lla;
+    int up_call;
+
+    /*
+     * For safety reason, there is a condition test applied -
+     * independently, if M_WAITOK was enabled or not.
+     */
+
+    if ((sc = malloc(sizeof(struct vether_softc),
+            M_DEVBUF, M_WAITOK|M_ZERO)) != NULL) {
+
+        if ((ifp = if_alloc(IFT_ETHER)) != NULL) {
+            sc->sc_ifp = ifp;
+            ifp->if_softc = sc;
+
+            if_initname(ifp, vether_name, unit);
+
+            ifp->if_init = vether_init;
+            ifp->if_ioctl = vether_ioctl;
+            ifp->if_start = vether_start;
+
+            ifp->if_flags = VETHER_IF_FLAGS;
+
+            ifp->if_capabilities = VETHER_IFCAP_FLAGS;
+            ifp->if_capenable = VETHER_IFCAP_FLAGS;
+
+            ifp->if_baudrate = 0;
+
+            ifmedia_init(&sc->sc_ifm, 0, vether_ifmedia_upd,
+                vether_ifmedia_req);
+            ifmedia_add(&sc->sc_ifm, VETHER_IFM_FLAGS, 0, NULL);
+            ifmedia_set(&sc->sc_ifm, VETHER_IFM_FLAGS);
+
+            vether_ifaddr_init(ifp, &lla);
+            ether_ifattach(ifp, lla.octet);
+
+            up_call = 0;
+        } else {
+            up_call = ENOSPC;
+            free(sc, M_DEVBUF);
+        }
+    } else
+        up_call = ENOBUFS;
+
+    return (up_call);
+}
+
+static void
+vether_clone_destroy(struct ifnet *ifp)
+{
+    struct vether_softc *sc;
+
+    if (ifp != NULL) {
+        ifp->if_flags &= ~IFF_UP;
+
+        vether_stop(ifp);
+
+        if ((sc = ifp->if_softc) != NULL) {
+            free(sc, M_DEVBUF);
+            ifp->if_softc = NULL;
+        }
+        ether_ifdetach(ifp);
+        if_free(ifp);
+    }
+}
+
+static void
+vnet_vether_init(const void *unused __unused)
+{
+
+    V_vether_cloner = if_clone_simple(vether_name,
+        vether_clone_create, vether_clone_destroy, 0);
+}
+VNET_SYSINIT(vnet_vether_init, SI_SUB_PROTO_IFATTACHDOMAIN, SI_ORDER_ANY,
+    vnet_vether_init, NULL);
+
+static void
+vnet_vether_uninit(const void *unused __unused)
+{
+
+    if_clone_detach(V_vether_cloner);
+}
+VNET_SYSUNINIT(vnet_vether_uninit, SI_SUB_PSEUDO, SI_ORDER_ANY,
+    vnet_vether_uninit, NULL);
+
+static int
+vether_mod_event(module_t mod, int event, void *data)
+{
+    switch (event) {
+    case MOD_LOAD:
+        netisr_register(&vether_nh_fwd);
+        return (0);
+    case MOD_UNLOAD:
+        netisr_unregister(&vether_nh_fwd);
+        return (0);
+    default:
+        break;
+    }
+    return (EOPNOTSUPP);
+}
+
+static moduledata_t vether_mod = {
+    "if_vether",
+    vether_mod_event,
+    0,
+};
+DECLARE_MODULE(if_vether, vether_mod, SI_SUB_PSEUDO, SI_ORDER_ANY);
+
+/*
+ * I/O.
+ */
+
+static void
+vether_txeof(struct ifnet *ifp)
+{
+    struct mbuf *m;
+
+    if (ifp != NULL) {
+        IFQ_DEQUEUE(&ifp->if_snd, m);
+        if (m != NULL) {
+            BPF_MTAP(ifp, m);
+
+            if ((m->m_flags & M_PKTHDR) != 0) {
+
+                /* do some statistics */
+
+                if_inc_counter(ifp, IFCOUNTER_OBYTES, m->m_pkthdr.len);
+                if_inc_counter(ifp, IFCOUNTER_OPACKETS, 1);
+
+                /* discard, if not member of if_bridge(4) */
+                if (ifp->if_bridge == NULL)
+                    m->m_pkthdr.rcvif = ifp;
+
+                /*
+                 * Three cases are considered here:
+                 *
+                 *  (a) Frame was tx'd by layer above.
+                 *
+                 *  (b) Frame was rx'd by link-layer.
+                 *
+                 *  (c) Data sink.
+                 */
+                if (m->m_pkthdr.rcvif == NULL) {
+                    m->m_pkthdr.rcvif = ifp;
+                    netisr_dispatch(vether_netisr_fwd, m);
+                } else if (m->m_pkthdr.rcvif != ifp) {
+                    m->m_pkthdr.rcvif = ifp;
+
+                    /* demultiplex any other frame */
+                    (*ifp->if_input)(ifp, m);
+                } else {
+                    m_freem(m);
+                    m = NULL;
+                }
+
+            } else {
+                if_inc_counter(ifp, IFCOUNTER_OERRORS, 1);
+
+                m_freem(m);
+                m = NULL;
+            }
+            vether_txeof(ifp);
+        }
+    }
+}
+
+static void
+vether_start(struct ifnet *ifp)
+{
+    if ((ifp->if_flags & IFF_UP) != 0) {
+        ifp->if_drv_flags |= IFF_DRV_OACTIVE;
+        vether_txeof(ifp);
+        ifp->if_drv_flags &= ~IFF_DRV_OACTIVE;
+    }
+}
+
+/*
+ * Broadcast frame by if_bridge(4).
+ */
+
+static void
+vether_encap(struct mbuf *m)
+{
+    struct ifnet *ifp;
+    int up_call;
+
+    if (m != NULL) {
+
+        if ((m->m_flags & M_PKTHDR) != 0) {
+
+            if ((ifp = m->m_pkthdr.rcvif) != NULL) {
+
+                if (ifp->if_mtu > m->m_pkthdr.len)
+                    m_freem(m);
+                else {
+                    BRIDGE_OUTPUT(ifp, m, up_call);
+
+                    if (up_call != 0)
+                        m_freem(m);
+                }
+            } else
+                m_freem(m);
+        } else
+            m_freem(m);
+    }
+}
+
+/*
+ * Initialize lla.
+ */
+
+static void
+vether_ifaddr_init(struct ifnet *ifp, struct ether_addr *lla)
+{
+    caddr_t pfx, sfx;
+
+    if (ifp != NULL) {
+
+        if (lla != NULL) {
+            pfx = lla->octet;
+            pfx[0] = 0x02;
+
+            sfx = (pfx + 1);
+            arc4rand(sfx, 5, 0);
+        }
+    }
+}
+
+static int
+vether_ifmedia_upd(struct ifnet *ifp)
+{
+    int up_call;
+
+    if (ifp != NULL)
+        up_call = 0;
+    else
+        up_call = EADDRNOTAVAIL;
+
+    return (up_call);
+}
+
+static void
+vether_ifmedia_req(struct ifnet *ifp, struct ifmediareq *ifm)
+{
+    if (ifp != NULL) {
+
+        if (ifm != NULL) {
+            ifm->ifm_active = (IFM_ETHER|IFM_AUTO);
+            ifm->ifm_status = (IFM_AVALID|IFM_ACTIVE);
+        }
+    }
+}
+
+static void
+vether_init(void *xsc)
+{
+    struct vether_softc *sc;
+    struct ifnet *ifp;
+
+    if ((sc = (struct vether_softc *)xsc) != NULL) {
+
+        if ((ifp = sc->sc_ifp) != NULL) {
+            ifp->if_drv_flags |= IFF_DRV_RUNNING;
+            ifp->if_drv_flags &= ~IFF_DRV_OACTIVE;
+        }
+    }
+}
+
+static void
+vether_stop(struct ifnet *ifp)
+{
+    if (ifp != NULL)
+        ifp->if_drv_flags &= ~(IFF_DRV_RUNNING|IFF_DRV_OACTIVE);
+}
+
+static int
+vether_ioctl(struct ifnet *ifp, u_long req, caddr_t argp)
+{
+    struct vether_softc *sc;
+    struct ifreq *ifr;
+    int up_call;
+
+    if (ifp != NULL) {
+
+        if ((sc = ifp->if_softc) != NULL) {
+            ifr = (struct ifreq *)argp;
+
+            switch (req) {
+            case SIOCSIFMTU:
+                if (ifr->ifr_mtu < ETHER_MAX_LEN_JUMBO) {
+                    ifp->if_mtu = ifr->ifr_mtu;
+                    up_call = 0;
+                } else
+                    up_call = EINVAL;
+                break;
+            case SIOCSIFMEDIA:  /* Media types can't be changed. */
+            case SIOCGIFMEDIA:
+                up_call = ifmedia_ioctl(ifp, ifr, &sc->sc_ifm, req);
+                break;
+            case SIOCSIFFLAGS:
+            case SIOCADDMULTI:
+            case SIOCDELMULTI:
+                up_call = 0;
+                break;
+            case SIOCSIFPHYS:
+                up_call = EOPNOTSUPP;
+                break;
+            default:
+                up_call = ether_ioctl(ifp, req, argp);
+                break;
+            }
+        } else
+            up_call = ENXIO;
+    } else
+        up_call = ENOTTY;
+
+    return (up_call);
+}

Resursively dequeuement of mbuf{}s against (if_snd, ifnet{}) enqueued Frames during runtime of ((if_start, ifnet{}), vether_start(9)) and vether_txeof(9). Finally, cond.-tests against mtu over (if_mtu, ifnet{}), prformend by netisr(4)-component provided softintr., etc..

Therefore, this operation results in present patch:

diff --git a/net/vether-kmod/Makefile b/net/vether-kmod/Makefile
index 51dc96828b5b..eed42ad4a065 100644
--- a/net/vether-kmod/Makefile
+++ b/net/vether-kmod/Makefile
@@ -1,8 +1,8 @@
 PORTNAME=      vether-kmod
-DISTVERSION=   g20190422
+DISTVERSION=   g20211214
 CATEGORIES=    net
 
-MAINTAINER=    henning.matyschok@outlook.com
+MAINTAINER=    publicweb@us.af.mil
 COMMENT=       Virtual Ethernet Interface
 
 LICENSE=       BSD2CLAUSE ISCL
@@ -13,7 +13,7 @@ USES=         kmod uidfix
 USE_GITHUB=    yes
 GH_ACCOUNT=    hmatyschok
 GH_PROJECT=    if_vether
-GH_TAGNAME=    ecc91f865218f2bb85521b285c8f7f81198aa553
+GH_TAGNAME=    511ee3b393029cfff0c5b1873fe0a16f077a7459
 
 PLIST_FILES=   ${KMODDIR}/if_vether.ko \
                man/man4/if_vether.4.gz \
diff --git a/net/vether-kmod/distinfo b/net/vether-kmod/distinfo
index 4d14d86a02bc..9b59f036d5d4 100644
--- a/net/vether-kmod/distinfo
+++ b/net/vether-kmod/distinfo
@@ -1,3 +1,3 @@
-TIMESTAMP = 1555928075
-SHA256 (hmatyschok-if_vether-g20190422-ecc91f865218f2bb85521b285c8f7f81198aa553_GH0.tar.gz) = 85b4280715707734bac06cf8d950a11b6cd6f4ff8a2b61c684e16c86f92f5f7d
-SIZE (hmatyschok-if_vether-g20190422-ecc91f865218f2bb85521b285c8f7f81198aa553_GH0.tar.gz) = 7015
+TIMESTAMP = 1639499475
+SHA256 (hmatyschok-if_vether-g20211214-511ee3b393029cfff0c5b1873fe0a16f077a7459_GH0.tar.gz) = a97a5fd68d6f13f6114fcadd0d5ef59766b8e088466b8c33e5fd035bc08edaf8
+SIZE (hmatyschok-if_vether-g20211214-511ee3b393029cfff0c5b1873fe0a16f077a7459_GH0.tar.gz) = 7936

and

Index: net/vether-kmod/Makefile
===================================================================
--- net/vether-kmod/Makefile	(revision 569609)
+++ net/vether-kmod/Makefile	(working copy)
@@ -1,10 +1,8 @@
-# $FreeBSD$
-
 PORTNAME=	vether-kmod
-DISTVERSION=	g20190422
+DISTVERSION=	g20211214
 CATEGORIES=	net
 
-MAINTAINER=	henning.matyschok@outlook.com
+MAINTAINER=	publicweb@us.af.mil
 COMMENT=	Virtual Ethernet Interface
 
 LICENSE=	BSD2CLAUSE ISCL
@@ -15,7 +13,7 @@
 USE_GITHUB=	yes
 GH_ACCOUNT=	hmatyschok
 GH_PROJECT=	if_vether
-GH_TAGNAME=	ecc91f865218f2bb85521b285c8f7f81198aa553
+GH_TAGNAME=	511ee3b393029cfff0c5b1873fe0a16f077a7459
 
 PLIST_FILES=	${KMODDIR}/if_vether.ko \
 		man/man4/if_vether.4.gz \
Index: net/vether-kmod/distinfo
===================================================================
--- net/vether-kmod/distinfo	(revision 569609)
+++ net/vether-kmod/distinfo	(working copy)
@@ -1,3 +1,3 @@
-TIMESTAMP = 1555928075
-SHA256 (hmatyschok-if_vether-g20190422-ecc91f865218f2bb85521b285c8f7f81198aa553_GH0.tar.gz) = 85b4280715707734bac06cf8d950a11b6cd6f4ff8a2b61c684e16c86f92f5f7d
-SIZE (hmatyschok-if_vether-g20190422-ecc91f865218f2bb85521b285c8f7f81198aa553_GH0.tar.gz) = 7015
+TIMESTAMP = 1639502634
+SHA256 (hmatyschok-if_vether-g20211214-511ee3b393029cfff0c5b1873fe0a16f077a7459_GH0.tar.gz) = a97a5fd68d6f13f6114fcadd0d5ef59766b8e088466b8c33e5fd035bc08edaf8
+SIZE (hmatyschok-if_vether-g20211214-511ee3b393029cfff0c5b1873fe0a16f077a7459_GH0.tar.gz) = 7936

Any duplicate work still invalidated and / or obsoleted by g20211214 in conjuction with reason, as stated before.

 Henning Andersen Matyschok, 120179M11214, USAF
 
United States Air-force (USAF)
Henning Andersen Matyschok
Wasserlooser Weg 5
Flensburg
24944 Germany
Comment 1 Kubilay Kocak freebsd_committer freebsd_triage 2021-12-16 00:57:28 UTC
Should this be merged to the quarterly branch?
Comment 2 henning.matyschok 2021-12-16 14:38:20 UTC
(In reply to Kubilay Kocak from comment #1)

> Should this be merged to the quarterly branch?

No.

 Henning Andersen Matyschok, 120179M11214, USAF

U.S. Air Force
Henning Andersen Matyschok
Wasserlooser Weg 5
Flensburg
24944 Germany
Comment 3 henning.matyschok 2021-12-16 15:00:32 UTC
Would you please commit patches about recent changes, due to version g20211214?

 Henning Andersen Matyschok, 120179M11214, USAF

U.S. Air Force
Henning Andersen Matyschok
Wasserlooser Weg 5
Flensburg
24944 Germany
Comment 4 commit-hook freebsd_committer freebsd_triage 2021-12-17 07:15:11 UTC
A commit in branch main references this bug:

URL: https://cgit.FreeBSD.org/ports/commit/?id=c3b187a6bae9c76a9cc3ae63683687701db35f2d

commit c3b187a6bae9c76a9cc3ae63683687701db35f2d
Author:     Henning Matyschok <henning.matyschok@outlook.com>
AuthorDate: 2021-12-17 07:13:32 +0000
Commit:     Tobias C. Berner <tcberner@FreeBSD.org>
CommitDate: 2021-12-17 07:13:57 +0000

    net/vether-kmod: update to 20211214

    PR:             260439

 net/vether-kmod/Makefile | 4 ++--
 net/vether-kmod/distinfo | 6 +++---
 2 files changed, 5 insertions(+), 5 deletions(-)
Comment 5 henning.matyschok 2021-12-17 11:50:00 UTC
(In reply to commit-hook from comment #4)
>
> A commit in branch main references this bug:
>
> URL: https://cgit.FreeBSD.org/ports/commit/id=c3b187a6bae9c76a9cc3ae63683687701db35f2d
>
> commit c3b187a6bae9c76a9cc3ae63683687701db35f2d
> Author:     Henning Matyschok <henning.matyschok@outlook.com>
> AuthorDate: 2021-12-17 07:13:32 +0000
> Commit:     Tobias C. Berner <tcberner@FreeBSD.org>
> CommitDate: 2021-12-17 07:13:57 +0000
>
>    net/vether-kmod: update to 20211214
>
>    PR:             260439

> net/vether-kmod/Makefile | 4 ++--
> net/vether-kmod/distinfo | 6 +++---
> 2 files changed, 5 insertions(+), 5 deletions(-)
>

Mr. Berner,

the authors Theo de Raadt and Henning Andersen Matyschok (120179M11214, USAF) are not employed and / or contarctors with Mr. Tobias C. Berner and / or employer of Mr. Tobias C. Berner.

Therefore, please send a note about this conversation to Mr. Theo de Raadt by mail, e. g. tech@openbsd.org, due to documentation purpuses.

 Henning Andersen Matyschok, 120179M11214, USAF

United States Air Force (USAF)
Henning Andersen Matyschok
Wasserlooser Weg 5
Flensburg
24944 Germany
Comment 6 henning.matyschok 2021-12-17 11:52:25 UTC
(In reply to Henning Matyschok from comment #5)
>
> A commit in branch main references this bug:

>
> URL: https://cgit.FreeBSD.org/ports/commit/id=c3b187a6bae9c76a9cc3ae63683687701db35f2d

>
> commit c3b187a6bae9c76a9cc3ae63683687701db35f2d
> Author:     Henning Matyschok <henning.matyschok@outlook.com>
> AuthorDate: 2021-12-17 07:13:32 +0000
> Commit:     Tobias C. Berner <tcberner@FreeBSD.org>
> CommitDate: 2021-12-17 07:13:57 +0000

>
>    net/vether-kmod: update to 20211214

>
>    PR:             260439


> net/vether-kmod/Makefile | 4 ++--
> net/vether-kmod/distinfo | 6 +++---
> 2 files changed, 5 insertions(+), 5 deletions(-)

>

Mr. Berner,

the authors Theo de Raadt and Henning Andersen Matyschok (120179M11214, USAF) are not employed by and / or contractors with Mr. Tobias C. Berner and / or employer of Mr. Tobias C. Berner and / or not employed by Mr. Tobias C. Berner and / or not employed by this company / business still employer of Mr. Tobias C. Berner.

Therefore, please send a note about this conversation to Mr. Theo de Raadt by mail, e. g. tech@openbsd.org, due to documentation purpuses.

 Henning Andersen Matyschok, 120179M11214, USAF

United States Air Force (USAF)
Henning Andersen Matyschok
Wasserlooser Weg 5
Flensburg
24944 Germany
Comment 7 henning.matyschok 2021-12-17 11:58:20 UTC
Therefore,

information about employement-situation of Henning Andersen Matyschok still provided, e. g. either by  https://github.com/hmatyschok or HQ EUCOM J1, because of re-enlistement since 2000 at TCA Tempelhof, Berlin-Brigade.

 Henning Andersen Matyschok, 120179M11214, USAF

United States Air Force (USAF)
Henning Andersen Matyschok
Wasserlooser Weg 5
Flensburg
24944 Germany
Comment 8 henning.matyschok 2021-12-17 22:29:31 UTC
Copyright about if_vether(4) holds Theo de Raadt and the Air Force Research Laboratories.

 Henning Andersen Matyschok, 120179M11214, USAF

United States Air Force (USAF)
Henning Andersen Matyschok
Wasserlooser Weg 5, 6th floor
Flensburg
24944 Germany