2019-05-07 22:50:31 +03:00
|
|
|
/* ************************************************************************** */
|
|
|
|
/* */
|
|
|
|
/* ::: :::::::: */
|
|
|
|
/* malloc_tests.c :+: :+: :+: */
|
|
|
|
/* +:+ +:+ +:+ */
|
|
|
|
/* By: gtertysh <gtertysh@student.unit.ua> +#+ +:+ +#+ */
|
|
|
|
/* +#+#+#+#+#+ +#+ */
|
|
|
|
/* Created: 2019/05/06 22:35:37 by foton #+# #+# */
|
2019-05-09 23:53:14 +03:00
|
|
|
/* Updated: 2019/05/09 23:49:52 by gtertysh ### ########.fr */
|
2019-05-07 22:50:31 +03:00
|
|
|
/* */
|
|
|
|
/* ************************************************************************** */
|
|
|
|
|
|
|
|
#include <unistd.h>
|
2019-04-24 20:59:37 +03:00
|
|
|
#include "t.h"
|
2019-05-04 20:23:32 +03:00
|
|
|
#include "ft_malloc.h"
|
|
|
|
#include "ft_malloc_internal.h"
|
|
|
|
|
|
|
|
int inital_base_next_point_to_itself(void)
|
2019-04-24 20:59:37 +03:00
|
|
|
{
|
2019-05-04 20:23:32 +03:00
|
|
|
_IS(g_base.next == &g_base);
|
|
|
|
_END("inital_base_next_point_to_itself");
|
|
|
|
}
|
|
|
|
|
|
|
|
int returns_not_null_pointer(void)
|
|
|
|
{
|
2019-05-05 19:30:06 +03:00
|
|
|
t_chunk *ptr;
|
2019-05-04 20:23:32 +03:00
|
|
|
|
2019-05-05 19:30:06 +03:00
|
|
|
g_base.next = &g_base;
|
2019-05-04 20:23:32 +03:00
|
|
|
ptr = malloc(10);
|
|
|
|
_IS(ptr != NULL);
|
2019-05-05 19:30:06 +03:00
|
|
|
ptr = ptr - 1;
|
|
|
|
_IS(ptr->is_free == 0);
|
2019-05-08 19:50:07 +03:00
|
|
|
_IS(ptr->size == 10 + sizeof(t_chunk));
|
2019-05-07 22:50:31 +03:00
|
|
|
_IS(ptr->magic == MAGIC);
|
2019-05-05 19:30:06 +03:00
|
|
|
_IS(ptr->next == NULL);
|
|
|
|
_IS(ptr->prev != NULL);
|
|
|
|
_IS(ptr->prev->size > TINY * NALLOC && ptr->prev->size < SMALL * NALLOC);
|
2019-05-08 21:46:06 +03:00
|
|
|
// show_alloc_mem();
|
2019-05-04 20:23:32 +03:00
|
|
|
_END("returns_not_null_pointer");
|
2019-04-24 20:59:37 +03:00
|
|
|
}
|
|
|
|
|
2019-05-05 23:31:38 +03:00
|
|
|
int free_concatenates_adjacent_blocks(void)
|
2019-05-05 19:30:06 +03:00
|
|
|
{
|
|
|
|
t_chunk *ptr;
|
|
|
|
t_chunk *next_malloc;
|
|
|
|
t_chunk *heap;
|
|
|
|
|
|
|
|
g_base.next = &g_base;
|
|
|
|
ptr = malloc(10);
|
|
|
|
next_malloc = malloc(10);
|
|
|
|
ptr -= 1;
|
|
|
|
next_malloc -= 1;
|
|
|
|
free(ptr + 1);
|
|
|
|
_IS(ptr->is_free == 1);
|
|
|
|
_IS(ptr->prev == next_malloc);
|
|
|
|
_IS(next_malloc->is_free == 0);
|
|
|
|
_IS(next_malloc->next == ptr);
|
|
|
|
_IS(next_malloc->prev->prev == NULL);
|
|
|
|
heap = next_malloc->prev;
|
|
|
|
free(next_malloc + 1);
|
|
|
|
_IS(heap->is_free == 1);
|
|
|
|
_IS(heap->prev == NULL);
|
|
|
|
_IS(heap->next == NULL);
|
2019-05-05 23:31:38 +03:00
|
|
|
_END("free_concatenates_adjacent_blocks");
|
|
|
|
}
|
|
|
|
|
|
|
|
int malloc_creates_new_arena(void)
|
|
|
|
{
|
|
|
|
t_chunk *second_arena_chunk;
|
|
|
|
int chunks_count;
|
|
|
|
int i;
|
|
|
|
int page;
|
2019-05-07 22:50:31 +03:00
|
|
|
|
2019-05-05 23:31:38 +03:00
|
|
|
g_base.next = &g_base;
|
|
|
|
page = getpagesize();
|
|
|
|
// minimum 100 chunks aligned to page size
|
|
|
|
chunks_count = (ARENA_SIZE(CHUNK_SIZE(TINY) * NALLOC) + page - 1)
|
|
|
|
/ page * page / CHUNK_SIZE(TINY);
|
|
|
|
i = 0;
|
|
|
|
while (i < chunks_count)
|
|
|
|
{
|
2019-05-07 22:50:31 +03:00
|
|
|
second_arena_chunk = malloc(TINY);
|
2019-05-05 23:31:38 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
_IS(g_base.next->next == &g_base);
|
|
|
|
_IS(g_base.next->type == TINY);
|
|
|
|
second_arena_chunk = malloc(TINY);
|
|
|
|
_IS(g_base.next->next != &g_base);
|
|
|
|
_IS(g_base.next->type == TINY);
|
|
|
|
_IS(g_base.next->heap->next == second_arena_chunk - 1);
|
2019-05-08 21:46:06 +03:00
|
|
|
// show_alloc_mem();
|
2019-05-05 23:31:38 +03:00
|
|
|
_END("malloc_creates_new_arena");
|
2019-05-05 19:30:06 +03:00
|
|
|
}
|
|
|
|
|
2019-05-07 22:50:31 +03:00
|
|
|
int realloc_return_same_pointer(void)
|
|
|
|
{
|
|
|
|
t_chunk *ptr;
|
|
|
|
t_chunk *new_ptr;
|
|
|
|
|
|
|
|
g_base.next = &g_base;
|
2019-05-09 23:53:14 +03:00
|
|
|
ptr = malloc(20000);
|
|
|
|
new_ptr = realloc(ptr, 100);
|
2019-05-07 22:50:31 +03:00
|
|
|
_IS(ptr == new_ptr);
|
2019-05-09 23:53:14 +03:00
|
|
|
// show_alloc_mem();
|
2019-05-07 22:50:31 +03:00
|
|
|
_END("realloc_return_same_pointer");
|
|
|
|
}
|
|
|
|
|
2019-05-03 00:18:45 +03:00
|
|
|
int main(void)
|
2019-04-24 20:59:37 +03:00
|
|
|
{
|
2019-05-04 20:23:32 +03:00
|
|
|
_SHOULD(inital_base_next_point_to_itself);
|
|
|
|
_SHOULD(returns_not_null_pointer);
|
2019-05-05 23:31:38 +03:00
|
|
|
_SHOULD(free_concatenates_adjacent_blocks);
|
|
|
|
_SHOULD(malloc_creates_new_arena);
|
2019-05-07 22:50:31 +03:00
|
|
|
_SHOULD(realloc_return_same_pointer);
|
2019-05-08 19:50:07 +03:00
|
|
|
return (0);
|
|
|
|
}
|