aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/tree-ssa/popcount.c
blob: efd906a0f5447f0beb3752eded3756999b02e6e6 (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
/* { dg-do compile } */
/* { dg-require-effective-target popcountl } */
/* { dg-options "-O3 -fdump-tree-optimized -fno-tree-ch" } */

extern int foo (int);

int PopCount (long b) {
    int c = 0;
    b++;

    while (b) {
	b &= b - 1;
	c++;
    }
    return c;
}
int PopCount2 (long b) {
    int c = 0;

    while (b) {
	b &= b - 1;
	c++;
    }
    foo (c);
    return foo (c);
}

void PopCount3 (long b1) {

    for (long i = 0; i < b1; ++i)
      {
	long b = i;
	int c = 0;
	while (b) {
	    b &= b - 1;
	    c++;
	}
	foo (c);
      }
}

/* { dg-final { scan-tree-dump-times "__builtin_popcount|\\.POPCOUNT" 3 "optimized" } } */