Commit c7260e29 authored by Sven Peter's avatar Sven Peter Committed by Greg Kroah-Hartman

usb: typec: tipd: Add short-circuit for no irqs

If no interrupts are set in IntEventX directly skip to the end of the
interrupt handler and return IRQ_NONE instead of IRQ_HANDLED.
This possibly allows to detect spurious interrupts if the i2c bus is fast
enough.
Reviewed-by: default avatarHeikki Krogerus <heikki.krogerus@linux.intel.com>
Signed-off-by: default avatarSven Peter <sven@svenpeter.dev>
Link: https://lore.kernel.org/r/20210928155502.71372-4-sven@svenpeter.devSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 0fbb79b7
...@@ -479,6 +479,9 @@ static irqreturn_t tps6598x_interrupt(int irq, void *data) ...@@ -479,6 +479,9 @@ static irqreturn_t tps6598x_interrupt(int irq, void *data)
} }
trace_tps6598x_irq(event1, event2); trace_tps6598x_irq(event1, event2);
if (!(event1 | event2))
goto err_unlock;
if (!tps6598x_read_status(tps, &status)) if (!tps6598x_read_status(tps, &status))
goto err_clear_ints; goto err_clear_ints;
...@@ -501,7 +504,9 @@ static irqreturn_t tps6598x_interrupt(int irq, void *data) ...@@ -501,7 +504,9 @@ static irqreturn_t tps6598x_interrupt(int irq, void *data)
err_unlock: err_unlock:
mutex_unlock(&tps->lock); mutex_unlock(&tps->lock);
if (event1 | event2)
return IRQ_HANDLED; return IRQ_HANDLED;
return IRQ_NONE;
} }
static int tps6598x_check_mode(struct tps6598x *tps) static int tps6598x_check_mode(struct tps6598x *tps)
......
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