1 #ifndef FIO_FFZ_H 2 #define FIO_FFZ_H 3 4 #include <inttypes.h> 5 6 static inline int ffs64(uint64_t word) 7 { 8 int r = 0; 9 10 if ((word & 0xffffffff) == 0) { 11 r += 32; 12 word >>= 32; 13 } 14 if (!(word & 0xffff)) { 15 word >>= 16; 16 r += 16; 17 } 18 if (!(word & 0xff)) { 19 word >>= 8; 20 r += 8; 21 } 22 if (!(word & 0xf)) { 23 word >>= 4; 24 r += 4; 25 } 26 if (!(word & 3)) { 27 word >>= 2; 28 r += 2; 29 } 30 if (!(word & 1)) { 31 word >>= 1; 32 r += 1; 33 } 34 35 return r; 36 } 37 38 #ifndef ARCH_HAVE_FFZ 39 40 static inline int ffz(unsigned long bitmask) 41 { 42 return ffs64(~bitmask); 43 } 44 45 #else 46 #define ffz(bitmask) arch_ffz(bitmask) 47 #endif 48 49 static inline int ffz64(uint64_t bitmask) 50 { 51 return ffs64(~bitmask); 52 } 53 54 #endif 55