slab.h 1.7 KB
Newer Older
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
#ifndef MM_SLAB_H
#define MM_SLAB_H
/*
 * Internal slab definitions
 */

/*
 * State of the slab allocator.
 *
 * This is used to describe the states of the allocator during bootup.
 * Allocators use this to gradually bootstrap themselves. Most allocators
 * have the problem that the structures used for managing slab caches are
 * allocated from slab caches themselves.
 */
enum slab_state {
	DOWN,			/* No slab functionality yet */
	PARTIAL,		/* SLUB: kmem_cache_node available */
	PARTIAL_ARRAYCACHE,	/* SLAB: kmalloc size for arraycache available */
	PARTIAL_L3,		/* SLAB: kmalloc size for l3 struct available */
	UP,			/* Slab caches usable but not all extras yet */
	FULL			/* Everything is working */
};

extern enum slab_state slab_state;

26 27
/* The slab cache mutex protects the management structures during changes */
extern struct mutex slab_mutex;
28 29

/* The list of all slab caches on the system */
30 31
extern struct list_head slab_caches;

32 33 34 35
/* The slab cache that manages slab cache information */
extern struct kmem_cache *kmem_cache;

/* Functions provided by the slab allocators */
36 37
extern int __kmem_cache_create(struct kmem_cache *, const char *name,
	size_t size, size_t align, unsigned long flags, void (*ctor)(void *));
38

39 40 41
#ifdef CONFIG_SLUB
struct kmem_cache *__kmem_cache_alias(const char *name, size_t size,
	size_t align, unsigned long flags, void (*ctor)(void *));
42
extern int sysfs_slab_add(struct kmem_cache *s);
43 44 45 46
#else
static inline struct kmem_cache *__kmem_cache_alias(const char *name, size_t size,
	size_t align, unsigned long flags, void (*ctor)(void *))
{ return NULL; }
47 48
static inline int sysfs_slab_add(struct kmem_cache *s) { return 0; }

49 50 51
#endif


52 53
int __kmem_cache_shutdown(struct kmem_cache *);

54
#endif