mirror of
https://review.haiku-os.org/haiku
synced 2025-01-20 21:41:28 +01:00
ff59ce680d
they were never freed unless the cache was destroyed (I just wondered why my system would bury >1G in the magazines). * Made the magazine capacity variable per cache, ie. for larger objects, it's not a good idea to have 64*CPU buffers lying around in the worst case. * Furthermore, the create_object_cache_etc()/object_depot_init() now have arguments for the magazine capacity as well as the maximum number of full unused magazines. * By default, you might want to initialize both to zero, as then some hopefully usable defaults are computed. Otherwise (the only current example is the vm_page_mapping cache) you can just put in the values you'd want there. The page mapping cache uses larger values, as its objects are usually allocated and deleted in larger chunks. * Beware, though, I couldn't test these changes yet as Qemu didn't like to run today. I'll test these changes on another machine now. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@35601 a95241bf-73f2-0310-859d-f6bbb57e9c96
72 lines
2.1 KiB
C
72 lines
2.1 KiB
C
/*
|
|
* Copyright 2008-2010, 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 <heap.h>
|
|
|
|
|
|
enum {
|
|
/* object_cache_{alloc,free}() flags */
|
|
CACHE_DONT_WAIT_FOR_MEMORY = HEAP_DONT_WAIT_FOR_MEMORY,
|
|
CACHE_DONT_LOCK_KERNEL_SPACE = HEAP_DONT_LOCK_KERNEL_SPACE,
|
|
CACHE_PRIORITY_VIP = HEAP_PRIORITY_VIP,
|
|
CACHE_ALLOC_FLAGS = CACHE_DONT_WAIT_FOR_MEMORY
|
|
| CACHE_DONT_LOCK_KERNEL_SPACE
|
|
| CACHE_PRIORITY_VIP,
|
|
|
|
/* create_object_cache_etc flags */
|
|
CACHE_NO_DEPOT = 0x08000000,
|
|
CACHE_UNLOCKED_PAGES = 0x10000000, // unsupported
|
|
CACHE_LARGE_SLAB = 0x20000000,
|
|
|
|
/* internal */
|
|
CACHE_ALIGN_ON_SIZE = 0x40000000,
|
|
CACHE_DURING_BOOT = 0x80000000
|
|
};
|
|
|
|
struct ObjectCache;
|
|
typedef struct ObjectCache 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 objectSize,
|
|
size_t alignment, void* cookie, object_cache_constructor constructor,
|
|
object_cache_destructor destructor);
|
|
object_cache* create_object_cache_etc(const char* name, size_t objectSize,
|
|
size_t alignment, size_t maxByteUsage, size_t magazineCapacity,
|
|
size_t maxMagazineCount, 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, uint32 flags);
|
|
|
|
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_ */
|