diff options
| author | Alexander van Heukelum <heukelum@mailshack.com> | 2008-03-15 13:30:57 -0400 |
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2008-04-26 13:21:16 -0400 |
| commit | 7d9dff22e8ad06ad330968c9e3d3a2fb55a5f9c3 (patch) | |
| tree | 1c65cd4cdf14f42d59e72514991c4b04278db8d5 /include/asm-generic/bitops | |
| parent | 12d9c8420b9daa1da3d9e090640fb24bcd0deba2 (diff) | |
generic: introduce a generic __fls implementation
Add a generic __fls implementation in the same spirit as
the generic __ffs one. It finds the last (most significant)
set bit in the given long value.
Signed-off-by: Alexander van Heukelum <heukelum@fastmail.fm>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'include/asm-generic/bitops')
| -rw-r--r-- | include/asm-generic/bitops/__fls.h | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/include/asm-generic/bitops/__fls.h b/include/asm-generic/bitops/__fls.h new file mode 100644 index 00000000000..be24465403d --- /dev/null +++ b/include/asm-generic/bitops/__fls.h | |||
| @@ -0,0 +1,43 @@ | |||
| 1 | #ifndef _ASM_GENERIC_BITOPS___FLS_H_ | ||
| 2 | #define _ASM_GENERIC_BITOPS___FLS_H_ | ||
| 3 | |||
| 4 | #include <asm/types.h> | ||
| 5 | |||
| 6 | /** | ||
| 7 | * __fls - find last (most-significant) set bit in a long word | ||
| 8 | * @word: the word to search | ||
| 9 | * | ||
| 10 | * Undefined if no set bit exists, so code should check against 0 first. | ||
| 11 | */ | ||
| 12 | static inline unsigned long __fls(unsigned long word) | ||
| 13 | { | ||
| 14 | int num = BITS_PER_LONG - 1; | ||
| 15 | |||
| 16 | #if BITS_PER_LONG == 64 | ||
| 17 | if (!(word & (~0ul << 32))) { | ||
| 18 | num -= 32; | ||
| 19 | word <<= 32; | ||
| 20 | } | ||
| 21 | #endif | ||
| 22 | if (!(word & (~0ul << (BITS_PER_LONG-16)))) { | ||
| 23 | num -= 16; | ||
| 24 | word <<= 16; | ||
| 25 | } | ||
| 26 | if (!(word & (~0ul << (BITS_PER_LONG-8)))) { | ||
| 27 | num -= 8; | ||
| 28 | word <<= 8; | ||
| 29 | } | ||
| 30 | if (!(word & (~0ul << (BITS_PER_LONG-4)))) { | ||
| 31 | num -= 4; | ||
| 32 | word <<= 4; | ||
| 33 | } | ||
| 34 | if (!(word & (~0ul << (BITS_PER_LONG-2)))) { | ||
| 35 | num -= 2; | ||
| 36 | word <<= 2; | ||
| 37 | } | ||
| 38 | if (!(word & (~0ul << (BITS_PER_LONG-1)))) | ||
| 39 | num -= 1; | ||
| 40 | return num; | ||
| 41 | } | ||
| 42 | |||
| 43 | #endif /* _ASM_GENERIC_BITOPS___FLS_H_ */ | ||
