[parisc-linux] backport bitops.h stuff
James Bottomley
James.Bottomley@steeleye.com
04 Aug 2003 11:08:01 -0500
Let me try to clarify, since there are two differently defined macros in
the kernel (off by one) that would appear to have the same interface,
but which in fact have different semantics (I know, recipe for
disaster): ffs and ffz (meaning find first set and find first zero).
Both tend to have machine code implementations for architectures that
support them. The difference is that ffz counts bit zero as zero, but
ffz counts bit zero as one.
They also have different requirements for the error case (no bit set for
ffs and no bit zero for ffz). For ffs, this is defined to be 32. For
ffz, this is undefined.
The reason for all of this is that on x86 there is an instruction bsfl
that actually finds first set bit (but counting from zero, not one), but
the O(1) scheduler needed to find clear bits for the arrays, so ffz was
implemented as the complement of this.
ffs has been around a long time (inherited from BSD). The differing
semantics are because "damnit, computers count from zero not one for
fast operations".
i.e.
ffs(0) == 0
ffz(0) == 0
ffs(1) == 1
ffz(~1) == 0 (same as above ffz, bit zero clear)
ffs(2) == 2
ffz(~3) == 1
[...]
ffs(0x8000000) == 32
ffz(0x7ffffff) == 31
ffz(0xffffffff) == could be anything
Some machine architectures have an __ffs() (usually mirroring a machine
instruction) whose semantics are identical to ffs() except that it also
is undefined in the error case (so ffs can simply be implemented as if
not error case, do __ffs()).
James