From: Linus Torvalds Date: Fri, 29 Jul 2005 15:01:22 +0000 (-0400) Subject: x86: fix new find_first_bit() X-Git-Tag: v2.6.13-rc5~104 X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d6d2a2ab05da6e44bd127fe375078bb7c36a0ad0;p=linux-2.6 x86: fix new find_first_bit() Some edge problems with the original C rewrite. Thanks go to Cal Peake, who pinpointed the breakage to the rewrite, and tested this fixed version. Signed-off-by: Linus Torvalds --- diff --git a/include/asm-i386/bitops.h b/include/asm-i386/bitops.h index 1caee10393..ddf1739dc7 100644 --- a/include/asm-i386/bitops.h +++ b/include/asm-i386/bitops.h @@ -335,14 +335,13 @@ static inline unsigned long __ffs(unsigned long word) static inline int find_first_bit(const unsigned long *addr, unsigned size) { int x = 0; - do { - if (*addr) - return __ffs(*addr) + x; - addr++; - if (x >= size) - break; + + while (x < size) { + unsigned long val = *addr++; + if (val) + return __ffs(val) + x; x += (sizeof(*addr)<<3); - } while (1); + } return x; }