Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/net tap: Report link state based on if the interface has...
details: https://anonhg.NetBSD.org/src/rev/f1d2880ce350
branches: trunk
changeset: 1014613:f1d2880ce350
user: roy <roy%NetBSD.org@localhost>
date: Sun Sep 27 13:44:47 2020 +0000
description:
tap: Report link state based on if the interface has been opened or not
While a nice addition, it does render tap(4) useless as a bridge(4)
endpoint. We now have vether(4) for use as bridge endpoint.
diffstat:
share/man/man4/tap.4 | 16 ++++++++++++++--
sys/net/if_tap.c | 12 ++++++++----
2 files changed, 22 insertions(+), 6 deletions(-)
diffs (95 lines):
diff -r f4e8fd07a368 -r f1d2880ce350 share/man/man4/tap.4
--- a/share/man/man4/tap.4 Sun Sep 27 13:31:04 2020 +0000
+++ b/share/man/man4/tap.4 Sun Sep 27 13:44:47 2020 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: tap.4,v 1.12 2018/08/14 06:21:36 maxv Exp $
+.\" $NetBSD: tap.4,v 1.13 2020/09/27 13:44:47 roy Exp $
.\"
.\" Copyright (c) 2004, 2005 The NetBSD Foundation.
.\" All rights reserved.
@@ -24,7 +24,7 @@
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
.\" POSSIBILITY OF SUCH DAMAGE.
.\"
-.Dd August 14, 2018
+.Dd September 27, 2020
.Dt TAP 4
.Os
.Sh NAME
@@ -170,9 +170,21 @@
.Xr bridge 4 ,
.Xr l2tp 4 ,
.Xr tun 4 ,
+.Xr vether 4 ,
.Xr ifconfig 8
.Sh HISTORY
The
.Nm
driver first appeared in
.Nx 3.0 .
+.Sh CAVEATS
+Starting from
+.Nx 10.0 ,
+the
+.Nm
+driver can no longer be used as a
+.Xr bridge 4
+endpoint because it supports a link state based on if it has been opened or not.
+Use the
+.Xr vether 4
+driver instead as it's been explicitly designed for this purpose.
diff -r f4e8fd07a368 -r f1d2880ce350 sys/net/if_tap.c
--- a/sys/net/if_tap.c Sun Sep 27 13:31:04 2020 +0000
+++ b/sys/net/if_tap.c Sun Sep 27 13:44:47 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_tap.c,v 1.118 2020/09/26 19:38:45 roy Exp $ */
+/* $NetBSD: if_tap.c,v 1.119 2020/09/27 13:44:47 roy Exp $ */
/*
* Copyright (c) 2003, 2004, 2008, 2009 The NetBSD Foundation.
@@ -33,7 +33,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_tap.c,v 1.118 2020/09/26 19:38:45 roy Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_tap.c,v 1.119 2020/09/27 13:44:47 roy Exp $");
#if defined(_KERNEL_OPT)
@@ -334,9 +334,8 @@
strcpy(ifp->if_xname, device_xname(self));
ifp->if_softc = sc;
ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST;
- ifp->if_extflags = IFEF_NO_LINK_STATE_CHANGE;
#ifdef NET_MPSAFE
- ifp->if_extflags |= IFEF_MPSAFE;
+ ifp->if_extflags = IFEF_MPSAFE;
#endif
ifp->if_ioctl = tap_ioctl;
ifp->if_start = tap_start;
@@ -358,6 +357,8 @@
}
ifp->if_percpuq = if_percpuq_create(ifp);
ether_ifattach(ifp, enaddr);
+ /* Opening the device will bring the link state up. */
+ ifp->if_link_state = LINK_STATE_DOWN;
if_register(ifp);
/*
@@ -708,6 +709,8 @@
if (sc->sc_flags & TAP_INUSE)
return EBUSY;
sc->sc_flags |= TAP_INUSE;
+ if_link_state_change(&sc->sc_ec.ec_if, LINK_STATE_UP);
+
return 0;
}
@@ -844,6 +847,7 @@
sc->sc_sih = NULL;
}
sc->sc_flags &= ~(TAP_INUSE | TAP_ASYNCIO);
+ if_link_state_change(ifp, LINK_STATE_DOWN);
return 0;
}
Home |
Main Index |
Thread Index |
Old Index