Re: [PATCH v2 3/4] drm/xe: Wire up dmem cgroup reclaim for VRAM manager
From: Thomas Hellström
Date: Tue Apr 28 2026 - 06:02:51 EST
On Tue, 2026-04-28 at 11:50 +0200, Maarten Lankhorst wrote:
>
>
> Den 2026-04-28 kl. 09:31, skrev Thomas Hellström:
> > Register the VRAM manager with the dmem cgroup reclaim
> > infrastructure
> > so that lowering dmem.max below current VRAM usage triggers TTM
> > eviction rather than failing with -EBUSY.
> >
> > Assisted-by: GitHub Copilot:claude-sonnet-4.6
> > Signed-off-by: Thomas Hellström <thomas.hellstrom@xxxxxxxxxxxxxxx>
> > ---
> > drivers/gpu/drm/xe/xe_ttm_vram_mgr.c | 19 ++++++++++++-------
> > 1 file changed, 12 insertions(+), 7 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/xe/xe_ttm_vram_mgr.c
> > b/drivers/gpu/drm/xe/xe_ttm_vram_mgr.c
> > index 5fd0d5506a7e..1bdcb3fee901 100644
> > --- a/drivers/gpu/drm/xe/xe_ttm_vram_mgr.c
> > +++ b/drivers/gpu/drm/xe/xe_ttm_vram_mgr.c
> > @@ -303,13 +303,6 @@ int __xe_ttm_vram_mgr_init(struct xe_device
> > *xe, struct xe_ttm_vram_mgr *mgr,
> > struct ttm_resource_manager *man = &mgr->manager;
> > int err;
> >
> > - if (mem_type != XE_PL_STOLEN) {
> > - const char *name = mem_type == XE_PL_VRAM0 ?
> > "vram0" : "vram1";
> > - man->cg = drmm_cgroup_register_region(&xe->drm,
> > name, size);
> > - if (IS_ERR(man->cg))
> > - return PTR_ERR(man->cg);
> > - }
> > -
> > man->func = &xe_ttm_vram_mgr_func;
> > mgr->mem_type = mem_type;
> > mutex_init(&mgr->lock);
> > @@ -318,6 +311,18 @@ int __xe_ttm_vram_mgr_init(struct xe_device
> > *xe, struct xe_ttm_vram_mgr *mgr,
> > mgr->visible_avail = io_size;
> >
> > ttm_resource_manager_init(man, &xe->ttm, size);
> > +
> > + if (mem_type != XE_PL_STOLEN) {
> > + const char *name = mem_type == XE_PL_VRAM0 ?
> > "vram0" : "vram1";
> > + struct dmem_cgroup_region *cg =
> > + drmm_cgroup_register_region(&xe->drm,
> > name, size);
> > +
> > + if (IS_ERR(cg))
> > + return PTR_ERR(cg);
> > +
> > + ttm_resource_manager_set_dmem_region(man, cg);
> > + }
> > +
> > err = gpu_buddy_init(&mgr->mm, man->size,
> > default_page_size);
> > if (err)
> > return err;
>
> This patch will conflict with
> https://patchwork.freedesktop.org/series/164694/ which removes
> stolen support, can we merge that patch first while we wait for AMD
> acks?
Sure, np.
>
> Do I need an ack to get the series through drm-misc?
Which series? The stolen support or this cgroup series?
Thanks,
Thomas
>
> Kind regards,
> ~Maarten Lankhorst