TEST(Metachunk, basic) { size_t size = 2 * 1024 * 1024; void* memory = malloc(size); ASSERT_TRUE(NULL != memory) << "Failed to malloc 2MB"; Metachunk* metachunk = ::new (memory) Metachunk(size / BytesPerWord, NULL); EXPECT_EQ((MetaWord*) metachunk, metachunk->bottom()); EXPECT_EQ((uintptr_t*) metachunk + metachunk->size(), metachunk->end()); // Check sizes EXPECT_EQ(metachunk->size(), metachunk->word_size()); EXPECT_EQ(pointer_delta(metachunk->end(), metachunk->bottom(), sizeof (MetaWord*)), metachunk->word_size()); // Check usage EXPECT_EQ(metachunk->used_word_size(), metachunk->overhead()); EXPECT_EQ(metachunk->word_size() - metachunk->used_word_size(), metachunk->free_word_size()); EXPECT_EQ(MetachunkTest::top(metachunk), MetachunkTest::initial_top(metachunk)); EXPECT_TRUE(metachunk->is_empty()); // Allocate size_t alloc_size = 64; // Words EXPECT_TRUE(is_size_aligned(alloc_size, Metachunk::object_alignment())); MetaWord* mem = metachunk->allocate(alloc_size); // Check post alloc EXPECT_EQ(MetachunkTest::initial_top(metachunk), mem); EXPECT_EQ(MetachunkTest::top(metachunk), mem + alloc_size); EXPECT_EQ(metachunk->overhead() + alloc_size, metachunk->used_word_size()); EXPECT_EQ(metachunk->word_size() - metachunk->used_word_size(), metachunk->free_word_size()); EXPECT_FALSE(metachunk->is_empty()); // Clear chunk metachunk->reset_empty(); // Check post clear EXPECT_EQ(metachunk->used_word_size(), metachunk->overhead()); EXPECT_EQ(metachunk->word_size() - metachunk->used_word_size(), metachunk->free_word_size()); EXPECT_EQ(MetachunkTest::top(metachunk), MetachunkTest::initial_top(metachunk)); EXPECT_TRUE(metachunk->is_empty()); free(memory); }
static void test() { size_t size = 2 * 1024 * 1024; void* memory = malloc(size); assert(memory != NULL, "Failed to malloc 2MB"); Metachunk* metachunk = ::new (memory) Metachunk(size / BytesPerWord, NULL); assert(metachunk->bottom() == (MetaWord*)metachunk, "assert"); assert(metachunk->end() == (uintptr_t*)metachunk + metachunk->size(), "assert"); // Check sizes assert(metachunk->size() == metachunk->word_size(), "assert"); assert(metachunk->word_size() == pointer_delta(metachunk->end(), metachunk->bottom(), sizeof(MetaWord*)), "assert"); // Check usage assert(metachunk->used_word_size() == metachunk->overhead(), "assert"); assert(metachunk->free_word_size() == metachunk->word_size() - metachunk->used_word_size(), "assert"); assert(metachunk->top() == metachunk->initial_top(), "assert"); assert(metachunk->is_empty(), "assert"); // Allocate size_t alloc_size = 64; // Words assert(is_size_aligned(alloc_size, Metachunk::object_alignment()), "assert"); MetaWord* mem = metachunk->allocate(alloc_size); // Check post alloc assert(mem == metachunk->initial_top(), "assert"); assert(mem + alloc_size == metachunk->top(), "assert"); assert(metachunk->used_word_size() == metachunk->overhead() + alloc_size, "assert"); assert(metachunk->free_word_size() == metachunk->word_size() - metachunk->used_word_size(), "assert"); assert(!metachunk->is_empty(), "assert"); // Clear chunk metachunk->reset_empty(); // Check post clear assert(metachunk->used_word_size() == metachunk->overhead(), "assert"); assert(metachunk->free_word_size() == metachunk->word_size() - metachunk->used_word_size(), "assert"); assert(metachunk->top() == metachunk->initial_top(), "assert"); assert(metachunk->is_empty(), "assert"); free(memory); }