diff options
author | Sebastian Andrzej Siewior <bigeasy@linutronix.de> | 2015-05-08 22:26:38 +0200 |
---|---|---|
committer | Anders Roxell <anders.roxell@linaro.org> | 2015-05-08 22:30:54 +0200 |
commit | e6e52dd280d935ffd8d5fac58544bc5943079c7b (patch) | |
tree | d71c1c4f5b11c2f3c3e7bd76de78a313a7bfb781 /mm | |
parent | de7005638885ad7bba128948a205966048a342a0 (diff) |
slub: delay ctor until the object is requested
It seems that allocation of plenty objects causes latency on ARM since that
code can not be preempted
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: Anders Roxell <anders.roxell@linaro.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/slub.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/mm/slub.c b/mm/slub.c index 534609a0326a..72bb06beaabc 100644 --- a/mm/slub.c +++ b/mm/slub.c @@ -1376,8 +1376,10 @@ static void setup_object(struct kmem_cache *s, struct page *page, void *object) { setup_object_debug(s, page, object); +#ifndef CONFIG_PREEMPT_RT_FULL if (unlikely(s->ctor)) s->ctor(object); +#endif } static struct page *new_slab(struct kmem_cache *s, gfp_t flags, int node) @@ -2499,6 +2501,10 @@ redo: if (unlikely(gfpflags & __GFP_ZERO) && object) memset(object, 0, s->object_size); +#ifdef CONFIG_PREEMPT_RT_FULL + if (unlikely(s->ctor) && object) + s->ctor(object); +#endif slab_post_alloc_hook(s, gfpflags, object); |