autoconfig_irq() expects a CPU detects an interrupt from a serial
port, but it doesn't work when the CPU has interrupts disabled
during the waiting time.
New one tries to specify own CPU to probe the interrupt
and reduce the risk of the failure as far as possible.

Signed-off-by: Taichi Kageyama <t-kagey...@cp.jp.nec.com>
Cc: Naoya Horiguchi <n-horigu...@ah.jp.nec.com>
Suggested-by: Peter Hurley <pe...@hurleysoftware.com>
---
 drivers/tty/serial/8250/8250_core.c | 9 +++++++++
 1 file changed, 9 insertions(+)

diff --git v4.2-rc4.org/drivers/tty/serial/8250/8250_core.c 
v4.2-rc4.work/drivers/tty/serial/8250/8250_core.c
index ed1e23e..85e8cdf 100644
--- v4.2-rc4.org/drivers/tty/serial/8250/8250_core.c
+++ v4.2-rc4.work/drivers/tty/serial/8250/8250_core.c
@@ -1295,6 +1295,7 @@ static void autoconfig_irq(struct uart_8250_port *up)
        unsigned int ICP = 0;
        unsigned long irqs;
        int irq;
+       cpumask_t this_cpu;
 
        if (port->flags & UPF_FOURPORT) {
                ICP = (port->iobase & 0xfe0) | 0x1f;
@@ -1313,6 +1314,13 @@ static void autoconfig_irq(struct uart_8250_port *up)
        serial_out(up, UART_MCR, UART_MCR_OUT1 | UART_MCR_OUT2);
 
        irqs = probe_irq_on();
+
+       /* Try to detect irq on the current CPU */
+       cpumask_clear(&this_cpu);
+       preempt_disable();
+       cpumask_set_cpu(smp_processor_id(), &this_cpu);
+       probe_irq_set_affinity(irqs, &this_cpu);
+
        serial_out(up, UART_MCR, 0);
        udelay(10);
        if (port->flags & UPF_FOURPORT) {
@@ -1330,6 +1338,7 @@ static void autoconfig_irq(struct uart_8250_port *up)
        serial_out(up, UART_TX, 0xFF);
        udelay(20);
        irq = probe_irq_off(irqs);
+       preempt_enable();
 
        serial_out(up, UART_MCR, save_mcr);
        serial_out(up, UART_IER, save_ier);
-- 
2.4.6
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to