All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH REPOST] mfd: dln2: use irqsave() in USB's complete callback
@ 2018-07-01 15:41 ` Sebastian Andrzej Siewior
  0 siblings, 0 replies; 10+ messages in thread
From: Sebastian Andrzej Siewior @ 2018-07-01 15:41 UTC (permalink / raw)
  To: linux-kernel
  Cc: linux-usb, tglx, Sebastian Andrzej Siewior, Lee Jones, Octavian Purdila

The USB completion callback does not disable interrupts while acquiring
the lock. We want to remove the local_irq_disable() invocation from
__usb_hcd_giveback_urb() and therefore it is required for the callback
handler to disable the interrupts while acquiring the lock.
The callback may be invoked either in IRQ or BH context depending on the
USB host controller.
Use the _irqsave() variant of the locking primitives.

Cc: Lee Jones <lee.jones@linaro.org>
Cc: Octavian Purdila <octavian.purdila@intel.com>
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
---
 drivers/mfd/dln2.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/drivers/mfd/dln2.c b/drivers/mfd/dln2.c
index 704e189ca162..1ef3c92f32e0 100644
--- a/drivers/mfd/dln2.c
+++ b/drivers/mfd/dln2.c
@@ -194,6 +194,7 @@ static bool dln2_transfer_complete(struct dln2_dev *dln2, struct urb *urb,
 	struct device *dev = &dln2->interface->dev;
 	struct dln2_mod_rx_slots *rxs = &dln2->mod_rx_slots[handle];
 	struct dln2_rx_context *rxc;
+	unsigned long flags;
 	bool valid_slot = false;
 
 	if (rx_slot >= DLN2_MAX_RX_SLOTS)
@@ -206,13 +207,13 @@ static bool dln2_transfer_complete(struct dln2_dev *dln2, struct urb *urb,
 	 * context elsewhere in this driver. This function (or its callers) are
 	 * also not exported to other modules.
 	 */
-	spin_lock(&rxs->lock);
+	spin_lock_irqsave(&rxs->lock, flags);
 	if (rxc->in_use && !rxc->urb) {
 		rxc->urb = urb;
 		complete(&rxc->done);
 		valid_slot = true;
 	}
-	spin_unlock(&rxs->lock);
+	spin_unlock_irqrestore(&rxs->lock, flags);
 
 out:
 	if (!valid_slot)
-- 
2.18.0


^ permalink raw reply related	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2018-07-04  7:40 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-07-01 15:41 [PATCH REPOST] mfd: dln2: use irqsave() in USB's complete callback Sebastian Andrzej Siewior
2018-07-01 15:41 ` [REPOST] " Sebastian Andrzej Siewior
2018-07-01 22:07 ` [PATCH REPOST] " Octavian Purdila
2018-07-01 22:07   ` [REPOST] " Octavian Purdila
2018-07-02  6:24   ` [PATCH REPOST] " Johan Hovold
2018-07-02  6:24     ` [REPOST] " Johan Hovold
2018-07-02  7:31     ` [PATCH v2] " Sebastian Andrzej Siewior
2018-07-02  7:31       ` [v2] " Sebastian Andrzej Siewior
2018-07-04  7:40       ` [PATCH v2] " Lee Jones
2018-07-04  7:40         ` [v2] " Lee Jones

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.