diff options
author | Richard Braun <rbraun@sceen.net> | 2014-12-10 21:52:40 +0100 |
---|---|---|
committer | Justus Winter <4winter@informatik.uni-hamburg.de> | 2015-08-15 12:43:27 +0200 |
commit | f070e81f33c7f01a70923782b5358d014712d9ef (patch) | |
tree | 8ceb5b8852c111558d394b002d71fc34bc421996 /ipc | |
parent | 0b0d06c34589595cec2bea6f9b55b8e9ae51c3cf (diff) |
kern/slab: directmap update
The main impact of the direct physical mapping on the kmem module is the
slab size computation. The page allocator requires the allocation size
to be a power-of-two above the page size since it uses the buddy memory
allocation algorithm.
Custom slab allocation functions are no longer needed since the only
user was the kentry area, which has been removed recently.
The KMEM_CACHE_NOCPUPOOL flag is also no longer needed since CPU pools,
which are allocated from a kmem cache, can now always be allocated out
of the direct physical mapping.
Diffstat (limited to 'ipc')
-rw-r--r-- | ipc/ipc_init.c | 30 | ||||
-rw-r--r-- | ipc/ipc_marequest.c | 6 |
2 files changed, 23 insertions, 13 deletions
diff --git a/ipc/ipc_init.c b/ipc/ipc_init.c index 2c58a6e..b7483d4 100644 --- a/ipc/ipc_init.c +++ b/ipc/ipc_init.c @@ -72,17 +72,25 @@ ipc_bootstrap(void) ipc_port_timestamp_lock_init(); ipc_port_timestamp_data = 0; - kmem_cache_init(&ipc_space_cache, "ipc_space", - sizeof(struct ipc_space), 0, NULL, NULL, NULL, 0); - - kmem_cache_init(&ipc_entry_cache, "ipc_entry", - sizeof(struct ipc_entry), 0, NULL, NULL, NULL, 0); - - kmem_cache_init(&ipc_object_caches[IOT_PORT], "ipc_port", - sizeof(struct ipc_port), 0, NULL, NULL, NULL, 0); - - kmem_cache_init(&ipc_object_caches[IOT_PORT_SET], "ipc_pset", - sizeof(struct ipc_pset), 0, NULL, NULL, NULL, 0); + kmem_cache_init (&ipc_space_cache, + "ipc_space", + sizeof(struct ipc_space), 0, + NULL, 0); + + kmem_cache_init (&ipc_entry_cache, + "ipc_entry", + sizeof(struct ipc_entry), 0, + NULL, 0); + + kmem_cache_init (&ipc_object_caches[IOT_PORT], + "ipc_port", + sizeof(struct ipc_port), 0, + NULL, 0); + + kmem_cache_init (&ipc_object_caches[IOT_PORT_SET], + "ipc_pset", + sizeof(struct ipc_pset), 0, + NULL, 0); /* create special spaces */ diff --git a/ipc/ipc_marequest.c b/ipc/ipc_marequest.c index ded1711..ab4d8fe 100644 --- a/ipc/ipc_marequest.c +++ b/ipc/ipc_marequest.c @@ -136,8 +136,10 @@ ipc_marequest_init(void) bucket->imarb_head = IMAR_NULL; } - kmem_cache_init(&ipc_marequest_cache, "ipc_marequest", - sizeof(struct ipc_marequest), 0, NULL, NULL, NULL, 0); + kmem_cache_init (&ipc_marequest_cache, + "ipc_marequest", + sizeof(struct ipc_marequest), 0, + NULL, 0); } /* |