Source-Changes-HG archive

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

[src/trunk]: src/sys/net/lagg Make a link-layer address of lagg(4) configurab...



details:   https://anonhg.NetBSD.org/src/rev/c654b7138b64
branches:  trunk
changeset: 987516:c654b7138b64
user:      yamaguchi <yamaguchi%NetBSD.org@localhost>
date:      Thu Sep 30 04:23:30 2021 +0000

description:
Make a link-layer address of lagg(4) configurable by ifconfig(8)

lagg(4) uses a configured link-layer (MAC) address instead
of a random MAC address generated on creating.
The configured MAC address is copied to all child interface
and used for a system id of LACP.

diffstat:

 sys/net/lagg/if_lagg.c      |  637 +++++++++++++++++++++++++------------------
 sys/net/lagg/if_lagg_lacp.c |   35 +-
 sys/net/lagg/if_laggproto.h |    7 +-
 3 files changed, 383 insertions(+), 296 deletions(-)

diffs (truncated from 939 to 300 lines):

diff -r 04759e3edcd4 -r c654b7138b64 sys/net/lagg/if_lagg.c
--- a/sys/net/lagg/if_lagg.c    Thu Sep 30 04:20:14 2021 +0000
+++ b/sys/net/lagg/if_lagg.c    Thu Sep 30 04:23:30 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_lagg.c,v 1.8 2021/09/30 04:20:14 yamaguchi Exp $    */
+/*     $NetBSD: if_lagg.c,v 1.9 2021/09/30 04:23:30 yamaguchi Exp $    */
 
 /*
  * Copyright (c) 2005, 2006 Reyk Floeter <reyk%openbsd.org@localhost>
@@ -20,7 +20,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_lagg.c,v 1.8 2021/09/30 04:20:14 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_lagg.c,v 1.9 2021/09/30 04:23:30 yamaguchi Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -186,8 +186,13 @@
 static int     lagg_ether_delmulti(struct lagg_softc *, struct ifreq *);
 static void    lagg_port_syncmulti(struct lagg_softc *, struct lagg_port *);
 static void    lagg_port_purgemulti(struct lagg_softc *, struct lagg_port *);
+static int     lagg_port_setup(struct lagg_softc *, struct lagg_port *,
+                   struct ifnet *);
+static void    lagg_port_teardown(struct lagg_softc *, struct lagg_port *,
+                   bool);
 static void    lagg_port_syncvlan(struct lagg_softc *, struct lagg_port *);
 static void    lagg_port_purgevlan(struct lagg_softc *, struct lagg_port *);
+static void    lagg_lladdr_update(struct lagg_softc *);
 
 static struct if_clone  lagg_cloner =
     IF_CLONE_INITIALIZER("lagg", lagg_clone_create, lagg_clone_destroy);
@@ -209,7 +214,7 @@
 #define LAGG_DPRINTF(_sc, _fmt, _args...)      __nothing
 #endif
 
-static inline size_t
+static size_t
 lagg_sizeof_softc(enum lagg_iftypes ift)
 {
        struct lagg_softc *_dummy = NULL;
@@ -229,7 +234,7 @@
        return s;
 }
 
-static inline bool
+static bool
 lagg_debug_enable(struct lagg_softc *sc)
 {
        if (__predict_false(ISSET(sc->sc_if.if_flags, IFF_DEBUG)))
@@ -238,7 +243,7 @@
        return false;
 }
 
-static inline void
+static void
 lagg_evcnt_attach(struct lagg_softc *sc,
     struct evcnt *ev, const char *name)
 {
@@ -247,7 +252,7 @@
            sc->sc_evgroup, name);
 }
 
-static inline void
+static void
 lagg_in6_ifattach(struct ifnet *ifp)
 {
 
@@ -261,7 +266,7 @@
 #endif
 }
 
-static inline void
+static void
 lagg_in6_ifdetach(struct ifnet *ifp)
 {
 
@@ -274,7 +279,7 @@
 #endif
 }
 
-static inline int
+static int
 lagg_lp_ioctl(struct lagg_port *lp, u_long cmd, void *data)
 {
        struct ifnet *ifp_port;
@@ -291,6 +296,23 @@
        return error;
 }
 
+static bool
+lagg_lladdr_equal(const uint8_t *a, const uint8_t *b)
+{
+
+       if (memcmp(a, b, ETHER_ADDR_LEN) == 0)
+               return true;
+
+       return false;
+}
+
+static void
+lagg_lladdr_cpy(uint8_t *dst, const uint8_t *src)
+{
+
+       memcpy(dst, src, ETHER_ADDR_LEN);
+}
+
 void
 laggattach(int n)
 {
@@ -386,7 +408,8 @@
 
        switch (lagg_iftype) {
        case LAGG_IF_TYPE_ETHERNET:
-               cprng_fast(sc->sc_lladdr, sizeof(sc->sc_lladdr));
+               cprng_fast(sc->sc_lladdr_rand, sizeof(sc->sc_lladdr_rand));
+               lagg_lladdr_cpy(sc->sc_lladdr, sc->sc_lladdr_rand);
                ether_set_vlan_cb((struct ethercom *)ifp, lagg_vlan_cb);
                ether_ifattach(ifp, sc->sc_lladdr);
                break;
@@ -472,6 +495,8 @@
        if (ISSET(ifp->if_flags, IFF_RUNNING))
                lagg_stop_locked(sc);
 
+       lagg_lladdr_update(sc);
+
        SET(ifp->if_flags, IFF_RUNNING);
 
        rv = lagg_proto_up(sc);
@@ -1594,142 +1619,6 @@
                kmem_free(var, sizeof(*var));
 }
 
-static void
-lagg_lladdr_set(struct lagg_softc *sc, struct lagg_port *lp, u_long if_type)
-{
-       struct ifnet *ifp, *ifp_port;
-       const uint8_t *lladdr;
-
-       KASSERT(IFNET_LOCKED(&sc->sc_if));
-       KASSERT(LAGG_LOCKED(sc));
-
-       ifp = &sc->sc_if;
-       ifp_port = lp->lp_ifp;
-
-       if (ifp->if_type != IFT_ETHER)
-               return;
-
-       switch (lp->lp_iftype) {
-       case IFT_ETHER:
-               memcpy(lp->lp_lladdr, CLLADDR(ifp_port->if_sadl),
-                   ETHER_ADDR_LEN);
-
-               if (SIMPLEQ_EMPTY(&sc->sc_ports)) {
-                       if_set_sadl(ifp, CLLADDR(ifp_port->if_sadl),
-                           ETHER_ADDR_LEN, 0);
-                       LAGG_UNLOCK(sc);
-                       /* apply new IPv6LLA */
-                       lagg_in6_ifdetach(&sc->sc_if);
-                       lagg_in6_ifattach(&sc->sc_if);
-                       LAGG_LOCK(sc);
-               }
-
-               lladdr = CLLADDR(ifp->if_sadl);
-
-               if (lp->lp_iftype != if_type ||
-                   memcmp(lp->lp_lladdr, lladdr, ETHER_ADDR_LEN) != 0) {
-                       IFNET_LOCK(ifp_port);
-                       if_set_sadl(ifp_port, lladdr, ETHER_ADDR_LEN, false);
-                       IFNET_UNLOCK(ifp_port);
-               }
-               break;
-       }
-}
-
-static void
-lagg_lladdr_update(struct lagg_softc *sc)
-{
-       struct lagg_port *lp;
-       struct ifnet *ifp_port;
-       const uint8_t *lladdr;
-       bool stopped;
-       int error;
-
-       KASSERT(LAGG_LOCKED(sc));
-       KASSERT(sc->sc_if.if_type == IFT_ETHER);
-
-       lladdr = CLLADDR(sc->sc_if.if_sadl);
-
-       LAGG_PORTS_FOREACH(sc, lp) {
-               ifp_port = lp->lp_ifp;
-
-               if (memcmp(lladdr, CLLADDR(ifp_port->if_sadl),
-                   ETHER_ADDR_LEN) == 0) {
-                       continue;
-               }
-
-               IFNET_LOCK(ifp_port);
-               if (ISSET(ifp_port->if_flags, IFF_RUNNING)) {
-                       ifp_port->if_stop(ifp_port, 0);
-                       stopped = true;
-               } else {
-                       stopped = false;
-               }
-
-               if_set_sadl(ifp_port, lladdr, ETHER_ADDR_LEN, false);
-
-               if (stopped) {
-                       error = ifp_port->if_init(ifp_port);
-
-                       if (error != 0) {
-                               lagg_log(sc, LOG_WARNING,
-                                   "%s failed to if_init() on %d\n",
-                                   ifp_port->if_xname, error);
-                       }
-               }
-
-               IFNET_UNLOCK(ifp_port);
-       }
-}
-
-static void
-lagg_lladdr_unset(struct lagg_softc *sc, struct lagg_port *lp, u_int if_type)
-{
-       struct ifnet *ifp, *ifp_port;
-       struct lagg_port *lp0;
-
-       KASSERT(IFNET_LOCKED(&sc->sc_if));
-       KASSERT(LAGG_LOCKED(sc));
-
-       ifp = &sc->sc_if;
-       ifp_port = lp->lp_ifp;
-
-       if (ifp->if_type != IFT_ETHER)
-               return;
-
-       switch (lp->lp_iftype) {
-       case IFT_ETHER:
-               if (memcmp(lp->lp_lladdr, CLLADDR(ifp->if_sadl),
-                   ETHER_ADDR_LEN) == 0) {
-                       lp0 = SIMPLEQ_FIRST(&sc->sc_ports);
-                       if (lp0 == NULL) {
-                               if_set_sadl(ifp, sc->sc_lladdr,
-                                   ETHER_ADDR_LEN, 0);
-                       } else {
-                               if_set_sadl(ifp, lp0->lp_lladdr,
-                                   ETHER_ADDR_LEN, 0);
-                       }
-
-                       LAGG_UNLOCK(sc);
-                       lagg_in6_ifdetach(ifp);
-                       lagg_in6_ifattach(ifp);
-                       LAGG_LOCK(sc);
-
-                       lagg_lladdr_update(sc);
-               }
-
-               if (lp->lp_iftype != if_type ||
-                   memcmp(lp->lp_lladdr, CLLADDR(ifp_port->if_sadl),
-                   ETHER_ADDR_LEN) != 0) {
-                       IFNET_LOCK(ifp_port);
-                       if_set_sadl(ifp_port, lp->lp_lladdr,
-                           ETHER_ADDR_LEN, false);
-                       IFNET_UNLOCK(ifp_port);
-               }
-               break;
-       }
-}
-
 static int
 lagg_ether_addmulti(struct lagg_softc *sc, struct ifreq *ifr)
 {
@@ -1891,21 +1780,215 @@
 }
 
 static int
-lagg_addport_locked(struct lagg_softc *sc, struct lagg_port *lp)
+lagg_setup_mtu(struct lagg_softc *sc, struct lagg_port *lp)
+{
+       struct ifnet *ifp_port;
+       struct ifreq ifr;
+       int error;
+
+       ifp_port = lp->lp_ifp;
+       KASSERT(IFNET_LOCKED(ifp_port));
+
+       error = 0;
+       memset(&ifr, 0, sizeof(ifr));
+
+       if (SIMPLEQ_EMPTY(&sc->sc_ports)) {
+               ifr.ifr_mtu = lp->lp_mtu;
+       } else {
+               ifr.ifr_mtu = sc->sc_if.if_mtu;
+       }
+
+       if (sc->sc_if.if_mtu != (uint64_t)ifr.ifr_mtu) {
+               sc->sc_if.if_mtu = ifr.ifr_mtu;
+       }
+
+       if (lp->lp_mtu != (uint64_t)ifr.ifr_mtu) {



Home | Main Index | Thread Index | Old Index