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