Module Name:    src
Committed By:   yamaguchi
Date:           Fri Nov 12 05:34:46 UTC 2021

Modified Files:
        src/sys/net/lagg: if_lagg.c

Log Message:
lagg: Notify the changes of capenables of interface
to child interfaces


To generate a diff of this commit:
cvs rdiff -u -r1.21 -r1.22 src/sys/net/lagg/if_lagg.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/net/lagg/if_lagg.c
diff -u src/sys/net/lagg/if_lagg.c:1.21 src/sys/net/lagg/if_lagg.c:1.22
--- src/sys/net/lagg/if_lagg.c:1.21	Thu Nov 11 01:10:09 2021
+++ src/sys/net/lagg/if_lagg.c	Fri Nov 12 05:34:45 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: if_lagg.c,v 1.21 2021/11/11 01:10:09 yamaguchi Exp $	*/
+/*	$NetBSD: if_lagg.c,v 1.22 2021/11/12 05:34:45 yamaguchi Exp $	*/
 
 /*
  * Copyright (c) 2005, 2006 Reyk Floeter <r...@openbsd.org>
@@ -20,7 +20,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_lagg.c,v 1.21 2021/11/11 01:10:09 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_lagg.c,v 1.22 2021/11/12 05:34:45 yamaguchi Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -198,6 +198,8 @@ static void	lagg_port_syncvlan(struct la
 static void	lagg_port_purgevlan(struct lagg_softc *, struct lagg_port *);
 static void	lagg_lladdr_update(struct lagg_softc *);
 static void	lagg_capabilities_update(struct lagg_softc *);
+static void	lagg_sync_ifcaps(struct lagg_softc *);
+static void	lagg_sync_ethcaps(struct lagg_softc *);
 
 static struct if_clone	 lagg_cloner =
     IF_CLONE_INITIALIZER("lagg", lagg_clone_create, lagg_clone_destroy);
@@ -780,6 +782,16 @@ lagg_ioctl(struct ifnet *ifp, u_long cmd
 			error = EPROTONOSUPPORT;
 		}
 		break;
+	case SIOCSIFCAP:
+		error = ether_ioctl(ifp, cmd, data);
+		if (error == 0)
+			lagg_sync_ifcaps(sc);
+		break;
+	case SIOCSETHERCAP:
+		error = ether_ioctl(ifp, cmd, data);
+		if (error == 0)
+			lagg_sync_ethcaps(sc);
+		break;
 	default:
 		error = ether_ioctl(ifp, cmd, data);
 	}
@@ -1837,6 +1849,29 @@ lagg_setifcaps(struct lagg_port *lp, uin
 	return error;
 }
 
+static void
+lagg_sync_ifcaps(struct lagg_softc *sc)
+{
+	struct lagg_port *lp;
+	struct ifnet *ifp;
+	int error = 0;
+
+	ifp = (struct ifnet *)&sc->sc_if;
+
+	LAGG_LOCK(sc);
+	LAGG_PORTS_FOREACH(sc, lp) {
+		error = lagg_setifcaps(lp, ifp->if_capenable);
+
+		if (error != 0) {
+			lagg_log(sc, LOG_WARNING,
+			    "failed to update capabilities "
+			    "of %s, error=%d",
+			    lp->lp_ifp->if_xname, error);
+		}
+	}
+	LAGG_UNLOCK(sc);
+}
+
 static int
 lagg_setethcaps(struct lagg_port *lp, int cap)
 {
@@ -1861,6 +1896,32 @@ lagg_setethcaps(struct lagg_port *lp, in
 }
 
 static void
+lagg_sync_ethcaps(struct lagg_softc *sc)
+{
+	struct ethercom *ec;
+	struct lagg_port *lp;
+	int error;
+
+	ec = (struct ethercom *)&sc->sc_if;
+
+	LAGG_LOCK(sc);
+	LAGG_PORTS_FOREACH(sc, lp) {
+		if (lp->lp_iftype != IFT_ETHER)
+			continue;
+
+		error = lagg_setethcaps(lp, ec->ec_capenable);
+		if (error != 0) {
+			lagg_log(sc, LOG_WARNING,
+			    "failed to update ether "
+			    "capabilities"" of %s, error=%d",
+			    lp->lp_ifp->if_xname, error);
+		}
+
+	}
+	LAGG_UNLOCK(sc);
+}
+
+static void
 lagg_ifcap_update(struct lagg_softc *sc)
 {
 	struct ifnet *ifp;

Reply via email to