[<prev] [next>] [day] [month] [year] [list]
Message-Id: <1416048746-12717-1-git-send-email-andrey.utkin@corp.bluecherry.net>
Date: Sat, 15 Nov 2014 14:52:26 +0400
From: Andrey Utkin <andrey.utkin@...p.bluecherry.net>
To: khalasa@...p.pl, linux-media@...r.kernel.org,
linux-kernel@...r.kernel.org, m.chehab@...sung.com,
hverkuil@...all.nl
Subject: [PATCH] solo6x10: fix a race in IRQ handler
From: Krzysztof Hałasa <khalasa@...p.pl>
The IRQs have to be acknowledged before they are serviced, otherwise some events
may be skipped. Also, acknowledging IRQs just before returning from the handler
doesn't leave enough time for the device to deassert the INTx line, and for
bridges to propagate this change. This resulted in twice the IRQ rate on ARMv6
dual core CPU.
Signed-off-by: Krzysztof Hałasa <khalasa@...p.pl>
Acked-by: Andrey Utkin <andrey.utkin@...p.bluecherry.net>
Tested-by: Andrey Utkin <andrey.utkin@...p.bluecherry.net>
--- a/drivers/media/pci/solo6x10/solo6x10-core.c
+++ b/drivers/media/pci/solo6x10/solo6x10-core.c
@@ -105,11 +105,8 @@ static irqreturn_t solo_isr(int irq, void *data)
if (!status)
return IRQ_NONE;
- if (status & ~solo_dev->irq_mask) {
- solo_reg_write(solo_dev, SOLO_IRQ_STAT,
- status & ~solo_dev->irq_mask);
- status &= solo_dev->irq_mask;
- }
+ /* Acknowledge all interrupts immediately */
+ solo_reg_write(solo_dev, SOLO_IRQ_STAT, status);
if (status & SOLO_IRQ_PCI_ERR)
solo_p2m_error_isr(solo_dev);
@@ -132,9 +129,6 @@ static irqreturn_t solo_isr(int irq, void *data)
if (status & SOLO_IRQ_G723)
solo_g723_isr(solo_dev);
- /* Clear all interrupts handled */
- solo_reg_write(solo_dev, SOLO_IRQ_STAT, status);
-
return IRQ_HANDLED;
}
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists