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