* [PATCH 0/2] net: isolate SKB data area allocations
@ 2026-06-02 18:31 Pedro Falcato
2026-06-02 18:31 ` [PATCH 1/2] mm/slab: add a node-track-caller variant for kmem buckets allocation Pedro Falcato
2026-06-02 18:31 ` [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket Pedro Falcato
0 siblings, 2 replies; 8+ messages in thread
From: Pedro Falcato @ 2026-06-02 18:31 UTC (permalink / raw)
To: Vlastimil Babka, Harry Yoo, Andrew Morton, David S. Miller,
Eric Dumazet, Jakub Kicinski, Paolo Abeni
Cc: linux-hardening, linux-mm, netdev, linux-kernel, Hao Li,
Christoph Lameter, David Rientjes, Roman Gushchin, Simon Horman,
Jason Xing, Kuniyuki Iwashima, Pedro Falcato
This is a rather simple series that attempts to address a possible
exploitation avenue - the allocation of skbs around the network stack, which
frequently get user-controlled contents. Found while doing some amateur
exploitation analysis for some other issue, elsewhere.
Patch 0 is a precursor patch that adds a slab allocation helper, patch 1
does the actual bucketing.
I don't know what tree should pick this up, so I just based this on linux-next.
Pedro Falcato (2):
mm/slab: add a node-track-caller variant for kmem buckets allocation
net: skb: isolate skb data area allocations into a separate bucket
include/linux/slab.h | 7 +++++--
net/core/skbuff.c | 5 ++++-
2 files changed, 9 insertions(+), 3 deletions(-)
--
2.54.0
^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH 1/2] mm/slab: add a node-track-caller variant for kmem buckets allocation
2026-06-02 18:31 [PATCH 0/2] net: isolate SKB data area allocations Pedro Falcato
@ 2026-06-02 18:31 ` Pedro Falcato
2026-06-04 5:19 ` Harry Yoo
2026-06-02 18:31 ` [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket Pedro Falcato
1 sibling, 1 reply; 8+ messages in thread
From: Pedro Falcato @ 2026-06-02 18:31 UTC (permalink / raw)
To: Vlastimil Babka, Harry Yoo, Andrew Morton, David S. Miller,
Eric Dumazet, Jakub Kicinski, Paolo Abeni
Cc: linux-hardening, linux-mm, netdev, linux-kernel, Hao Li,
Christoph Lameter, David Rientjes, Roman Gushchin, Simon Horman,
Jason Xing, Kuniyuki Iwashima, Pedro Falcato
This is required by users that want to use kmem buckets, but still
desire specifying the NUMA node.
Signed-off-by: Pedro Falcato <pfalcato@suse.de>
---
include/linux/slab.h | 7 +++++--
1 file changed, 5 insertions(+), 2 deletions(-)
diff --git a/include/linux/slab.h b/include/linux/slab.h
index 7b46fa499b08..685a87d8f0c5 100644
--- a/include/linux/slab.h
+++ b/include/linux/slab.h
@@ -1153,8 +1153,11 @@ void *kmalloc_nolock(size_t size, gfp_t gfp_flags, int node);
#define kmem_buckets_alloc(_b, _size, _flags) \
alloc_hooks(__kmalloc_node_noprof(PASS_KMALLOC_PARAMS(_size, _b, __kmalloc_token(_size)), _flags, NUMA_NO_NODE))
-#define kmem_buckets_alloc_track_caller(_b, _size, _flags) \
- alloc_hooks(__kmalloc_node_track_caller_noprof(PASS_KMALLOC_PARAMS(_size, _b, __kmalloc_token(_size)), _flags, NUMA_NO_NODE, _RET_IP_))
+#define kmem_buckets_alloc_node_track_caller(_b, _size, _flags, _node) \
+ alloc_hooks(__kmalloc_node_track_caller_noprof(PASS_KMALLOC_PARAMS(_size, _b, __kmalloc_token(_size)), _flags, _node, _RET_IP_))
+
+#define kmem_buckets_alloc_track_caller(_b, _size, _flags) \
+ kmem_buckets_alloc_node_track_caller(_b, _size, _flags, NUMA_NO_NODE)
static __always_inline __alloc_size(1) void *_kmalloc_node_noprof(size_t size, gfp_t flags, int node, kmalloc_token_t token)
{
--
2.54.0
^ permalink raw reply related [flat|nested] 8+ messages in thread
* [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket
2026-06-02 18:31 [PATCH 0/2] net: isolate SKB data area allocations Pedro Falcato
2026-06-02 18:31 ` [PATCH 1/2] mm/slab: add a node-track-caller variant for kmem buckets allocation Pedro Falcato
@ 2026-06-02 18:31 ` Pedro Falcato
2026-06-04 5:30 ` Harry Yoo
2026-06-05 1:52 ` Jakub Kicinski
1 sibling, 2 replies; 8+ messages in thread
From: Pedro Falcato @ 2026-06-02 18:31 UTC (permalink / raw)
To: Vlastimil Babka, Harry Yoo, Andrew Morton, David S. Miller,
Eric Dumazet, Jakub Kicinski, Paolo Abeni
Cc: linux-hardening, linux-mm, netdev, linux-kernel, Hao Li,
Christoph Lameter, David Rientjes, Roman Gushchin, Simon Horman,
Jason Xing, Kuniyuki Iwashima, Pedro Falcato
SKB data area allocations (as done from alloc_skb()) use kmalloc().
These allocations can be variably sized and their contents can be more
or less controlled from userspace, which makes them useful for attackers
that want to overwrite a use-after-free'd object from the same kmalloc slab
(which often just requires the sizes to roughly match into the same kmalloc
bucket). [0] is an easy example of an exploit that uses netlink skb
allocation to target another similarly-sized accidentally freed object.
While other mitigations like CONFIG_RANDOM_KMALLOC_CACHES exist, these are
probabilistic. Use the existing kmem buckets API to further isolate these
allocations in a guaranteed fashion, when CONFIG_SLAB_BUCKETS=y.
Link: https://github.com/google/security-research/blob/master/pocs/linux/kernelctf/CVE-2023-4207_lts_cos_mitigation_2/docs/exploit.md [0]
Signed-off-by: Pedro Falcato <pfalcato@suse.de>
---
net/core/skbuff.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/net/core/skbuff.c b/net/core/skbuff.c
index 44a7f8401468..1f6c6b531ece 100644
--- a/net/core/skbuff.c
+++ b/net/core/skbuff.c
@@ -594,6 +594,8 @@ static void *kmalloc_pfmemalloc(size_t obj_size, gfp_t flags, int node)
return kmalloc_node_track_caller(obj_size, flags, node);
}
+static kmem_buckets *skb_data_buckets __ro_after_init;
+
/*
* kmalloc_reserve is a wrapper around kmalloc_node_track_caller that tells
* the caller if emergency pfmemalloc reserves are being used. If it is and
@@ -632,7 +634,7 @@ static void *kmalloc_reserve(unsigned int *size, gfp_t flags, int node,
* Try a regular allocation, when that fails and we're not entitled
* to the reserves, fail.
*/
- obj = kmalloc_node_track_caller(obj_size,
+ obj = kmem_buckets_alloc_node_track_caller(skb_data_buckets, obj_size,
flags | __GFP_NOMEMALLOC | __GFP_NOWARN,
node);
if (likely(obj))
@@ -5213,6 +5215,7 @@ void __init skb_init(void)
0,
SKB_SMALL_HEAD_HEADROOM,
NULL);
+ skb_data_buckets = kmem_buckets_create("skb_data", SLAB_PANIC, 0, INT_MAX, NULL);
skb_extensions_init();
}
--
2.54.0
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH 1/2] mm/slab: add a node-track-caller variant for kmem buckets allocation
2026-06-02 18:31 ` [PATCH 1/2] mm/slab: add a node-track-caller variant for kmem buckets allocation Pedro Falcato
@ 2026-06-04 5:19 ` Harry Yoo
2026-06-04 19:12 ` Pedro Falcato
0 siblings, 1 reply; 8+ messages in thread
From: Harry Yoo @ 2026-06-04 5:19 UTC (permalink / raw)
To: Pedro Falcato, Vlastimil Babka, Andrew Morton, David S. Miller,
Eric Dumazet, Jakub Kicinski, Paolo Abeni
Cc: linux-hardening, linux-mm, netdev, linux-kernel, Hao Li,
Christoph Lameter, David Rientjes, Roman Gushchin, Simon Horman,
Jason Xing, Kuniyuki Iwashima
[-- Attachment #1.1: Type: text/plain, Size: 299 bytes --]
On 6/3/26 3:31 AM, Pedro Falcato wrote:
> This is required by users that want to use kmem buckets, but still
> desire specifying the NUMA node.
>
> Signed-off-by: Pedro Falcato <pfalcato@suse.de>
> ---
Acked-by: Harry Yoo (Oracle) <harry@kernel.org>
--
Cheers,
Harry / Hyeonggon
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket
2026-06-02 18:31 ` [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket Pedro Falcato
@ 2026-06-04 5:30 ` Harry Yoo
2026-06-04 19:12 ` Pedro Falcato
2026-06-05 1:52 ` Jakub Kicinski
1 sibling, 1 reply; 8+ messages in thread
From: Harry Yoo @ 2026-06-04 5:30 UTC (permalink / raw)
To: Pedro Falcato, Vlastimil Babka, Andrew Morton, David S. Miller,
Eric Dumazet, Jakub Kicinski, Paolo Abeni
Cc: linux-hardening, linux-mm, netdev, linux-kernel, Hao Li,
Christoph Lameter, David Rientjes, Roman Gushchin, Simon Horman,
Jason Xing, Kuniyuki Iwashima
[-- Attachment #1.1: Type: text/plain, Size: 2374 bytes --]
On 6/3/26 3:31 AM, Pedro Falcato wrote:
> SKB data area allocations (as done from alloc_skb()) use kmalloc().
> These allocations can be variably sized and their contents can be more
> or less controlled from userspace, which makes them useful for attackers
> that want to overwrite a use-after-free'd object from the same kmalloc slab
> (which often just requires the sizes to roughly match into the same kmalloc
> bucket). [0] is an easy example of an exploit that uses netlink skb
> allocation to target another similarly-sized accidentally freed object.
>
> While other mitigations like CONFIG_RANDOM_KMALLOC_CACHES exist, these are
> probabilistic. Use the existing kmem buckets API to further isolate these
> allocations in a guaranteed fashion, when CONFIG_SLAB_BUCKETS=y.
>
> Link: https://github.com/google/security-research/blob/master/pocs/linux/kernelctf/CVE-2023-4207_lts_cos_mitigation_2/docs/exploit.md [0]
> Signed-off-by: Pedro Falcato <pfalcato@suse.de>
> ---
> net/core/skbuff.c | 5 ++++-
> 1 file changed, 4 insertions(+), 1 deletion(-)
>
> diff --git a/net/core/skbuff.c b/net/core/skbuff.c
> index 44a7f8401468..1f6c6b531ece 100644
> --- a/net/core/skbuff.c
> +++ b/net/core/skbuff.c
> @@ -594,6 +594,8 @@ static void *kmalloc_pfmemalloc(size_t obj_size, gfp_t flags, int node)
> return kmalloc_node_track_caller(obj_size, flags, node);
> }
>
> +static kmem_buckets *skb_data_buckets __ro_after_init;
> +
> /*
> * kmalloc_reserve is a wrapper around kmalloc_node_track_caller that tells
> * the caller if emergency pfmemalloc reserves are being used. If it is and
> @@ -632,7 +634,7 @@ static void *kmalloc_reserve(unsigned int *size, gfp_t flags, int node,
> * Try a regular allocation, when that fails and we're not entitled
> * to the reserves, fail.
> */
> - obj = kmalloc_node_track_caller(obj_size,
> + obj = kmem_buckets_alloc_node_track_caller(skb_data_buckets, obj_size,
> flags | __GFP_NOMEMALLOC | __GFP_NOWARN,
> node);
> if (likely(obj))
What about kmalloc_pfmemalloc()?
> @@ -5213,6 +5215,7 @@ void __init skb_init(void)
> 0,
> SKB_SMALL_HEAD_HEADROOM,
> NULL);
> + skb_data_buckets = kmem_buckets_create("skb_data", SLAB_PANIC, 0, INT_MAX, NULL);
> skb_extensions_init();
> }
>
--
Cheers,
Harry / Hyeonggon
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket
2026-06-04 5:30 ` Harry Yoo
@ 2026-06-04 19:12 ` Pedro Falcato
0 siblings, 0 replies; 8+ messages in thread
From: Pedro Falcato @ 2026-06-04 19:12 UTC (permalink / raw)
To: Harry Yoo
Cc: Vlastimil Babka, Andrew Morton, David S. Miller, Eric Dumazet,
Jakub Kicinski, Paolo Abeni, linux-hardening, linux-mm, netdev,
linux-kernel, Hao Li, Christoph Lameter, David Rientjes,
Roman Gushchin, Simon Horman, Jason Xing, Kuniyuki Iwashima
On Thu, Jun 04, 2026 at 02:30:34PM +0900, Harry Yoo wrote:
>
>
> On 6/3/26 3:31 AM, Pedro Falcato wrote:
> > SKB data area allocations (as done from alloc_skb()) use kmalloc().
> > These allocations can be variably sized and their contents can be more
> > or less controlled from userspace, which makes them useful for attackers
> > that want to overwrite a use-after-free'd object from the same kmalloc slab
> > (which often just requires the sizes to roughly match into the same kmalloc
> > bucket). [0] is an easy example of an exploit that uses netlink skb
> > allocation to target another similarly-sized accidentally freed object.
> >
> > While other mitigations like CONFIG_RANDOM_KMALLOC_CACHES exist, these are
> > probabilistic. Use the existing kmem buckets API to further isolate these
> > allocations in a guaranteed fashion, when CONFIG_SLAB_BUCKETS=y.
> >
> > Link: https://github.com/google/security-research/blob/master/pocs/linux/kernelctf/CVE-2023-4207_lts_cos_mitigation_2/docs/exploit.md [0]
> > Signed-off-by: Pedro Falcato <pfalcato@suse.de>
> > ---
> > net/core/skbuff.c | 5 ++++-
> > 1 file changed, 4 insertions(+), 1 deletion(-)
> >
> > diff --git a/net/core/skbuff.c b/net/core/skbuff.c
> > index 44a7f8401468..1f6c6b531ece 100644
> > --- a/net/core/skbuff.c
> > +++ b/net/core/skbuff.c
> > @@ -594,6 +594,8 @@ static void *kmalloc_pfmemalloc(size_t obj_size, gfp_t flags, int node)
> > return kmalloc_node_track_caller(obj_size, flags, node);
> > }
> >
> > +static kmem_buckets *skb_data_buckets __ro_after_init;
> > +
> > /*
> > * kmalloc_reserve is a wrapper around kmalloc_node_track_caller that tells
> > * the caller if emergency pfmemalloc reserves are being used. If it is and
> > @@ -632,7 +634,7 @@ static void *kmalloc_reserve(unsigned int *size, gfp_t flags, int node,
> > * Try a regular allocation, when that fails and we're not entitled
> > * to the reserves, fail.
> > */
> > - obj = kmalloc_node_track_caller(obj_size,
> > + obj = kmem_buckets_alloc_node_track_caller(skb_data_buckets, obj_size,
> > flags | __GFP_NOMEMALLOC | __GFP_NOWARN,
> > node);
> > if (likely(obj))
>
> What about kmalloc_pfmemalloc()?
Good point, that looks free as well.
Sidenote: isolating kmem_cache_alloc for possibly-aliasing caches could also
be useful. skb allocation has net_hotdata.skb_small_head_cache. It doesn't merge
with anything for $raisins (odd size, plus I don't think usercopy caches are
getting merged?) but it feels too... accidental?
Maybe passing something like SLAB_NO_MERGE and making the size
standard-looking would be nice. I have a size of 704 bytes per object, and
this probably causes some weird wastage for each slab.
--
Pedro
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH 1/2] mm/slab: add a node-track-caller variant for kmem buckets allocation
2026-06-04 5:19 ` Harry Yoo
@ 2026-06-04 19:12 ` Pedro Falcato
0 siblings, 0 replies; 8+ messages in thread
From: Pedro Falcato @ 2026-06-04 19:12 UTC (permalink / raw)
To: Harry Yoo
Cc: Vlastimil Babka, Andrew Morton, David S. Miller, Eric Dumazet,
Jakub Kicinski, Paolo Abeni, linux-hardening, linux-mm, netdev,
linux-kernel, Hao Li, Christoph Lameter, David Rientjes,
Roman Gushchin, Simon Horman, Jason Xing, Kuniyuki Iwashima
On Thu, Jun 04, 2026 at 02:19:30PM +0900, Harry Yoo wrote:
>
>
> On 6/3/26 3:31 AM, Pedro Falcato wrote:
> > This is required by users that want to use kmem buckets, but still
> > desire specifying the NUMA node.
> >
> > Signed-off-by: Pedro Falcato <pfalcato@suse.de>
> > ---
>
> Acked-by: Harry Yoo (Oracle) <harry@kernel.org>
Thanks for the review!
--
Pedro
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket
2026-06-02 18:31 ` [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket Pedro Falcato
2026-06-04 5:30 ` Harry Yoo
@ 2026-06-05 1:52 ` Jakub Kicinski
1 sibling, 0 replies; 8+ messages in thread
From: Jakub Kicinski @ 2026-06-05 1:52 UTC (permalink / raw)
To: Pedro Falcato
Cc: Vlastimil Babka, Harry Yoo, Andrew Morton, David S. Miller,
Eric Dumazet, Paolo Abeni, linux-hardening, linux-mm, netdev,
linux-kernel, Hao Li, Christoph Lameter, David Rientjes,
Roman Gushchin, Simon Horman, Jason Xing, Kuniyuki Iwashima
On Tue, 2 Jun 2026 19:31:22 +0100 Pedro Falcato wrote:
> SKB data area allocations (as done from alloc_skb()) use kmalloc().
> These allocations can be variably sized and their contents can be more
> or less controlled from userspace, which makes them useful for attackers
> that want to overwrite a use-after-free'd object from the same kmalloc slab
> (which often just requires the sizes to roughly match into the same kmalloc
> bucket). [0] is an easy example of an exploit that uses netlink skb
> allocation to target another similarly-sized accidentally freed object.
>
> While other mitigations like CONFIG_RANDOM_KMALLOC_CACHES exist, these are
> probabilistic. Use the existing kmem buckets API to further isolate these
> allocations in a guaranteed fashion, when CONFIG_SLAB_BUCKETS=y.
No idea on the merits but from networking point of view:
Acked-by: Jakub Kicinski <kuba@kernel.org>
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2026-06-05 1:52 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-06-02 18:31 [PATCH 0/2] net: isolate SKB data area allocations Pedro Falcato
2026-06-02 18:31 ` [PATCH 1/2] mm/slab: add a node-track-caller variant for kmem buckets allocation Pedro Falcato
2026-06-04 5:19 ` Harry Yoo
2026-06-04 19:12 ` Pedro Falcato
2026-06-02 18:31 ` [PATCH 2/2] net: skb: isolate skb data area allocations into a separate bucket Pedro Falcato
2026-06-04 5:30 ` Harry Yoo
2026-06-04 19:12 ` Pedro Falcato
2026-06-05 1:52 ` Jakub Kicinski
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox