提交 3b0040a4 编写于 作者: M Martin Schwidefsky

s390/bitops: fix find_next_bit_left

The find_next_bit_left function is broken if used with an offset which
is not a multiple of 64. The shift to mask the bits of a 64-bit word
not to search is in the wrong direction, the result can be either a
bit found smaller than the offset or failure to find a set bit.

Cc: <stable@vger.kernel.org> # v3.8+
Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
上级 59471227
...@@ -693,7 +693,7 @@ static inline int find_next_bit_left(const unsigned long *addr, ...@@ -693,7 +693,7 @@ static inline int find_next_bit_left(const unsigned long *addr,
size -= offset; size -= offset;
p = addr + offset / BITS_PER_LONG; p = addr + offset / BITS_PER_LONG;
if (bit) { if (bit) {
set = __flo_word(0, *p & (~0UL << bit)); set = __flo_word(0, *p & (~0UL >> bit));
if (set >= size) if (set >= size)
return size + offset; return size + offset;
if (set < BITS_PER_LONG) if (set < BITS_PER_LONG)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册