Commit b6e5d69a authored by Jonathan Cameron's avatar Jonathan Cameron Committed by Greg Kroah-Hartman

staging: iio: simplify logic in iio_interrupt_handler

Signed-off-by: default avatarJonathan Cameron <jic23@cam.ac.uk>
Acked-by: default avatarManuel Stahl <manuel.stahl@iis.fraunhofer.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent b156cf70
...@@ -125,19 +125,10 @@ static irqreturn_t iio_interrupt_handler(int irq, void *_int_info) ...@@ -125,19 +125,10 @@ static irqreturn_t iio_interrupt_handler(int irq, void *_int_info)
} }
time_ns = iio_get_time_ns(); time_ns = iio_get_time_ns();
/* detect single element list*/ list_for_each_entry(p, &int_info->ev_list, list) {
if (list_is_singular(&int_info->ev_list)) {
disable_irq_nosync(irq); disable_irq_nosync(irq);
p = list_first_entry(&int_info->ev_list,
struct iio_event_handler_list,
list);
/* single event handler - maybe shared */
p->handler(dev_info, 1, time_ns, !(p->refcount > 1)); p->handler(dev_info, 1, time_ns, !(p->refcount > 1));
} else }
list_for_each_entry(p, &int_info->ev_list, list) {
disable_irq_nosync(irq);
p->handler(dev_info, 1, time_ns, 0);
}
spin_unlock_irqrestore(&int_info->ev_list_lock, flags); spin_unlock_irqrestore(&int_info->ev_list_lock, flags);
return IRQ_HANDLED; return IRQ_HANDLED;
......
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