[media] smipcie: return more proper value in interrupt handler
authorNibble Max <nibble.max@gmail.com>
Thu, 25 Dec 2014 08:18:31 +0000 (05:18 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Mon, 2 Feb 2015 16:42:53 +0000 (14:42 -0200)
Although IRQ_HANDLED is "safe" value to return,
it is better to let the kernel know whether the driver handle the interrupt or not.

Signed-off-by: Nibble Max <nibble.max@gmail.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/pci/smipcie/smipcie.c

index f773350e67b9908a55e48d04639b387b6436f0cf..36c8ed77309ce63d04f5daa1472406b8fbeb85f1 100644 (file)
@@ -448,16 +448,19 @@ static void smi_port_exit(struct smi_port *port)
        port->enable = 0;
 }
 
-static void smi_port_irq(struct smi_port *port, u32 int_status)
+static int smi_port_irq(struct smi_port *port, u32 int_status)
 {
        u32 port_req_irq = port->_dmaInterruptCH0 | port->_dmaInterruptCH1;
+       int handled = 0;
 
        if (int_status & port_req_irq) {
                smi_port_disableInterrupt(port);
                port->_int_status = int_status;
                smi_port_clearInterrupt(port);
                tasklet_schedule(&port->tasklet);
+               handled = 1;
        }
+       return handled;
 }
 
 static irqreturn_t smi_irq_handler(int irq, void *dev_id)
@@ -465,18 +468,19 @@ static irqreturn_t smi_irq_handler(int irq, void *dev_id)
        struct smi_dev *dev = dev_id;
        struct smi_port *port0 = &dev->ts_port[0];
        struct smi_port *port1 = &dev->ts_port[1];
+       int handled = 0;
 
        u32 intr_status = smi_read(MSI_INT_STATUS);
 
        /* ts0 interrupt.*/
        if (dev->info->ts_0)
-               smi_port_irq(port0, intr_status);
+               handled += smi_port_irq(port0, intr_status);
 
        /* ts1 interrupt.*/
        if (dev->info->ts_1)
-               smi_port_irq(port1, intr_status);
+               handled += smi_port_irq(port1, intr_status);
 
-       return IRQ_HANDLED;
+       return IRQ_RETVAL(handled);
 }
 
 static struct i2c_client *smi_add_i2c_client(struct i2c_adapter *adapter,