diff options
Diffstat (limited to 'tools/lib/find_bit.c')
| -rw-r--r-- | tools/lib/find_bit.c | 25 | 
1 files changed, 25 insertions, 0 deletions
diff --git a/tools/lib/find_bit.c b/tools/lib/find_bit.c index 9122a9e80046..6d8b8f22cf55 100644 --- a/tools/lib/find_bit.c +++ b/tools/lib/find_bit.c @@ -82,3 +82,28 @@ unsigned long find_first_bit(const unsigned long *addr, unsigned long size)  	return size;  }  #endif + +#ifndef find_first_zero_bit +/* + * Find the first cleared bit in a memory region. + */ +unsigned long find_first_zero_bit(const unsigned long *addr, unsigned long size) +{ +	unsigned long idx; + +	for (idx = 0; idx * BITS_PER_LONG < size; idx++) { +		if (addr[idx] != ~0UL) +			return min(idx * BITS_PER_LONG + ffz(addr[idx]), size); +	} + +	return size; +} +#endif + +#ifndef find_next_zero_bit +unsigned long find_next_zero_bit(const unsigned long *addr, unsigned long size, +				 unsigned long offset) +{ +	return _find_next_bit(addr, size, offset, ~0UL); +} +#endif  | 
