All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] serial/amba-pl011: Disable interrupts around TX softirq
@ 2015-07-09 10:57 ` Dave Martin
  0 siblings, 0 replies; 33+ messages in thread
From: Dave Martin @ 2015-07-09 10:57 UTC (permalink / raw)
  To: linux-serial, Greg Kroah-Hartman
  Cc: Russell King, Robin Murphy, linux-arm-kernel,
	Jakub Kiciński, Andrew Jackson, Graeme Gregory,
	Andre Przywara, Jorge Ramirez-Ortiz, popcorn mix, stable

pl011_tx_softirq() currently uses spin_{,un}lock(), which are not
sufficient to inhibit pl011_int() from being triggered by a local
IRQ and trying to re-take the same lock.  This can lead to
deadlocks.

This patch uses the _irq() locking variants instead to ensure that
pl011_int() handling for a given port is deferred until any
pl011_tx_softirq() work for that port is complete.

Fixes: 734745caeb9f serial/amba-pl011: Activate TX IRQ passively
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Tested-by: Robin Murphy <robin.murphy@arm.com>
Tested-by: Stefan Wahren <stefan.wahren@i2se.com>
Cc: stable <stable@vger.kernel.org> # 4.1
---
 drivers/tty/serial/amba-pl011.c |    4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/tty/serial/amba-pl011.c b/drivers/tty/serial/amba-pl011.c
index 763eb20..0cc622a 100644
--- a/drivers/tty/serial/amba-pl011.c
+++ b/drivers/tty/serial/amba-pl011.c
@@ -1360,9 +1360,9 @@ static void pl011_tx_softirq(struct work_struct *work)
 	struct uart_amba_port *uap =
 		container_of(dwork, struct uart_amba_port, tx_softirq_work);
 
-	spin_lock(&uap->port.lock);
+	spin_lock_irq(&uap->port.lock);
 	while (pl011_tx_chars(uap)) ;
-	spin_unlock(&uap->port.lock);
+	spin_unlock_irq(&uap->port.lock);
 }
 
 static void pl011_tx_irq_seen(struct uart_amba_port *uap)
-- 
1.7.10.4


^ permalink raw reply related	[flat|nested] 33+ messages in thread
* [PATCH] serial/amba-pl011: Disable interrupts around TX softirq
@ 2015-06-18 13:54 ` Dave Martin
  0 siblings, 0 replies; 33+ messages in thread
From: Dave Martin @ 2015-06-18 13:54 UTC (permalink / raw)
  To: linux-serial, Greg Kroah-Hartman
  Cc: Russell King, Robin Murphy, linux-arm-kernel,
	Jakub Kiciński, Andrew Jackson, Graeme Gregory,
	Andre Przywara, Jorge Ramirez-Ortiz, popcorn mix, stable

pl011_tx_softirq() currently uses spin_{,un}lock(), which are not
sufficient to inhibit pl011_int() from being triggered by a local
IRQ and trying to re-take the same lock.  This can lead to
deadlocks.

This patch uses the _irq() locking variants instead to ensure that
pl011_int() handling for a given port is deferred until any
pl011_tx_softirq() work for that port is complete.

Fixes: 734745caeb9f serial/amba-pl011: Activate TX IRQ passively
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Tested-by: Robin Murphy <robin.murphy@arm.com>
Cc: stable <stable@vger.kernel.org> # 4.1

---
 drivers/tty/serial/amba-pl011.c |    4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/tty/serial/amba-pl011.c b/drivers/tty/serial/amba-pl011.c
index 763eb20..0cc622a 100644
--- a/drivers/tty/serial/amba-pl011.c
+++ b/drivers/tty/serial/amba-pl011.c
@@ -1360,9 +1360,9 @@ static void pl011_tx_softirq(struct work_struct *work)
 	struct uart_amba_port *uap =
 		container_of(dwork, struct uart_amba_port, tx_softirq_work);
 
-	spin_lock(&uap->port.lock);
+	spin_lock_irq(&uap->port.lock);
 	while (pl011_tx_chars(uap)) ;
-	spin_unlock(&uap->port.lock);
+	spin_unlock_irq(&uap->port.lock);
 }
 
 static void pl011_tx_irq_seen(struct uart_amba_port *uap)
-- 
1.7.10.4


^ permalink raw reply related	[flat|nested] 33+ messages in thread
* [PATCH] serial/amba-pl011: Disable interrupts around TX softirq
@ 2015-06-05 14:07 ` Dave Martin
  0 siblings, 0 replies; 33+ messages in thread
From: Dave Martin @ 2015-06-05 14:07 UTC (permalink / raw)
  To: linux-serial, Greg Kroah-Hartman
  Cc: Russell King, Jakub Kiciński, Andre Przywara,
	Andrew Jackson, Graeme Gregory, popcorn mix, Jorge Ramirez-Ortiz,
	Robin Murphy, linux-arm-kernel

pl011_tx_softirq() currently uses spin_{,un}lock(), which are not
sufficient to inhibit pl011_int() from being triggered by a local
IRQ and trying to re-take the same lock.  This can lead to
deadlocks.

This patch uses the _irq() locking variants instead to ensure that
pl011_int() handling for a given port is deferred until any
pl011_tx_softirq() work for that port is complete.

Signed-off-by: Dave Martin <Dave.Martin@arm.com>
---

Another candidate for v4.1 if possible (sorry!) -- I thought this change
was already in, but it went astray when I was refactoring.

This patch conflicts with tty-next like the previous patch, since it
fixes code that is removed by tty-next.  The correct resolution for
the resulting merge conflict is to keep the code from tty-next.


I am not 100% certain yet whether some rare deadlocks that Robin is
seeing are caused by this issue, or whether this patch fixes them --
he's testing atm.

The patch is straightforward and using non _irq() locking in a workitem
that expects the lock to protect against interrupt handlers on the same
CPU is clearly wrong.


Cheers
---Dave


 drivers/tty/serial/amba-pl011.c |    4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/tty/serial/amba-pl011.c b/drivers/tty/serial/amba-pl011.c
index 763eb20..0cc622a 100644
--- a/drivers/tty/serial/amba-pl011.c
+++ b/drivers/tty/serial/amba-pl011.c
@@ -1360,9 +1360,9 @@ static void pl011_tx_softirq(struct work_struct *work)
 	struct uart_amba_port *uap =
 		container_of(dwork, struct uart_amba_port, tx_softirq_work);
 
-	spin_lock(&uap->port.lock);
+	spin_lock_irq(&uap->port.lock);
 	while (pl011_tx_chars(uap)) ;
-	spin_unlock(&uap->port.lock);
+	spin_unlock_irq(&uap->port.lock);
 }
 
 static void pl011_tx_irq_seen(struct uart_amba_port *uap)
-- 
1.7.10.4

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

end of thread, other threads:[~2015-07-24 16:46 UTC | newest]

Thread overview: 33+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-07-09 10:57 [PATCH] serial/amba-pl011: Disable interrupts around TX softirq Dave Martin
2015-07-09 10:57 ` Dave Martin
2015-07-23 22:05 ` Greg Kroah-Hartman
2015-07-23 22:05   ` Greg Kroah-Hartman
2015-07-24  9:56   ` Dave Martin
2015-07-24  9:56     ` Dave Martin
2015-07-24 15:15     ` Greg Kroah-Hartman
2015-07-24 15:15       ` Greg Kroah-Hartman
2015-07-24 16:46       ` Dave Martin
2015-07-24 16:46         ` Dave Martin
  -- strict thread matches above, loose matches on Subject: below --
2015-06-18 13:54 Dave Martin
2015-06-18 13:54 ` Dave Martin
2015-06-20  9:09 ` Stefan Wahren
2015-06-20  9:09   ` Stefan Wahren
2015-06-20  9:09   ` Stefan Wahren
2015-06-23 11:13   ` Dave P Martin
2015-06-23 11:13     ` Dave P Martin
2015-06-05 14:07 Dave Martin
2015-06-05 14:07 ` Dave Martin
2015-06-05 18:03 ` Robin Murphy
2015-06-05 18:03   ` Robin Murphy
2015-06-08 10:34   ` Robin Murphy
2015-06-08 10:34     ` Robin Murphy
2015-06-08 11:34     ` Dave P Martin
2015-06-08 11:34       ` Dave P Martin
2015-06-13  0:39 ` Greg Kroah-Hartman
2015-06-13  0:39   ` Greg Kroah-Hartman
2015-06-15 10:53   ` Dave P Martin
2015-06-15 10:53     ` Dave P Martin
2015-06-15 11:09   ` Andre Przywara
2015-06-15 11:09     ` Andre Przywara
2015-06-15 14:03     ` Dave Martin
2015-06-15 14:03       ` Dave Martin

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.