|
|
| File: [Development] / xfs-linux / Attic / xfs_rtbit.c (download)
Revision 1.3, Sat Dec 20 00:22:44 1997 UTC (19 years, 10 months ago) by doucette
Rewrite so there are fewer return points. The compiler had a hard time generating compact code for the earlier form. pv: 546137 rv: lord@cray.com |
#ident "$Revision: 1.3 $"
/*
* XFS bit manipulation routines, used only in realtime code.
*/
#include <sys/types.h>
#include "xfs_bit.h"
/*
* xfs_lowbit32: get low bit set out of 32-bit argument, -1 if none set.
*/
int
xfs_lowbit32(
__uint32_t v)
{
int i;
if (v & 0x0000ffff)
if (v & 0x000000ff)
i = 0;
else
i = 8;
else if (v & 0xffff0000)
if (v & 0x00ff0000)
i = 16;
else
i = 24;
else
return -1;
return i + xfs_lowbit[(v >> i) & 0xff];
}
/*
* xfs_highbit64: get high bit set out of 64-bit argument, -1 if none set.
*/
int
xfs_highbit64(
__uint64_t v)
{
int i;
#if (_MIPS_SIM == _ABIN32 || _MIPS_SIM == _ABI64)
if (v & 0xffffffff00000000)
if (v & 0xffff000000000000)
if (v & 0xff00000000000000)
i = 56;
else
i = 48;
else
if (v & 0x0000ff0000000000)
i = 40;
else
i = 32;
else if (v & 0x00000000ffffffff)
if (v & 0x00000000ffff0000)
if (v & 0x00000000ff000000)
i = 24;
else
i = 16;
else
if (v & 0x000000000000ff00)
i = 8;
else
i = 0;
else
return -1;
return i + xfs_highbit[(v >> i) & 0xff];
#else
__uint32_t vw;
if (vw = v >> 32) {
if (vw & 0xffff0000)
if (vw & 0xff000000)
i = 56;
else
i = 48;
else
if (vw & 0x0000ff00)
i = 40;
else
i = 32;
return i + xfs_highbit[(vw >> (i - 32)) & 0xff];
} else if (vw = v) {
if (vw & 0xffff0000)
if (vw & 0xff000000)
i = 24;
else
i = 16;
else
if (vw & 0x0000ff00)
i = 8;
else
i = 0;
return i + xfs_highbit[(vw >> i) & 0xff];
} else
return -1;
#endif
}