find: micro-optimize for_each_{set,clear}_bit()

The macros iterate thru all set/clear bits in a bitmap. They search a
first bit using find_first_bit(), and the rest bits using find_next_bit().

Since find_next_bit() is called shortly after find_first_bit(), we can
save few lines of I-cache by not using find_first_bit().

Signed-off-by: Yury Norov <yury.norov@gmail.com>
Tested-by: Wolfram Sang <wsa+renesas@sang-engineering.com>

+2 -2
+2 -2
include/linux/find.h
··· 280 #endif 281 282 #define for_each_set_bit(bit, addr, size) \ 283 - for ((bit) = find_first_bit((addr), (size)); \ 284 (bit) < (size); \ 285 (bit) = find_next_bit((addr), (size), (bit) + 1)) 286 ··· 291 (bit) = find_next_bit((addr), (size), (bit) + 1)) 292 293 #define for_each_clear_bit(bit, addr, size) \ 294 - for ((bit) = find_first_zero_bit((addr), (size)); \ 295 (bit) < (size); \ 296 (bit) = find_next_zero_bit((addr), (size), (bit) + 1)) 297
··· 280 #endif 281 282 #define for_each_set_bit(bit, addr, size) \ 283 + for ((bit) = find_next_bit((addr), (size), 0); \ 284 (bit) < (size); \ 285 (bit) = find_next_bit((addr), (size), (bit) + 1)) 286 ··· 291 (bit) = find_next_bit((addr), (size), (bit) + 1)) 292 293 #define for_each_clear_bit(bit, addr, size) \ 294 + for ((bit) = find_next_zero_bit((addr), (size), 0); \ 295 (bit) < (size); \ 296 (bit) = find_next_zero_bit((addr), (size), (bit) + 1)) 297