提交 c47a830c 编写于 作者: D Dick Hollenbeck 提交者: Russell King

ARM: 5688/1: ks8695_serial: disable_irq() lockup

disable_irq() cannot be called from interrupt context without self imposed deadlock. This was happening in ks8695uart_stop_tx().
Signed-off-by: NDick Hollenbeck <dick@softplc.com>
Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
上级 13f96d8f
...@@ -110,7 +110,11 @@ static struct console ks8695_console; ...@@ -110,7 +110,11 @@ static struct console ks8695_console;
static void ks8695uart_stop_tx(struct uart_port *port) static void ks8695uart_stop_tx(struct uart_port *port)
{ {
if (tx_enabled(port)) { if (tx_enabled(port)) {
disable_irq(KS8695_IRQ_UART_TX); /* use disable_irq_nosync() and not disable_irq() to avoid self
* imposed deadlock by not waiting for irq handler to end,
* since this ks8695uart_stop_tx() is called from interrupt context.
*/
disable_irq_nosync(KS8695_IRQ_UART_TX);
tx_enable(port, 0); tx_enable(port, 0);
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册