#ifndef find_next_bit /** * find_next_bit - find the next set bit in a memory region * @addr: The address to base the search on * @size: The bitmap size in bits * @offset: The bitnumber to start searching at * * Returns the bit number for the next set bit * If no bits are set, returns @size.
*/ staticinline unsignedlong find_next_bit(constunsignedlong *addr, unsignedlong size, unsignedlong offset)
{ if (small_const_nbits(size)) { unsignedlong val;
if (unlikely(offset >= size)) return size;
val = *addr & GENMASK(size - 1, offset); return val ? __ffs(val) : size;
}
#ifndef find_next_and_bit /** * find_next_and_bit - find the next set bit in both memory regions * @addr1: The first address to base the search on * @addr2: The second address to base the search on * @size: The bitmap size in bits * @offset: The bitnumber to start searching at * * Returns the bit number for the next set bit * If no bits are set, returns @size.
*/ staticinline unsignedlong find_next_and_bit(constunsignedlong *addr1, constunsignedlong *addr2, unsignedlong size, unsignedlong offset)
{ if (small_const_nbits(size)) { unsignedlong val;
if (unlikely(offset >= size)) return size;
val = *addr1 & *addr2 & GENMASK(size - 1, offset); return val ? __ffs(val) : size;
}
#ifndef find_next_zero_bit /** * find_next_zero_bit - find the next cleared bit in a memory region * @addr: The address to base the search on * @size: The bitmap size in bits * @offset: The bitnumber to start searching at * * Returns the bit number of the next zero bit * If no bits are zero, returns @size.
*/ staticinline unsignedlong find_next_zero_bit(constunsignedlong *addr, unsignedlong size, unsignedlong offset)
{ if (small_const_nbits(size)) { unsignedlong val;
if (unlikely(offset >= size)) return size;
val = *addr | ~GENMASK(size - 1, offset); return val == ~0UL ? size : ffz(val);
}
#ifndef find_first_bit /** * find_first_bit - find the first set bit in a memory region * @addr: The address to start the search at * @size: The maximum number of bits to search * * Returns the bit number of the first set bit. * If no bits are set, returns @size.
*/ staticinline unsignedlong find_first_bit(constunsignedlong *addr, unsignedlong size)
{ if (small_const_nbits(size)) { unsignedlong val = *addr & GENMASK(size - 1, 0);
return val ? __ffs(val) : size;
}
return _find_first_bit(addr, size);
} #endif
#ifndef find_first_and_bit /** * find_first_and_bit - find the first set bit in both memory regions * @addr1: The first address to base the search on * @addr2: The second address to base the search on * @size: The bitmap size in bits * * Returns the bit number for the next set bit * If no bits are set, returns @size.
*/ staticinline unsignedlong find_first_and_bit(constunsignedlong *addr1, constunsignedlong *addr2, unsignedlong size)
{ if (small_const_nbits(size)) { unsignedlong val = *addr1 & *addr2 & GENMASK(size - 1, 0);
#ifndef find_first_zero_bit /** * find_first_zero_bit - find the first cleared bit in a memory region * @addr: The address to start the search at * @size: The maximum number of bits to search * * Returns the bit number of the first cleared bit. * If no bits are zero, returns @size.
*/ staticinline unsignedlong find_first_zero_bit(constunsignedlong *addr, unsignedlong size)
{ if (small_const_nbits(size)) { unsignedlong val = *addr | ~GENMASK(size - 1, 0);
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.