Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1030456AbWBNFYa (ORCPT ); Tue, 14 Feb 2006 00:24:30 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1030364AbWBNFWR (ORCPT ); Tue, 14 Feb 2006 00:22:17 -0500 Received: from ns.miraclelinux.com ([219.118.163.66]:10447 "EHLO mail01.miraclelinux.com") by vger.kernel.org with ESMTP id S1030367AbWBNFFD (ORCPT ); Tue, 14 Feb 2006 00:05:03 -0500 Message-Id: <20060214050444.425684000@localhost.localdomain> References: <20060214050351.252615000@localhost.localdomain> Date: Tue, 14 Feb 2006 14:04:05 +0900 From: Akinobu Mita To: linux-kernel@vger.kernel.org Cc: akpm@osdl.org, Greg Ungerer , linux-mips@linux-mips.org, sparclinux@vger.kernel.org, ultralinux@vger.kernel.org, Akinobu Mita Subject: [patch 14/47] generic ffs() Content-Disposition: inline; filename=ffs-bitops.patch Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1437 Lines: 65 This patch introduces the C-language equivalent of the function: int ffs(int x); In include/asm-generic/bitops/ffs.h This code largely copied from: include/linux/bitops.h Signed-off-by: Akinobu Mita include/asm-generic/bitops/ffs.h | 41 +++++++++++++++++++++++++++++++++++++++ 1 files changed, 41 insertions(+) Index: 2.6-rc/include/asm-generic/bitops/ffs.h =================================================================== --- /dev/null +++ 2.6-rc/include/asm-generic/bitops/ffs.h @@ -0,0 +1,41 @@ +#ifndef _ASM_GENERIC_BITOPS_FFS_H_ +#define _ASM_GENERIC_BITOPS_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 inline int ffs(int x) +{ + int r = 1; + + if (!x) + return 0; + if (!(x & 0xffff)) { + x >>= 16; + r += 16; + } + if (!(x & 0xff)) { + x >>= 8; + r += 8; + } + if (!(x & 0xf)) { + x >>= 4; + r += 4; + } + if (!(x & 3)) { + x >>= 2; + r += 2; + } + if (!(x & 1)) { + x >>= 1; + r += 1; + } + return r; +} + +#endif /* _ASM_GENERIC_BITOPS_FFS_H_ */ -- - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/