bit_util.c 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. #include "test/jemalloc_test.h"
  2. #include "jemalloc/internal/bit_util.h"
  3. #define TEST_POW2_CEIL(t, suf, pri) do { \
  4. unsigned i, pow2; \
  5. t x; \
  6. \
  7. assert_##suf##_eq(pow2_ceil_##suf(0), 0, "Unexpected result"); \
  8. \
  9. for (i = 0; i < sizeof(t) * 8; i++) { \
  10. assert_##suf##_eq(pow2_ceil_##suf(((t)1) << i), ((t)1) \
  11. << i, "Unexpected result"); \
  12. } \
  13. \
  14. for (i = 2; i < sizeof(t) * 8; i++) { \
  15. assert_##suf##_eq(pow2_ceil_##suf((((t)1) << i) - 1), \
  16. ((t)1) << i, "Unexpected result"); \
  17. } \
  18. \
  19. for (i = 0; i < sizeof(t) * 8 - 1; i++) { \
  20. assert_##suf##_eq(pow2_ceil_##suf((((t)1) << i) + 1), \
  21. ((t)1) << (i+1), "Unexpected result"); \
  22. } \
  23. \
  24. for (pow2 = 1; pow2 < 25; pow2++) { \
  25. for (x = (((t)1) << (pow2-1)) + 1; x <= ((t)1) << pow2; \
  26. x++) { \
  27. assert_##suf##_eq(pow2_ceil_##suf(x), \
  28. ((t)1) << pow2, \
  29. "Unexpected result, x=%"pri, x); \
  30. } \
  31. } \
  32. } while (0)
  33. TEST_BEGIN(test_pow2_ceil_u64) {
  34. TEST_POW2_CEIL(uint64_t, u64, FMTu64);
  35. }
  36. TEST_END
  37. TEST_BEGIN(test_pow2_ceil_u32) {
  38. TEST_POW2_CEIL(uint32_t, u32, FMTu32);
  39. }
  40. TEST_END
  41. TEST_BEGIN(test_pow2_ceil_zu) {
  42. TEST_POW2_CEIL(size_t, zu, "zu");
  43. }
  44. TEST_END
  45. int
  46. main(void) {
  47. return test(
  48. test_pow2_ceil_u64,
  49. test_pow2_ceil_u32,
  50. test_pow2_ceil_zu);
  51. }