]> mj.ucw.cz Git - libucw.git/blob - lib/log2.c
Added a library module for generation of cryptographically secure
[libucw.git] / lib / log2.c
1 /*
2  *      Sherlock Library -- Binary Logarithm
3  *
4  *      (c) 1997 Martin Mares <mj@ucw.cz>
5  */
6
7 #include "lib/lib.h"
8
9 #undef log2
10
11 int
12 log2(u32 x)
13 {
14   uns l;
15
16   if (!x)
17         return 0;
18
19   l = 0;
20   if (x & 0xffff0000) { l += 16; x &= 0xffff0000; }
21   if (x & 0xff00ff00) { l += 8;  x &= 0xff00ff00; }
22   if (x & 0xf0f0f0f0) { l += 4;  x &= 0xf0f0f0f0; }
23   if (x & 0xcccccccc) { l += 2;  x &= 0xcccccccc; }
24   if (x & 0xaaaaaaaa) l++;
25   return l;
26 }