2001-07-06 01:29:17 +08:00
|
|
|
/* ffs -- Find the first bit set in the parameter
|
|
|
|
|
2001-10-16 10:55:31 +08:00
|
|
|
@deftypefn Supplemental int ffs (int @var{valu})
|
2001-07-06 01:29:17 +08:00
|
|
|
|
2001-10-18 06:35:28 +08:00
|
|
|
Find the first (least significant) bit set in @var{valu}. Bits are
|
2001-10-16 10:55:31 +08:00
|
|
|
numbered from right to left, starting with bit 1 (corresponding to the
|
|
|
|
value 1). If @var{valu} is zero, zero is returned.
|
2001-07-06 01:29:17 +08:00
|
|
|
|
2001-10-16 10:55:31 +08:00
|
|
|
@end deftypefn
|
2001-07-06 01:29:17 +08:00
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
int
|
2005-03-28 10:09:01 +08:00
|
|
|
ffs (register int valu)
|
2001-07-06 01:29:17 +08:00
|
|
|
{
|
|
|
|
register int bit;
|
|
|
|
|
|
|
|
if (valu == 0)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
for (bit = 1; !(valu & 1); bit++)
|
|
|
|
valu >>= 1;
|
|
|
|
|
|
|
|
return bit;
|
|
|
|
}
|
|
|
|
|