Commit ab98180a authored by Nibble Max's avatar Nibble Max Committed by Mauro Carvalho Chehab

[media] smipcie: return more proper value in interrupt handler

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: default avatarNibble Max <nibble.max@gmail.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@osg.samsung.com>
parent 93d8db80
...@@ -448,16 +448,19 @@ static void smi_port_exit(struct smi_port *port) ...@@ -448,16 +448,19 @@ static void smi_port_exit(struct smi_port *port)
port->enable = 0; 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; u32 port_req_irq = port->_dmaInterruptCH0 | port->_dmaInterruptCH1;
int handled = 0;
if (int_status & port_req_irq) { if (int_status & port_req_irq) {
smi_port_disableInterrupt(port); smi_port_disableInterrupt(port);
port->_int_status = int_status; port->_int_status = int_status;
smi_port_clearInterrupt(port); smi_port_clearInterrupt(port);
tasklet_schedule(&port->tasklet); tasklet_schedule(&port->tasklet);
handled = 1;
} }
return handled;
} }
static irqreturn_t smi_irq_handler(int irq, void *dev_id) 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) ...@@ -465,18 +468,19 @@ static irqreturn_t smi_irq_handler(int irq, void *dev_id)
struct smi_dev *dev = dev_id; struct smi_dev *dev = dev_id;
struct smi_port *port0 = &dev->ts_port[0]; struct smi_port *port0 = &dev->ts_port[0];
struct smi_port *port1 = &dev->ts_port[1]; struct smi_port *port1 = &dev->ts_port[1];
int handled = 0;
u32 intr_status = smi_read(MSI_INT_STATUS); u32 intr_status = smi_read(MSI_INT_STATUS);
/* ts0 interrupt.*/ /* ts0 interrupt.*/
if (dev->info->ts_0) if (dev->info->ts_0)
smi_port_irq(port0, intr_status); handled += smi_port_irq(port0, intr_status);
/* ts1 interrupt.*/ /* ts1 interrupt.*/
if (dev->info->ts_1) 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, static struct i2c_client *smi_add_i2c_client(struct i2c_adapter *adapter,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment