Source-Changes-HG archive

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

[src/trunk]: src/sys/net/agr Switch agr(4) to use a workqueue. This is necess...



details:   https://anonhg.NetBSD.org/src/rev/40e109344b1c
branches:  trunk
changeset: 350962:40e109344b1c
user:      maya <maya%NetBSD.org@localhost>
date:      Sat Jan 28 22:56:09 2017 +0000

description:
Switch agr(4) to use a workqueue. This is necessary because during
a callout, it allocates memory with M_WAITOK, which triggers a
DEBUG assert.

XXX we should drain the workqueue.

ok riastradh

diffstat:

 sys/net/agr/if_agr.c         |  11 ++++++++---
 sys/net/agr/if_agrmonitor.c  |  10 ++--------
 sys/net/agr/if_agrtimer.c    |  23 ++++++++++++++++++++---
 sys/net/agr/if_agrvar_impl.h |   7 +++++--
 4 files changed, 35 insertions(+), 16 deletions(-)

diffs (170 lines):

diff -r b9bde94dd1b6 -r 40e109344b1c sys/net/agr/if_agr.c
--- a/sys/net/agr/if_agr.c      Sat Jan 28 22:25:44 2017 +0000
+++ b/sys/net/agr/if_agr.c      Sat Jan 28 22:56:09 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_agr.c,v 1.40 2016/12/15 09:28:06 ozaki-r Exp $      */
+/*     $NetBSD: if_agr.c,v 1.41 2017/01/28 22:56:09 maya Exp $ */
 
 /*-
  * Copyright (c)2005 YAMAMOTO Takashi,
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_agr.c,v 1.40 2016/12/15 09:28:06 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_agr.c,v 1.41 2017/01/28 22:56:09 maya Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -343,14 +343,19 @@
 {
        struct agr_softc *sc;
        struct ifnet *ifp;
+       int error;
 
        sc = agr_alloc_softc();
+       error = agrtimer_init(sc);
+       if (error) {
+               agr_free_softc(sc);
+               return error;
+       }
        TAILQ_INIT(&sc->sc_ports);
        mutex_init(&sc->sc_lock, MUTEX_DEFAULT, IPL_NET);
        mutex_init(&sc->sc_entry_mtx, MUTEX_DEFAULT, IPL_NONE);
        cv_init(&sc->sc_insc_cv, "agrsoftc");
        cv_init(&sc->sc_ports_cv, "agrports");
-       agrtimer_init(sc);
        ifp = &sc->sc_if;
        snprintf(ifp->if_xname, sizeof(ifp->if_xname), "%s%d",
            ifc->ifc_name, unit);
diff -r b9bde94dd1b6 -r 40e109344b1c sys/net/agr/if_agrmonitor.c
--- a/sys/net/agr/if_agrmonitor.c       Sat Jan 28 22:25:44 2017 +0000
+++ b/sys/net/agr/if_agrmonitor.c       Sat Jan 28 22:56:09 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_agrmonitor.c,v 1.4 2008/03/24 09:14:52 yamt Exp $   */
+/*     $NetBSD: if_agrmonitor.c,v 1.5 2017/01/28 22:56:09 maya Exp $   */
 
 /*-
  * Copyright (c)2005 YAMAMOTO Takashi,
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_agrmonitor.c,v 1.4 2008/03/24 09:14:52 yamt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_agrmonitor.c,v 1.5 2017/01/28 22:56:09 maya Exp $");
 
 #include <sys/param.h>
 #include <sys/callout.h>
@@ -46,12 +46,6 @@
        u_int media;
        u_int status;
 
-       /*
-        * XXX XXX
-        * assuming that it's safe to use SIOCGIFMEDIA from callout handler.
-        * maybe it's better to have a worker thread.
-        */
-
        media = IFM_ETHER | IFM_NONE;
        status = IFM_AVALID;
        if ((~port->port_ifp->if_flags & (IFF_RUNNING | IFF_UP))
diff -r b9bde94dd1b6 -r 40e109344b1c sys/net/agr/if_agrtimer.c
--- a/sys/net/agr/if_agrtimer.c Sat Jan 28 22:25:44 2017 +0000
+++ b/sys/net/agr/if_agrtimer.c Sat Jan 28 22:56:09 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_agrtimer.c,v 1.6 2010/02/08 17:59:06 dyoung Exp $   */
+/*     $NetBSD: if_agrtimer.c,v 1.7 2017/01/28 22:56:09 maya Exp $     */
 
 /*-
  * Copyright (c)2005 YAMAMOTO Takashi,
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_agrtimer.c,v 1.6 2010/02/08 17:59:06 dyoung Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_agrtimer.c,v 1.7 2017/01/28 22:56:09 maya Exp $");
 
 #include <sys/param.h>
 #include <sys/callout.h>
@@ -40,14 +40,22 @@
 #include <net/agr/if_agrsubr.h>
 
 static void agrtimer_tick(void *);
+static void agrtimer_work(struct work *, void *);
 static int agrtimer_port_tick(struct agr_port *, void *);
 
-void
+int
 agrtimer_init(struct agr_softc *sc)
 {
+       int error;
+
+       error = workqueue_create(&sc->sc_wq, "agrmon",
+           agrtimer_work, sc, PRI_SOFTNET, IPL_SOFTNET, 0);
+       if (error)
+               return error;
 
        callout_init(&sc->sc_callout, 0);
        callout_setfunc(&sc->sc_callout, agrtimer_tick, sc);
+       return 0;
 }
 
 void
@@ -55,6 +63,7 @@
 {
 
        callout_destroy(&sc->sc_callout);
+       workqueue_destroy(sc->sc_wq);
 }
 
 void
@@ -75,6 +84,14 @@
 agrtimer_tick(void *arg)
 {
        struct agr_softc *sc = arg;
+
+       workqueue_enqueue(sc->sc_wq, &sc->sc_wk, NULL);
+}
+
+static void
+agrtimer_work(struct work *wk, void *arg)
+{
+       struct agr_softc *sc = arg;
        const struct agr_iftype_ops *iftop = sc->sc_iftop;
 
        KASSERT(iftop);
diff -r b9bde94dd1b6 -r 40e109344b1c sys/net/agr/if_agrvar_impl.h
--- a/sys/net/agr/if_agrvar_impl.h      Sat Jan 28 22:25:44 2017 +0000
+++ b/sys/net/agr/if_agrvar_impl.h      Sat Jan 28 22:56:09 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_agrvar_impl.h,v 1.10 2010/05/26 23:46:44 dyoung Exp $       */
+/*     $NetBSD: if_agrvar_impl.h,v 1.11 2017/01/28 22:56:09 maya Exp $ */
 
 /*-
  * Copyright (c)2005 YAMAMOTO Takashi,
@@ -35,6 +35,7 @@
 
 #include <sys/mutex.h>
 #include <sys/queue.h>
+#include <sys/workqueue.h>
 
 struct agr_port;
 struct agr_softc;
@@ -112,6 +113,8 @@
        volatile bool sc_wrports;
        volatile int sc_rdports;
        volatile int sc_paused;
+       struct workqueue *sc_wq;
+       struct work sc_wk;
        struct callout sc_callout;
        int sc_nports;
        TAILQ_HEAD(, agr_port) sc_ports;
@@ -142,7 +145,7 @@
 #define        AGR_ROUNDROBIN(sc)      (((sc)->sc_if.if_flags & IFF_LINK0) != 0)
 #define        AGR_STATIC(sc)          (((sc)->sc_if.if_flags & IFF_LINK1) != 0)
 
-void agrtimer_init(struct agr_softc *);
+int agrtimer_init(struct agr_softc *);
 void agrtimer_destroy(struct agr_softc *);
 void agrtimer_start(struct agr_softc *);
 void agrtimer_stop(struct agr_softc *);



Home | Main Index | Thread Index | Old Index