summaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
authorSean Young <sean@mess.org>2017-05-16 09:56:14 +0200
committerMauro Carvalho Chehab <mchehab@s-opensource.com>2017-06-06 12:19:10 +0200
commitf8c627fbabbe9ed6ae68dcfefb7519bd153a7ac0 (patch)
tree70d497fb0fea384db72f806c7db85a6ecb1d1469 /drivers/media
parent[media] cec-notifier.h: handle unreachable CONFIG_CEC_CORE (diff)
downloadlinux-f8c627fbabbe9ed6ae68dcfefb7519bd153a7ac0.tar.xz
linux-f8c627fbabbe9ed6ae68dcfefb7519bd153a7ac0.zip
[media] sir_ir: infinite loop in interrupt handler
Since this driver does no detection of hardware, it might be used with a non-sir port. Escape out if we are spinning. Reported-by: kbuild test robot <fengguang.wu@intel.com> Signed-off-by: Sean Young <sean@mess.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/rc/sir_ir.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/media/rc/sir_ir.c b/drivers/media/rc/sir_ir.c
index e12ec50bf0bf..90a5f8fd5eea 100644
--- a/drivers/media/rc/sir_ir.c
+++ b/drivers/media/rc/sir_ir.c
@@ -183,9 +183,15 @@ static irqreturn_t sir_interrupt(int irq, void *dev_id)
static unsigned long delt;
unsigned long deltintr;
unsigned long flags;
+ int counter = 0;
int iir, lsr;
while ((iir = inb(io + UART_IIR) & UART_IIR_ID)) {
+ if (++counter > 256) {
+ dev_err(&sir_ir_dev->dev, "Trapped in interrupt");
+ break;
+ }
+
switch (iir & UART_IIR_ID) { /* FIXME toto treba preriedit */
case UART_IIR_MSI:
(void)inb(io + UART_MSR);