bitmap: fix bitmal_clear() clearing bits in the wrong direction
This commit is contained in:
@@ -25,7 +25,7 @@ void bitmap_set(unsigned long *map, unsigned long bit)
|
|||||||
void bitmap_clear(unsigned long *map, unsigned long bit)
|
void bitmap_clear(unsigned long *map, unsigned long bit)
|
||||||
{
|
{
|
||||||
unsigned long index = bit / BITS_PER_WORD;
|
unsigned long index = bit / BITS_PER_WORD;
|
||||||
unsigned long offset = bit & (BITS_PER_WORD - 1);
|
unsigned long offset = (BITS_PER_WORD - bit - 1) & (BITS_PER_WORD - 1);
|
||||||
unsigned long mask = 1ul << offset;
|
unsigned long mask = 1ul << offset;
|
||||||
|
|
||||||
map[index] &= ~mask;
|
map[index] &= ~mask;
|
||||||
|
|||||||
Reference in New Issue
Block a user