generic: Implement generic ffs/fls using __builtin_* functions
This patch implements ffs, __ffs, fls, __fls using __builtin_* gcc functions. These header files can be used by other architectures that rely on the gcc builtins. Signed-off-by: Catalin Marinas <catalin.marinas@arm.com> Acked-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
15
include/asm-generic/bitops/builtin-__ffs.h
Normal file
15
include/asm-generic/bitops/builtin-__ffs.h
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
#ifndef _ASM_GENERIC_BITOPS_BUILTIN___FFS_H_
|
||||||
|
#define _ASM_GENERIC_BITOPS_BUILTIN___FFS_H_
|
||||||
|
|
||||||
|
/**
|
||||||
|
* __ffs - find first bit in word.
|
||||||
|
* @word: The word to search
|
||||||
|
*
|
||||||
|
* Undefined if no bit exists, so code should check against 0 first.
|
||||||
|
*/
|
||||||
|
static __always_inline unsigned long __ffs(unsigned long word)
|
||||||
|
{
|
||||||
|
return __builtin_ctzl(word);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
15
include/asm-generic/bitops/builtin-__fls.h
Normal file
15
include/asm-generic/bitops/builtin-__fls.h
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
#ifndef _ASM_GENERIC_BITOPS_BUILTIN___FLS_H_
|
||||||
|
#define _ASM_GENERIC_BITOPS_BUILTIN___FLS_H_
|
||||||
|
|
||||||
|
/**
|
||||||
|
* __fls - find last (most-significant) set bit in a long word
|
||||||
|
* @word: the word to search
|
||||||
|
*
|
||||||
|
* Undefined if no set bit exists, so code should check against 0 first.
|
||||||
|
*/
|
||||||
|
static __always_inline unsigned long __fls(unsigned long word)
|
||||||
|
{
|
||||||
|
return (sizeof(word) * 8) - 1 - __builtin_clzl(word);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
17
include/asm-generic/bitops/builtin-ffs.h
Normal file
17
include/asm-generic/bitops/builtin-ffs.h
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
#ifndef _ASM_GENERIC_BITOPS_BUILTIN_FFS_H_
|
||||||
|
#define _ASM_GENERIC_BITOPS_BUILTIN_FFS_H_
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ffs - find first bit set
|
||||||
|
* @x: the word to search
|
||||||
|
*
|
||||||
|
* This is defined the same way as
|
||||||
|
* the libc and compiler builtin ffs routines, therefore
|
||||||
|
* differs in spirit from the above ffz (man ffs).
|
||||||
|
*/
|
||||||
|
static __always_inline int ffs(int x)
|
||||||
|
{
|
||||||
|
return __builtin_ffs(x);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
16
include/asm-generic/bitops/builtin-fls.h
Normal file
16
include/asm-generic/bitops/builtin-fls.h
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
#ifndef _ASM_GENERIC_BITOPS_BUILTIN_FLS_H_
|
||||||
|
#define _ASM_GENERIC_BITOPS_BUILTIN_FLS_H_
|
||||||
|
|
||||||
|
/**
|
||||||
|
* fls - find last (most-significant) bit set
|
||||||
|
* @x: the word to search
|
||||||
|
*
|
||||||
|
* This is defined the same way as ffs.
|
||||||
|
* Note fls(0) = 0, fls(1) = 1, fls(0x80000000) = 32.
|
||||||
|
*/
|
||||||
|
static __always_inline int fls(int x)
|
||||||
|
{
|
||||||
|
return x ? sizeof(x) * 8 - __builtin_clz(x) : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
Reference in New Issue
Block a user