From: Andy Shevchenko Date: Mon, 3 Jul 2023 18:52:14 +0000 (+0300) Subject: HID: cp2112: Switch to for_each_set_bit() to simplify the code X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=ecb42bb8035c9901684c40c87cf1ea23f62e055d;p=linux.git HID: cp2112: Switch to for_each_set_bit() to simplify the code It's cleaner to use for_each_set_bit() than open coding it. Signed-off-by: Andy Shevchenko Link: https://lore.kernel.org/r/20230703185222.50554-5-andriy.shevchenko@linux.intel.com Signed-off-by: Benjamin Tissoires --- diff --git a/drivers/hid/hid-cp2112.c b/drivers/hid/hid-cp2112.c index 51399b231d368..fb4548feb0c88 100644 --- a/drivers/hid/hid-cp2112.c +++ b/drivers/hid/hid-cp2112.c @@ -16,6 +16,7 @@ * https://www.silabs.com/documents/public/application-notes/an495-cp2112-interface-specification.pdf */ +#include #include #include #include @@ -1100,7 +1101,6 @@ static void cp2112_gpio_poll_callback(struct work_struct *work) gpio_poll_worker.work); struct irq_data *d; u8 gpio_mask; - u8 virqs = (u8)dev->irq_mask; u32 irq_type; int irq, virq, ret; @@ -1111,11 +1111,7 @@ static void cp2112_gpio_poll_callback(struct work_struct *work) goto exit; gpio_mask = ret; - - while (virqs) { - virq = ffs(virqs) - 1; - virqs &= ~BIT(virq); - + for_each_set_bit(virq, &dev->irq_mask, 8) { if (!dev->gc.to_irq) break;