xref: /openbmc/linux/tools/testing/radix-tree/bitmap.c (revision 15a1fbdcfb519c2bd291ed01c6c94e0b89537a77)
1 /* lib/bitmap.c pulls in at least two other files. */
2 
3 #include <linux/bitmap.h>
4 
5 void bitmap_clear(unsigned long *map, unsigned int start, int len)
6 {
7 	unsigned long *p = map + BIT_WORD(start);
8 	const unsigned int size = start + len;
9 	int bits_to_clear = BITS_PER_LONG - (start % BITS_PER_LONG);
10 	unsigned long mask_to_clear = BITMAP_FIRST_WORD_MASK(start);
11 
12 	while (len - bits_to_clear >= 0) {
13 		*p &= ~mask_to_clear;
14 		len -= bits_to_clear;
15 		bits_to_clear = BITS_PER_LONG;
16 		mask_to_clear = ~0UL;
17 		p++;
18 	}
19 	if (len) {
20 		mask_to_clear &= BITMAP_LAST_WORD_MASK(size);
21 		*p &= ~mask_to_clear;
22 	}
23 }
24