diff options
author | Masao Uebayashi <uebayasi@cvs.openbsd.org> | 2015-02-10 23:10:22 +0000 |
---|---|---|
committer | Masao Uebayashi <uebayasi@cvs.openbsd.org> | 2015-02-10 23:10:22 +0000 |
commit | 3d196cee8016d9003de99a31843be06b7ea56465 (patch) | |
tree | e4b219db57a134cfcafafe241edeba85b250c00b /sys/dev/usb/dwc2 | |
parent | a2db6c9f05d7afa7eecdb540f399682931f665a4 (diff) |
Convert timeout(9)/taskq(9) usages.
Diffstat (limited to 'sys/dev/usb/dwc2')
-rw-r--r-- | sys/dev/usb/dwc2/dwc2.c | 11 | ||||
-rw-r--r-- | sys/dev/usb/dwc2/dwc2.h | 8 | ||||
-rw-r--r-- | sys/dev/usb/dwc2/dwc2_coreintr.c | 4 | ||||
-rw-r--r-- | sys/dev/usb/dwc2/dwc2_hcd.c | 13 | ||||
-rw-r--r-- | sys/dev/usb/dwc2/dwc2var.h | 8 |
5 files changed, 25 insertions, 19 deletions
diff --git a/sys/dev/usb/dwc2/dwc2.c b/sys/dev/usb/dwc2/dwc2.c index f69253f17b3..06a6382017b 100644 --- a/sys/dev/usb/dwc2/dwc2.c +++ b/sys/dev/usb/dwc2/dwc2.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dwc2.c,v 1.11 2015/02/10 14:34:14 uebayasi Exp $ */ +/* $OpenBSD: dwc2.c,v 1.12 2015/02/10 23:10:21 uebayasi Exp $ */ /* $NetBSD: dwc2.c,v 1.32 2014/09/02 23:26:20 macallan Exp $ */ /*- @@ -553,7 +553,7 @@ dwc2_abort_xfer(struct usbd_xfer *xfer, usbd_status status) if (sc->sc_dying) { xfer->status = status; - timeout_stop(&xfer->timeout_handle); + timeout_del(&xfer->timeout_handle); usb_transfer_complete(xfer); return; } @@ -577,7 +577,7 @@ dwc2_abort_xfer(struct usbd_xfer *xfer, usbd_status status) xfer->hcflags |= UXFER_ABORTING; xfer->status = status; /* make software ignore it */ - timeout_stop(&xfer->timeout_handle); + timeout_del(&xfer->timeout_handle); /* XXXNH suboptimal */ TAILQ_FOREACH_SAFE(d, &sc->sc_complete, xnext, tmp) { @@ -1656,7 +1656,8 @@ dw_timeout(void *arg) { struct delayed_work *dw = arg; - taskq_enqueue(dw->dw_wq, &dw->work, NULL); + task_set(&dw->work, dw->dw_fn, arg); + task_add(dw->dw_wq, &dw->work); } void dwc2_host_hub_info(struct dwc2_hsotg *hsotg, void *context, int *hub_addr, @@ -1778,7 +1779,7 @@ void dwc2_host_complete(struct dwc2_hsotg *hsotg, struct dwc2_qtd *qtd, } qtd->urb = NULL; - timeout_stop(&xfer->timeout_handle); + timeout_del(&xfer->timeout_handle); KASSERT(mtx_owned(&hsotg->lock)); diff --git a/sys/dev/usb/dwc2/dwc2.h b/sys/dev/usb/dwc2/dwc2.h index 6543b9a59f6..2c4223c5f43 100644 --- a/sys/dev/usb/dwc2/dwc2.h +++ b/sys/dev/usb/dwc2/dwc2.h @@ -1,4 +1,4 @@ -/* $OpenBSD: dwc2.h,v 1.6 2015/02/10 14:34:14 uebayasi Exp $ */ +/* $OpenBSD: dwc2.h,v 1.7 2015/02/10 23:10:21 uebayasi Exp $ */ /* $NetBSD: dwc2.h,v 1.4 2014/12/23 16:20:06 macallan Exp $ */ /*- @@ -213,18 +213,20 @@ struct delayed_work { struct timeout dw_timer; struct taskq *dw_wq; + void (*dw_fn)(struct task *); }; static inline void INIT_DELAYED_WORK(struct delayed_work *dw, void (*fn)(struct task *)) { - timeout_init(&dw->dw_timer, CALLOUT_MPSAFE); + dw->dw_fn = fn; + timeout_set(&dw->dw_timer, dw_timeout, dw); } static inline void queue_delayed_work(struct taskq *wq, struct delayed_work *dw, int j) { - timeout_reset(&dw->dw_timer, j, dw_timeout, dw); + timeout_add(&dw->dw_timer, j); } #endif diff --git a/sys/dev/usb/dwc2/dwc2_coreintr.c b/sys/dev/usb/dwc2/dwc2_coreintr.c index c0a592b3ba8..cef80f37f87 100644 --- a/sys/dev/usb/dwc2/dwc2_coreintr.c +++ b/sys/dev/usb/dwc2/dwc2_coreintr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dwc2_coreintr.c,v 1.4 2015/02/10 13:49:48 uebayasi Exp $ */ +/* $OpenBSD: dwc2_coreintr.c,v 1.5 2015/02/10 23:10:21 uebayasi Exp $ */ /* $NetBSD: dwc2_coreintr.c,v 1.8 2014/04/04 05:40:57 skrll Exp $ */ /* @@ -305,7 +305,7 @@ static void dwc2_handle_conn_id_status_change_intr(struct dwc2_hsotg *hsotg) * scheduling. */ spin_unlock(&hsotg->lock); - taskq_enqueue(hsotg->wq_otg, &hsotg->wf_otg, NULL); + task_add(hsotg->wq_otg, &hsotg->wf_otg); spin_lock(&hsotg->lock); /* Clear interrupt */ diff --git a/sys/dev/usb/dwc2/dwc2_hcd.c b/sys/dev/usb/dwc2/dwc2_hcd.c index af250a546c3..e0a0850dc44 100644 --- a/sys/dev/usb/dwc2/dwc2_hcd.c +++ b/sys/dev/usb/dwc2/dwc2_hcd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dwc2_hcd.c,v 1.7 2015/02/10 14:34:14 uebayasi Exp $ */ +/* $OpenBSD: dwc2_hcd.c,v 1.8 2015/02/10 23:10:21 uebayasi Exp $ */ /* $NetBSD: dwc2_hcd.c,v 1.15 2014/11/24 10:14:14 skrll Exp $ */ /* @@ -2137,7 +2137,7 @@ static void dwc2_hcd_free(struct dwc2_hsotg *hsotg) free(hsotg->core_params, M_DEVBUF, sizeof(*hsotg->core_params)); hsotg->core_params = NULL; - timeout_destroy(&hsotg->wkp_timer); + timeout_del(&hsotg->wkp_timer); } static void dwc2_hcd_release(struct dwc2_hsotg *hsotg) @@ -2174,7 +2174,7 @@ int dwc2_hcd_init(struct dwc2_hsotg *hsotg, { struct dwc2_host_chan *channel; int i, num_channels; - int err, retval; + int retval; dev_dbg(hsotg->dev, "DWC OTG HCD INIT\n"); @@ -2227,17 +2227,14 @@ int dwc2_hcd_init(struct dwc2_hsotg *hsotg, /* Create new workqueue and init work */ retval = -ENOMEM; - err = taskq_create(&hsotg->wq_otg, "dwc2", dwc2_worker, hsotg, - PRI_BIO, IPL_USB, WQ_MPSAFE); + hsotg->wq_otg = taskq_create("dwc2", 1, IPL_USB); - retval = -err; if (err) { dev_err(hsotg->dev, "Failed to create workqueue\n"); goto error2; } - timeout_init(&hsotg->wkp_timer, CALLOUT_MPSAFE); - timeout_setfunc(&hsotg->wkp_timer, dwc2_wakeup_detected, hsotg); + timeout_set(&hsotg->wkp_timer, dwc2_wakeup_detected, hsotg); /* Initialize the non-periodic schedule */ INIT_LIST_HEAD(&hsotg->non_periodic_sched_inactive); diff --git a/sys/dev/usb/dwc2/dwc2var.h b/sys/dev/usb/dwc2/dwc2var.h index b54fee3eef4..90ae725fe9d 100644 --- a/sys/dev/usb/dwc2/dwc2var.h +++ b/sys/dev/usb/dwc2/dwc2var.h @@ -1,4 +1,4 @@ -/* $OpenBSD: dwc2var.h,v 1.6 2015/02/10 14:15:14 uebayasi Exp $ */ +/* $OpenBSD: dwc2var.h,v 1.7 2015/02/10 23:10:21 uebayasi Exp $ */ /* $NetBSD: dwc2var.h,v 1.3 2013/10/22 12:57:40 skrll Exp $ */ /*- @@ -132,4 +132,10 @@ dwc2_root_intr(dwc2_softc_t *sc) softintr_schedule(sc->sc_rhc_si); } +#define timeout_reset(x, t, f, a) \ +do { \ + timeout_set((x), (f), (a)); \ + timeout_add((x), (t)); \ +} while (0) + #endif /* _DWC_OTGVAR_H_ */ |