drm/bridge: adv7511: Switch to atomic operations
[drm/drm-misc.git] / tools / include / asm-generic / bitops / fls.h
blob26f3ce1dd6e44872000d7066d4b3e37325e915fa
1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _ASM_GENERIC_BITOPS_FLS_H_
3 #define _ASM_GENERIC_BITOPS_FLS_H_
5 /**
6 * generic_fls - find last (most-significant) bit set
7 * @x: the word to search
9 * This is defined the same way as ffs.
10 * Note fls(0) = 0, fls(1) = 1, fls(0x80000000) = 32.
13 static __always_inline int generic_fls(unsigned int x)
15 int r = 32;
17 if (!x)
18 return 0;
19 if (!(x & 0xffff0000u)) {
20 x <<= 16;
21 r -= 16;
23 if (!(x & 0xff000000u)) {
24 x <<= 8;
25 r -= 8;
27 if (!(x & 0xf0000000u)) {
28 x <<= 4;
29 r -= 4;
31 if (!(x & 0xc0000000u)) {
32 x <<= 2;
33 r -= 2;
35 if (!(x & 0x80000000u)) {
36 x <<= 1;
37 r -= 1;
39 return r;
42 #ifndef __HAVE_ARCH_FLS
43 #define fls(x) generic_fls(x)
44 #endif
46 #endif /* _ASM_GENERIC_BITOPS_FLS_H_ */