util: faster logbase2
authorBrian Paul <brianp@vmware.com>
Thu, 2 Jun 2011 14:43:07 +0000 (08:43 -0600)
committerBrian Paul <brianp@vmware.com>
Thu, 2 Jun 2011 14:45:27 +0000 (08:45 -0600)
src/gallium/auxiliary/util/u_math.h

index 2ecade5..65a99fc 100644 (file)
@@ -477,10 +477,13 @@ float_to_byte_tex(float f)
 static INLINE unsigned
 util_logbase2(unsigned n)
 {
-   unsigned log2 = 0;
-   while (n >>= 1)
-      ++log2;
-   return log2;
+   unsigned pos = 0;
+   if (n >= 1<<16) { n >>= 16; pos += 16; }
+   if (n >= 1<< 8) { n >>=  8; pos +=  8; }
+   if (n >= 1<< 4) { n >>=  4; pos +=  4; }
+   if (n >= 1<< 2) { n >>=  2; pos +=  2; }
+   if (n >= 1<< 1) {           pos +=  1; }
+   return pos;
 }