Re: [PATCH V5 8/8] mm/slab: place slabobj_ext metadata in unused space within s->size
From: Hao Li
Date: Thu Jan 08 2026 - 06:49:07 EST
On Thu, Jan 08, 2026 at 05:41:00PM +0900, Harry Yoo wrote:
> On Thu, Jan 08, 2026 at 01:52:09PM +0800, Hao Li wrote:
> > On Mon, Jan 05, 2026 at 05:02:30PM +0900, Harry Yoo wrote:
> > > When a cache has high s->align value and s->object_size is not aligned
> > > to it, each object ends up with some unused space because of alignment.
> > > If this wasted space is big enough, we can use it to store the
> > > slabobj_ext metadata instead of wasting it.
> >
> > Hi, Harry,
>
> Hi Hao,
>
> > When we save obj_ext in s->size space, it seems that slab_ksize() might
> > be missing the corresponding handling.
>
> Oops.
>
> > It still returns s->size, which could cause callers of slab_ksize()
> > to see unexpected data (i.e. obj_ext), or even overwrite the obj_ext data.
>
> Yes indeed.
> Great point, thanks!
>
> I'll fix it by checking if the slab has obj_exts within the object
> layout and returning s->object_size if so.
Makes sense - I think there's one more nuance worth capturing.
slab_ksize() seems to compute the maximum safe size by applying layout
constraints from most-restrictive to least-restrictive:
redzones/poison/KASAN clamp it to object_size, tail metadata
(SLAB_TYPESAFE_BY_RCU / SLAB_STORE_USER) clamps it to inuse, and only
when nothing metadata lives does it return s->size.
With that ordering in mind, SLAB_OBJ_EXT_IN_OBJ should behave like
another "tail metadata" cap: put the check right before `return s->size`,
and if it's set, return s->inuse instead. Curious what you think.
--
Thanks,
Hao
>
> --
> Cheers,
> Harry / Hyeonggon