From: Matthew Wilcox <willy@infradead.org>
To: Mohammed EL Kadiri <med08elkadiri@gmail.com>
Cc: Andrew Morton <akpm@linux-foundation.org>,
Vlastimil Babka <vbabka@suse.cz>,
David Hildenbrand <david@redhat.com>,
Lorenzo Stoakes <lorenzo.stoakes@oracle.com>,
Jonathan Corbet <corbet@lwn.net>, Kees Cook <kees@kernel.org>,
linux-mm@kvack.org, linux-doc@vger.kernel.org,
linux-hardening@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH] docs/mm: document slab cache isolation with SLAB_NO_MERGE
Date: Sat, 6 Jun 2026 21:19:04 +0100 [thread overview]
Message-ID: <aiSAuP-qEhH_RoCn@casper.infradead.org> (raw)
In-Reply-To: <20260606155856.15548-1-med08elkadiri@gmail.com>
On Sat, Jun 06, 2026 at 04:58:55PM +0100, Mohammed EL Kadiri wrote:
> +The SLUB allocator merges slab caches with compatible size, alignment, and
More of a question for Vlastimil ... do we want to continue to
distinguish between slab (the API) and SLUB (the implementation)?
I don't think we ever want to go back to a situation where we have
multiple competing implementations of the slab API in the kernel.
So shouldn't we deprecate uses of SLUB, particularly in the
documentation?
> +flags to reduce memory fragmentation. While this improves memory efficiency,
> +it allows objects of different types to share the same slab pages. This
s/ pages//
> +enables cross-cache heap exploitation, where a use-after-free in one object
> +type can be leveraged to corrupt an unrelated type.
> +
> +The `SLAB_NO_MERGE` flag prevents a cache from being merged, ensuring it
> +receives dedicated slab pages.
s/slab pages/a dedicated slab/
> +2. *Actually mergeable*: The cache must not already be unmergeable.
> + A cache is already unmergeable if any of the following is true:
> +
> + - It has a constructor (`ctor` argument is non-NULL).
> + - It has a non-zero `usersize` (with `CONFIG_HARDENED_USERCOPY`).
> + - It already has `SLAB_NO_MERGE` or another `SLAB_NEVER_MERGE` flag.
I don't know if this is good advice for users of the API. It's true
that the slab will already be unmergable for these other reasons, but
it's harmless to specify SLAB_NO_MERGE in that case. And it
communicates intent. And in case somebody removes the ctor in the
future, or we decide to change which flags are in SLAB_NEVER_MERGE,
the slab will still be unmergable.
> +3. *Bounded allocation volume*: The cache has a predictable number of
> + active objects, so the memory cost of dedicated slab pages is
> + acceptable.
I don't understand why this is a criteria.
> +How merging works
> +=================
> +
> +When `kmem_cache_create()` is called:
> +
> +1. If `usersize` is non-zero, the merge path is skipped entirely.
> +
> +2. Otherwise, `find_mergeable()` in `mm/slab_common.c` searches for a
> + compatible existing cache. A merge is prevented if:
> +
> + - The `slab_nomerge` boot parameter is set
> + - The new cache has a constructor
> + - The new cache's flags include `SLAB_NO_MERGE`
> + - No existing cache has compatible size and flags
> +
> +3. If a compatible cache is found, the new cache becomes an alias. Both
> + share the same slab pages.
This feels like documenting internals rather than documenting how to use
the flag. I'd drop it entirely.
> +The cross-cache attack class
> +=============================
> +
> +Cross-cache attacks exploit slab merging to achieve type confusion:
> +
> +1. Attacker triggers a use-after-free in object type A.
> +2. Type A's cache is merged with type B (they share slab pages).
> +3. The freed type A slot is reallocated as type B.
> +4. Attacker uses the dangling pointer to corrupt type B.
> +5. Privilege escalation.
> +
> +CVE-2022-29582 demonstrates this technique: an io_uring use-after-free is
> +exploited via cross-cache page-level reallocation to achieve root.
> +
> +`SLAB_NO_MERGE` prevents step 2: dedicated pages mean a freed slot of
> +one type cannot be reallocated as a different type.
Not sure this section adds anything to what was already described.
> +Tradeoffs
> +=========
> +
> +*Memory*: Isolated caches may have partially-filled slab pages that
> +cannot be used by other types. For caches with bounded allocation counts,
> +this is typically a few extra pages.
> +
> +*Performance*: Zero impact on `kmem_cache_alloc()` and
> +`kmem_cache_free()`. The only effect is at boot when the cache is
> +created.
> +
> +Relationship to other mitigations
> +==================================
> +
> +`CONFIG_RANDOM_KMALLOC_CACHES`
> + Creates 16 copies of each `kmalloc` size class and randomly assigns
> + allocations among them. Only affects `kmalloc()` users. Does not
> + affect named caches created with `kmem_cache_create()`.
> +
> +`SLAB_TYPESAFE_BY_RCU`
> + Delays freeing the slab page by an RCU grace period. Does not delay
> + object slot reuse. Does not prevent cross-cache merging. Solves a
> + different problem: safe lockless access to freed-and-reallocated
> + objects of the same type.
> +
> +`slab_nomerge` boot parameter
> + Disables merging for all caches globally. `SLAB_NO_MERGE` provides
> + the same protection selectively for individual caches without the
> + global memory cost.
These two sections also feel unnecessary.
prev parent reply other threads:[~2026-06-06 20:19 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-06-06 15:58 [PATCH] docs/mm: document slab cache isolation with SLAB_NO_MERGE Mohammed EL Kadiri
2026-06-06 16:11 ` Jonathan Corbet
2026-06-06 17:44 ` Mohammed EL Kadiri
2026-06-06 19:36 ` Jonathan Corbet
2026-06-06 20:19 ` Matthew Wilcox [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aiSAuP-qEhH_RoCn@casper.infradead.org \
--to=willy@infradead.org \
--cc=akpm@linux-foundation.org \
--cc=corbet@lwn.net \
--cc=david@redhat.com \
--cc=kees@kernel.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-hardening@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=lorenzo.stoakes@oracle.com \
--cc=med08elkadiri@gmail.com \
--cc=vbabka@suse.cz \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox