mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-08 14:13:53 +00:00
idr: create idr_layer_cache at boot time
Avoid a possible kmem_cache_create() failure by creating idr_layer_cache unconditionary at boot time rather than creating it on-demand when idr_init() is called the first time. This change also enables us to eliminate the check every time idr_init() is called. [akpm@linux-foundation.org: rename init_id_cache() to idr_init_cache()] [akpm@linux-foundation.org: fix alpha build] Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
801678c5a3
commit
199f0ca514
@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/bitops.h>
|
#include <linux/bitops.h>
|
||||||
|
#include <linux/init.h>
|
||||||
|
|
||||||
#if BITS_PER_LONG == 32
|
#if BITS_PER_LONG == 32
|
||||||
# define IDR_BITS 5
|
# define IDR_BITS 5
|
||||||
@ -115,4 +116,6 @@ void ida_remove(struct ida *ida, int id);
|
|||||||
void ida_destroy(struct ida *ida);
|
void ida_destroy(struct ida *ida);
|
||||||
void ida_init(struct ida *ida);
|
void ida_init(struct ida *ida);
|
||||||
|
|
||||||
|
void __init idr_init_cache(void);
|
||||||
|
|
||||||
#endif /* __IDR_H__ */
|
#endif /* __IDR_H__ */
|
||||||
|
@ -58,6 +58,7 @@
|
|||||||
#include <linux/kthread.h>
|
#include <linux/kthread.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
#include <linux/signal.h>
|
#include <linux/signal.h>
|
||||||
|
#include <linux/idr.h>
|
||||||
|
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <asm/bugs.h>
|
#include <asm/bugs.h>
|
||||||
@ -637,6 +638,7 @@ asmlinkage void __init start_kernel(void)
|
|||||||
enable_debug_pagealloc();
|
enable_debug_pagealloc();
|
||||||
cpu_hotplug_init();
|
cpu_hotplug_init();
|
||||||
kmem_cache_init();
|
kmem_cache_init();
|
||||||
|
idr_init_cache();
|
||||||
setup_per_cpu_pageset();
|
setup_per_cpu_pageset();
|
||||||
numa_policy_init();
|
numa_policy_init();
|
||||||
if (late_time_init)
|
if (late_time_init)
|
||||||
|
10
lib/idr.c
10
lib/idr.c
@ -585,12 +585,11 @@ static void idr_cache_ctor(struct kmem_cache *idr_layer_cache, void *idr_layer)
|
|||||||
memset(idr_layer, 0, sizeof(struct idr_layer));
|
memset(idr_layer, 0, sizeof(struct idr_layer));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int init_id_cache(void)
|
void __init idr_init_cache(void)
|
||||||
{
|
{
|
||||||
if (!idr_layer_cache)
|
idr_layer_cache = kmem_cache_create("idr_layer_cache",
|
||||||
idr_layer_cache = kmem_cache_create("idr_layer_cache",
|
sizeof(struct idr_layer), 0, SLAB_PANIC,
|
||||||
sizeof(struct idr_layer), 0, 0, idr_cache_ctor);
|
idr_cache_ctor);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -602,7 +601,6 @@ static int init_id_cache(void)
|
|||||||
*/
|
*/
|
||||||
void idr_init(struct idr *idp)
|
void idr_init(struct idr *idp)
|
||||||
{
|
{
|
||||||
init_id_cache();
|
|
||||||
memset(idp, 0, sizeof(struct idr));
|
memset(idp, 0, sizeof(struct idr));
|
||||||
spin_lock_init(&idp->lock);
|
spin_lock_init(&idp->lock);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user