//===-- popcountsi2_test.c - Test __popcountsi2 ---------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file tests __popcountsi2 for the compiler_rt library. // //===----------------------------------------------------------------------===// #include "int_lib.h" #include <stdio.h> #include <stdlib.h> // Returns: count of 1 bits COMPILER_RT_ABI si_int __popcountsi2(si_int a); int naive_popcount(si_int a) { int r = 0; for (; a; a = (su_int)a >> 1) r += a & 1; return r; } int test__popcountsi2(si_int a) { si_int x = __popcountsi2(a); si_int expected = naive_popcount(a); if (x != expected) printf("error in __popcountsi2(0x%X) = %d, expected %d\n", a, x, expected); return x != expected; } char assumption_2[sizeof(si_int)*CHAR_BIT == 32] = {0}; int main() { if (test__popcountsi2(0)) return 1; if (test__popcountsi2(1)) return 1; if (test__popcountsi2(2)) return 1; if (test__popcountsi2(0xFFFFFFFD)) return 1; if (test__popcountsi2(0xFFFFFFFE)) return 1; if (test__popcountsi2(0xFFFFFFFF)) return 1; int i; for (i = 0; i < 10000; ++i) if (test__popcountsi2(rand())) return 1; return 0; }