1 //===-- popcountti2_test.c - Test __popcountti2 ----------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file tests __popcountti2 for the compiler_rt library.
12 //===----------------------------------------------------------------------===//
20 // Returns: count of 1 bits
22 si_int
__popcountti2(ti_int a
);
24 int naive_popcount(ti_int a
)
27 for (; a
; a
= (tu_int
)a
>> 1)
32 int test__popcountti2(ti_int a
)
34 si_int x
= __popcountti2(a
);
35 si_int expected
= naive_popcount(a
);
40 printf("error in __popcountti2(0x%.16llX%.16llX) = %d, expected %d\n",
41 at
.s
.high
, at
.s
.low
, x
, expected
);
46 char assumption_1
[sizeof(ti_int
) == 2*sizeof(di_int
)] = {0};
47 char assumption_2
[sizeof(di_int
)*CHAR_BIT
== 64] = {0};
54 if (test__popcountti2(0))
56 if (test__popcountti2(1))
58 if (test__popcountti2(2))
60 if (test__popcountti2(0xFFFFFFFFFFFFFFFDLL
))
62 if (test__popcountti2(0xFFFFFFFFFFFFFFFELL
))
64 if (test__popcountti2(0xFFFFFFFFFFFFFFFFLL
))
66 if (test__popcountti2(make_ti(0xFFFFFFFFFFFFFFFFLL
, 0xFFFFFFFFFFFFFFFDLL
)))
68 if (test__popcountti2(make_ti(0xFFFFFFFFFFFFFFFFLL
, 0xFFFFFFFFFFFFFFFELL
)))
70 if (test__popcountti2(make_ti(0xFFFFFFFFFFFFFFFFLL
, 0xFFFFFFFFFFFFFFFFLL
)))
73 for (i
= 0; i
< 10000; ++i
)
74 if (test__popcountti2(((ti_int
)rand() << 96) | ((ti_int
)rand() << 64) |
75 ((ti_int
)rand() << 32) | rand()))