12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- #include <limits.h>
- #include <string.h>
-
- int ffs(int i)
- {
- #if 1
-
- char n = 1;
- #if UINT_MAX == 0xffffU
-
- #elif UINT_MAX == 0xffffffffU
- if (!(i & 0xffff)) {
- n += 16;
- i >>= 16;
- }
- #else
- #error ffs needs rewriting!
- #endif
- if (!(i & 0xff)) {
- n += 8;
- i >>= 8;
- }
- if (!(i & 0x0f)) {
- n += 4;
- i >>= 4;
- }
- if (!(i & 0x03)) {
- n += 2;
- i >>= 2;
- }
- return (i) ? (n + ((i+1) & 0x01)) : 0;
- #else
-
- int n;
- for (n = 0 ; i ; ++n) {
- i >>= 1;
- }
- return n;
- #endif
- }
- libc_hidden_def(ffs)
- #if ULONG_MAX == UINT_MAX
- strong_alias_untyped(ffs, ffsl)
- #endif
|