From: Boris Brezillon <boris.brezillon@collabora.com>
To: "Adrián Larumbe" <adrian.larumbe@collabora.com>
Cc: "Steven Price" <steven.price@arm.com>,
"Liviu Dudau" <liviu.dudau@arm.com>,
dri-devel@lists.freedesktop.org,
"David Airlie" <airlied@gmail.com>,
"Simona Vetter" <simona@ffwll.ch>,
"Akash Goel" <akash.goel@arm.com>,
"Rob Clark" <robin.clark@oss.qualcomm.com>,
"Sean Paul" <sean@poorly.run>,
"Konrad Dybcio" <konradybcio@kernel.org>,
"Akhil P Oommen" <akhilpo@oss.qualcomm.com>,
"Maarten Lankhorst" <maarten.lankhorst@linux.intel.com>,
"Maxime Ripard" <mripard@kernel.org>,
"Thomas Zimmermann" <tzimmermann@suse.de>,
"Dmitry Osipenko" <dmitry.osipenko@collabora.com>,
"Chris Diamand" <chris.diamand@arm.com>,
"Danilo Krummrich" <dakr@kernel.org>,
"Matthew Brost" <matthew.brost@intel.com>,
"Thomas Hellström" <thomas.hellstrom@linux.intel.com>,
"Alice Ryhl" <aliceryhl@google.com>,
"Chia-I Wu" <olvaffe@gmail.com>,
kernel@collabora.com
Subject: Re: [PATCH v5 9/9] drm/panthor: Add a GEM shrinker
Date: Wed, 25 Mar 2026 09:10:31 +0100 [thread overview]
Message-ID: <20260325091031.36ea296c@fedora> (raw)
In-Reply-To: <acMkjZ0MkKLCnLvi@sobremesa>
On Wed, 25 Mar 2026 00:14:46 +0000
Adrián Larumbe <adrian.larumbe@collabora.com> wrote:
> > +static bool is_gpu_mapped(struct panthor_gem_object *bo,
> > + enum panthor_gem_reclaim_state *state)
> > +{
> > + struct drm_gpuvm *vm = NULL;
> > + struct drm_gpuvm_bo *vm_bo;
> > +
> > + drm_gem_for_each_gpuvm_bo(vm_bo, &bo->base) {
> > + /* Skip evicted GPU mappings. */
> > + if (vm_bo->evicted)
> > + continue;
> > +
> > + if (!vm) {
> > + *state = PANTHOR_GEM_GPU_MAPPED_PRIVATE;
> > + vm = vm_bo->vm;
> > + } else if (vm != vm_bo->vm) {
>
> I might be wrong to think that no two VM_BO's for a given BO can have the same
> VM, but if that were the case, then the above check could be omitted and left
> as an 'else'.
No you're correct. I'll go for:
static bool is_gpu_mapped(struct panthor_gem_object *bo,
enum panthor_gem_reclaim_state *state)
{
struct drm_gpuvm_bo *vm_bo;
u32 vm_count = 0;
drm_gem_for_each_gpuvm_bo(vm_bo, &bo->base) {
/* Skip evicted GPU mappings. */
if (vm_bo->evicted)
continue;
if (vm_count++) {
*state = PANTHOR_GEM_GPU_MAPPED_MULTI_VM;
break;
}
*state = PANTHOR_GEM_GPU_MAPPED_SINGLE_VM;
}
return vm_count > 0;
}
in v6.
>
> > + *state = PANTHOR_GEM_GPU_MAPPED_SHARED;
> > + break;
> > + }
> > + }
> > +
> > + return !!vm;
> > +}
> > +
[...]
> > +int panthor_gem_swapin_locked(struct panthor_gem_object *bo)
> > +{
> > + struct sg_table *sgt;
> > + int ret;
> > +
> > + dma_resv_assert_held(bo->base.resv);
> > +
> > + if (drm_WARN_ON_ONCE(bo->base.dev, drm_gem_is_imported(&bo->base)))
> > + return -EINVAL;
> > +
>
> Following call is redundant because it's already being done in panthor_gem_dev_map_get_sgt_locked().
Indeed, I'll drop this panthor_gem_backing_get_pages_locked().
>
> > + ret = panthor_gem_backing_get_pages_locked(bo);
> > + if (ret)
> > + return ret;
> > +
> > + sgt = panthor_gem_dev_map_get_sgt_locked(bo);
> > + if (IS_ERR(sgt))
> > + return PTR_ERR(sgt);
> > +
> > + return 0;
> > +}
prev parent reply other threads:[~2026-03-25 8:10 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-03-09 15:11 [PATCH v5 0/9] drm/panthor: Add a GEM shrinker Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 1/9] drm/gem: Consider GEM object reclaimable if shrinking fails Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 2/9] drm/panthor: Move panthor_gems_debugfs_init() to panthor_gem.c Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 3/9] drm/panthor: Group panthor_kernel_bo_xxx() helpers Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 4/9] drm/panthor: Don't call drm_gpuvm_bo_extobj_add() if the object is private Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 5/9] drm/panthor: Part ways with drm_gem_shmem_object Boris Brezillon
2026-03-09 15:34 ` Steven Price
2026-03-12 13:59 ` Liviu Dudau
2026-03-25 0:24 ` Adrián Larumbe
2026-03-25 7:59 ` Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 6/9] drm/panthor: Lazily allocate pages on mmap() Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 7/9] drm/panthor: Split panthor_vm_prepare_map_op_ctx() to prepare for reclaim Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 8/9] drm/panthor: Track the number of mmap on a BO Boris Brezillon
2026-03-09 15:11 ` [PATCH v5 9/9] drm/panthor: Add a GEM shrinker Boris Brezillon
2026-03-24 23:52 ` Adrián Larumbe
2026-03-25 8:13 ` Boris Brezillon
2026-03-25 0:14 ` Adrián Larumbe
2026-03-25 8:10 ` Boris Brezillon [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=20260325091031.36ea296c@fedora \
--to=boris.brezillon@collabora.com \
--cc=adrian.larumbe@collabora.com \
--cc=airlied@gmail.com \
--cc=akash.goel@arm.com \
--cc=akhilpo@oss.qualcomm.com \
--cc=aliceryhl@google.com \
--cc=chris.diamand@arm.com \
--cc=dakr@kernel.org \
--cc=dmitry.osipenko@collabora.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=kernel@collabora.com \
--cc=konradybcio@kernel.org \
--cc=liviu.dudau@arm.com \
--cc=maarten.lankhorst@linux.intel.com \
--cc=matthew.brost@intel.com \
--cc=mripard@kernel.org \
--cc=olvaffe@gmail.com \
--cc=robin.clark@oss.qualcomm.com \
--cc=sean@poorly.run \
--cc=simona@ffwll.ch \
--cc=steven.price@arm.com \
--cc=thomas.hellstrom@linux.intel.com \
--cc=tzimmermann@suse.de \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.