summaryrefslogtreecommitdiff
path: root/lib/ccan/ilog/_info
blob: 9a92f4e70e98f6ec87161dd18b6ccfd16df49bad (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/**
 * ilog - Integer logarithm.
 *
 * ilog_32() and ilog_64() compute the minimum number of bits required to store
 *  an unsigned 32-bit or 64-bit value without any leading zero bits.
 * This can also be thought of as the location of the highest set bit, with
 *  counting starting from one (so that 0 returns 0, 1 returns 1, and 2**31
 *  returns 32).
 * When the value is known to be non-zero ilog32_nz() and ilog64_nz() can
 *  compile into as few as two instructions, one of which may get optimized out
 *  later.
 * STATIC_ILOG_32 and STATIC_ILOG_64 allow computation on compile-time
 *  constants, so other compile-time constants can be derived from them.
 *
 * Example:
 *  #include <stdio.h>
 *  #include <limits.h>
 *  #include <ccan/ilog/ilog.h>
 *
 *  int main(void){
 *    int i;
 *    printf("ilog32(0x%08X)=%i\n",0,ilog32(0));
 *    for(i=1;i<=STATIC_ILOG_32(USHRT_MAX);i++){
 *      uint32_t v;
 *      v=(uint32_t)1U<<(i-1);
 *      //Here we know v is non-zero, so we can use ilog32_nz().
 *      printf("ilog32(0x%08X)=%i\n",v,ilog32_nz(v));
 *    }
 *    return 0;
 *  }
 *
 * License: LGPL (v2.1 or any later version)
 * Author: Timothy B. Terriberry <tterribe@xiph.org>
 */
#include <string.h>
#include <stdio.h>
#include "config.h"

int main(int _argc,const char *_argv[]){
  /*Expect exactly one argument.*/
  if(_argc!=2)return 1;
  if(strcmp(_argv[1],"depends")==0){
    printf("ccan/compiler\n");
    return 0;
  }
  return 1;
}