Commit 346aaf21 authored by Heiko Carstens's avatar Heiko Carstens Committed by Kleber Sacilotto de Souza

s390/bitops: add for_each_set_bit_inv helper

BugLink: http://bugs.launchpad.net/bugs/1744736

Same helper function like for_each_set_bit in generic code.
Signed-off-by: default avatarHeiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
(cherry picked from commit 09214545)
Signed-off-by: default avatarJoseph Salisbury <joseph.salisbury@canonical.com>
Acked-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
Acked-by: default avatarThadeu Lima de Souza Cascardo <cascardo@canonical.com>
Signed-off-by: default avatarThadeu Lima de Souza Cascardo <cascardo@canonical.com>
parent b701b07f
...@@ -301,6 +301,11 @@ unsigned long find_first_bit_inv(const unsigned long *addr, unsigned long size); ...@@ -301,6 +301,11 @@ unsigned long find_first_bit_inv(const unsigned long *addr, unsigned long size);
unsigned long find_next_bit_inv(const unsigned long *addr, unsigned long size, unsigned long find_next_bit_inv(const unsigned long *addr, unsigned long size,
unsigned long offset); unsigned long offset);
#define for_each_set_bit_inv(bit, addr, size) \
for ((bit) = find_first_bit_inv((addr), (size)); \
(bit) < (size); \
(bit) = find_next_bit_inv((addr), (size), (bit) + 1))
static inline void set_bit_inv(unsigned long nr, volatile unsigned long *ptr) static inline void set_bit_inv(unsigned long nr, volatile unsigned long *ptr)
{ {
return set_bit(nr ^ (BITS_PER_LONG - 1), ptr); return set_bit(nr ^ (BITS_PER_LONG - 1), ptr);
......
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