-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsplit_fusion.c
executable file
·56 lines (51 loc) · 1.35 KB
/
split_fusion.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
** split_fusion.c for in /home/locque_d//rendu/proj/malloc/backup_13_10
**
** Made by damien locque
** Login <[email protected]>
**
** Started on Sun Feb 13 22:43:27 2011 damien locque
** Last update Sun Feb 13 22:44:40 2011 damien locque
*/
#include <unistd.h>
#include "malloc.h"
void split(t_chunk *chunk, size_t size)
{
t_chunk *new;
size_t storage_size;
storage_size = size + sizeof(*chunk);
if (((chunk->size - storage_size)) > sizeof(*chunk))
{
new = (t_chunk *)((char *)chunk + storage_size);
new->next = NULL;
new->prev = NULL;
new->size = chunk->size - (size + sizeof(*chunk));
add_by_address_list(new, &free_list, &end_free);
chunk->size = size + sizeof(*chunk);
}
}
void fusion(t_chunk *chunk)
{
if (chunk && chunk->next &&
((t_chunk *)((char *)chunk + chunk->size)) == chunk->next)
{
chunk->size += chunk->next->size;
chunk->next = chunk->next->next;
if (chunk->next)
chunk->next->prev = chunk;
else
end_free = chunk;
fusion(chunk);
}
if (chunk && chunk->prev &&
((t_chunk *)((char *)chunk->prev + chunk->prev->size)) == chunk)
{
chunk->prev->size += chunk->size;
chunk->prev->next = chunk->next;
if (chunk->next)
chunk->next->prev = chunk->prev;
else
end_free = chunk->prev;
fusion(chunk->prev);
}
}