-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathslab.h
80 lines (60 loc) · 1.52 KB
/
slab.h
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#ifndef SLAB_H
#define SLAB_H 1
#include <stdlib.h>
#include <unistd.h>
#define PAGE_SZ (size_t)sysconf(_SC_PAGESIZE)
#define SLAB_SMALL_OBJ_SZ PAGE_SZ/8
#define SLAB_DEFAULT_ALIGN 8
#define CACHE_LINE_SZ 0x40
#define KM_SLEEP 0x00
#define KM_NOSLEEP 0x01
struct kmem_bufctl;
struct kmem_slab;
struct kmem_cache;
typedef struct kmem_cache * kmem_cache_t;
typedef struct kmem_bufctl * kmem_bufctl_t;
typedef struct kmem_slab * kmem_slab_t;
struct kmem_bufctl {
void * buf;
kmem_bufctl_t next;
kmem_slab_t slab;
};
struct kmem_slab {
kmem_slab_t next;
kmem_slab_t prev;
kmem_bufctl_t start;
void* free_list; /* may point to bufctl or buf directly */
int bufcount;
};
struct kmem_cache {
char * name;
size_t size;
size_t effsize;
int slab_maxbuf;
void (*constructor)(void *, size_t);
void (*destructor)(void *, size_t);
kmem_slab_t slabs;
kmem_slab_t slabs_back;
};
kmem_cache_t
kmem_cache_create(char *name, size_t size, int align,
void (*constructor)(void *, size_t),
void (*destructor)(void *, size_t));
void *
kmem_cache_alloc(kmem_cache_t cp, int flags);
void
kmem_cache_free(kmem_cache_t cp, void *buf);
void
kmem_cache_destroy(kmem_cache_t cp);
// TODO
void
kmem_cache_grow(kmem_cache_t cp);
void
kmem_cache_reap(void);
inline void
__slab_remove(kmem_cache_t cp, kmem_slab_t slab);
inline void
__slab_move_to_front(kmem_cache_t cp, kmem_slab_t slab);
inline void
__slab_move_to_back(kmem_cache_t cp, kmem_slab_t slab);
#endif