mirror of
https://review.haiku-os.org/haiku
synced 2025-01-22 06:16:03 +01:00
1cda5944ad
of free objects an object cache should try to have ready. If the number of free objects drops below the threshold, a new urgent priority thread is asked to asynchronously resize the object cache (pretty similar to the heap grower thread). Such a mechanism is necessary for code paths that are supposed to free pages, but may need memory themselves (like the swap support). git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@27100 a95241bf-73f2-0310-859d-f6bbb57e9c96
65 lines
1.7 KiB
C
65 lines
1.7 KiB
C
/*
|
|
* Copyright 2008, Axel Dörfler. All Rights Reserved.
|
|
* Copyright 2007, Hugo Santos. All Rights Reserved.
|
|
*
|
|
* Distributed under the terms of the MIT License.
|
|
*/
|
|
#ifndef _SLAB_SLAB_H_
|
|
#define _SLAB_SLAB_H_
|
|
|
|
|
|
#include <KernelExport.h>
|
|
#include <OS.h>
|
|
|
|
|
|
enum {
|
|
/* create_object_cache_etc flags */
|
|
CACHE_NO_DEPOT = 1 << 0,
|
|
CACHE_UNLOCKED_PAGES = 1 << 1,
|
|
CACHE_LARGE_SLAB = 1 << 2,
|
|
|
|
/* object_cache_alloc flags */
|
|
CACHE_DONT_SLEEP = 1 << 8,
|
|
|
|
/* internal */
|
|
CACHE_DURING_BOOT = 1 << 31
|
|
};
|
|
|
|
typedef struct object_cache object_cache;
|
|
|
|
typedef status_t (*object_cache_constructor)(void *cookie, void *object);
|
|
typedef void (*object_cache_destructor)(void *cookie, void *object);
|
|
typedef void (*object_cache_reclaimer)(void *cookie, int32 level);
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
object_cache *create_object_cache(const char *name, size_t object_size,
|
|
size_t alignment, void *cookie, object_cache_constructor constructor,
|
|
object_cache_destructor);
|
|
object_cache *create_object_cache_etc(const char *name, size_t object_size,
|
|
size_t alignment, size_t max_byte_usage, uint32 flags, void *cookie,
|
|
object_cache_constructor constructor, object_cache_destructor destructor,
|
|
object_cache_reclaimer reclaimer);
|
|
|
|
void delete_object_cache(object_cache *cache);
|
|
|
|
status_t object_cache_set_minimum_reserve(object_cache *cache,
|
|
size_t objectCount);
|
|
|
|
void *object_cache_alloc(object_cache *cache, uint32 flags);
|
|
void object_cache_free(object_cache *cache, void *object);
|
|
|
|
status_t object_cache_reserve(object_cache *cache, size_t object_count,
|
|
uint32 flags);
|
|
|
|
void object_cache_get_usage(object_cache *cache, size_t *_allocatedMemory);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* _SLAB_SLAB_H_ */
|