PMM - alloc two pages
This commit is contained in:
@@ -5,7 +5,7 @@
|
||||
|
||||
struct {
|
||||
uint8_t data[PAGE_SIZE];
|
||||
}__attribute__((packed)) mem[4];
|
||||
}__attribute__((packed)) mem[2];
|
||||
|
||||
TEST(alloc_returns_freed_page)
|
||||
{
|
||||
@@ -25,3 +25,28 @@ TEST(alloc_zero_after_all_free_pages)
|
||||
void *a = pmm_alloc();
|
||||
ASSERT_EQ_PTR(a, 0);
|
||||
}
|
||||
|
||||
TEST(alloc_two_pages___first_page_is_not_zero)
|
||||
{
|
||||
pmm_free(&mem[0]);
|
||||
pmm_free(&mem[1]);
|
||||
void *a = pmm_alloc();
|
||||
pmm_alloc();
|
||||
ASSERT_NEQ_PTR(a, 0);
|
||||
}
|
||||
TEST(alloc_two_pages___second_page_is_not_zero)
|
||||
{
|
||||
pmm_free(&mem[0]);
|
||||
pmm_free(&mem[1]);
|
||||
pmm_alloc();
|
||||
void *a = pmm_alloc();
|
||||
ASSERT_NEQ_PTR(a, 0);
|
||||
}
|
||||
TEST(alloc_two_pages___doesnt_return_same_page_twice)
|
||||
{
|
||||
pmm_free(&mem[0]);
|
||||
pmm_free(&mem[1]);
|
||||
void *a = pmm_alloc();
|
||||
void *b = pmm_alloc();
|
||||
ASSERT_NEQ_PTR(a, b);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user