summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2015-12-07 09:56:36 -0500
committerChristoph Hellwig <hch@lst.de>2015-12-11 14:52:27 -0500
commit0bc92ace52ef3ed1c8eb9bcf36cd3d7ca72d5d14 (patch)
tree0a76114d5562b687843015ee8c6c2c1ce87c68ec
parentea51190c03150fce4d9e428bfb608abbe0991db8 (diff)
irq_poll: fold irq_poll_disable_pending into irq_poll_softirq
Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Bart Van Assche <bart.vanassche@sandisk.com>
-rw-r--r--include/linux/irq_poll.h5
-rw-r--r--lib/irq_poll.c2
2 files changed, 1 insertions, 6 deletions
diff --git a/include/linux/irq_poll.h b/include/linux/irq_poll.h
index 57efae661400..b4ad03cee9d4 100644
--- a/include/linux/irq_poll.h
+++ b/include/linux/irq_poll.h
@@ -18,11 +18,6 @@ enum {
18 IRQ_POLL_F_DISABLE = 1, 18 IRQ_POLL_F_DISABLE = 1,
19}; 19};
20 20
21static inline int irq_poll_disable_pending(struct irq_poll *iop)
22{
23 return test_bit(IRQ_POLL_F_DISABLE, &iop->state);
24}
25
26extern void irq_poll_sched(struct irq_poll *); 21extern void irq_poll_sched(struct irq_poll *);
27extern void irq_poll_init(struct irq_poll *, int, irq_poll_fn *); 22extern void irq_poll_init(struct irq_poll *, int, irq_poll_fn *);
28extern void irq_poll_complete(struct irq_poll *); 23extern void irq_poll_complete(struct irq_poll *);
diff --git a/lib/irq_poll.c b/lib/irq_poll.c
index 43a3370a09fd..53d67e341ebb 100644
--- a/lib/irq_poll.c
+++ b/lib/irq_poll.c
@@ -122,7 +122,7 @@ static void irq_poll_softirq(struct softirq_action *h)
122 * move the instance around on the list at-will. 122 * move the instance around on the list at-will.
123 */ 123 */
124 if (work >= weight) { 124 if (work >= weight) {
125 if (irq_poll_disable_pending(iop)) 125 if (test_bit(IRQ_POLL_F_DISABLE, &iop->state))
126 __irq_poll_complete(iop); 126 __irq_poll_complete(iop);
127 else 127 else
128 list_move_tail(&iop->list, list); 128 list_move_tail(&iop->list, list);