Commit 5252a28b authored by Grygorii Maistrenko's avatar Grygorii Maistrenko Committed by Thadeu Lima de Souza Cascardo

slub: do not merge cache if slub_debug contains a never-merge flag

BugLink: http://bugs.launchpad.net/bugs/1729105


[ Upstream commit c6e28895 ]

In case CONFIG_SLUB_DEBUG_ON=n, find_mergeable() gets debug features from
commandline but never checks if there are features from the
SLAB_NEVER_MERGE set.

As a result selected by slub_debug caches are always mergeable if they
have been created without a custom constructor set or without one of the
SLAB_* debug features on.

This moves the SLAB_NEVER_MERGE check below the flags update from
commandline to make sure it won't merge the slab cache if one of the debug
features is on.

Link: http://lkml.kernel.org/r/20170101124451.GA4740@lp-laptop-dSigned-off-by: default avatarGrygorii Maistrenko <grygoriimkd@gmail.com>
Reviewed-by: default avatarPekka Enberg <penberg@kernel.org>
Acked-by: default avatarDavid Rientjes <rientjes@google.com>
Acked-by: default avatarChristoph Lameter <cl@linux.com>
Cc: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: default avatarSasha Levin <alexander.levin@verizon.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 558c38a2
...@@ -250,7 +250,7 @@ struct kmem_cache *find_mergeable(size_t size, size_t align, ...@@ -250,7 +250,7 @@ struct kmem_cache *find_mergeable(size_t size, size_t align,
{ {
struct kmem_cache *s; struct kmem_cache *s;
if (slab_nomerge || (flags & SLAB_NEVER_MERGE)) if (slab_nomerge)
return NULL; return NULL;
if (ctor) if (ctor)
...@@ -261,6 +261,9 @@ struct kmem_cache *find_mergeable(size_t size, size_t align, ...@@ -261,6 +261,9 @@ struct kmem_cache *find_mergeable(size_t size, size_t align,
size = ALIGN(size, align); size = ALIGN(size, align);
flags = kmem_cache_flags(size, flags, name, NULL); flags = kmem_cache_flags(size, flags, name, NULL);
if (flags & SLAB_NEVER_MERGE)
return NULL;
list_for_each_entry_reverse(s, &slab_caches, list) { list_for_each_entry_reverse(s, &slab_caches, list) {
if (slab_unmergeable(s)) if (slab_unmergeable(s))
continue; continue;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment