From: Boris Brezillon <boris.brezillon@collabora.com>
To: Steven Price <steven.price@arm.com>
Cc: "Liviu Dudau" <liviu.dudau@arm.com>,
"Adrián Larumbe" <adrian.larumbe@collabora.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>,
kernel@collabora.com
Subject: Re: [PATCH v3 8/9] drm/panthor: Track the number of mmap on a BO
Date: Thu, 12 Feb 2026 12:08:00 +0100 [thread overview]
Message-ID: <20260212120800.25a45426@fedora> (raw)
In-Reply-To: <7247f751-ff4b-47fe-a156-d289c288f433@arm.com>
On Wed, 11 Feb 2026 16:08:23 +0000
Steven Price <steven.price@arm.com> wrote:
> On 11/02/2026 08:03, Boris Brezillon wrote:
> > This will be used to order things by reclaimability.
> >
> > v2:
> > - Fix refcounting
> >
> > v3:
> > - Fix refcounting (again)
> >
> > Signed-off-by: Boris Brezillon <boris.brezillon@collabora.com>
>
> I think we've got the refcounting correct this time, one minor comment
> below but either way:
>
> Reviewed-by: Steven Price <steven.price@arm.com>
>
> > ---
> > drivers/gpu/drm/panthor/panthor_gem.c | 45 +++++++++++++++++++++++++--
> > drivers/gpu/drm/panthor/panthor_gem.h | 3 ++
> > 2 files changed, 46 insertions(+), 2 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/panthor/panthor_gem.c b/drivers/gpu/drm/panthor/panthor_gem.c
> > index 8905042b856c..e46bfc4f2063 100644
> > --- a/drivers/gpu/drm/panthor/panthor_gem.c
> > +++ b/drivers/gpu/drm/panthor/panthor_gem.c
> > @@ -491,6 +491,7 @@ static void panthor_gem_print_info(struct drm_printer *p, unsigned int indent,
> > drm_printf_indent(p, indent, "vmap_use_count=%u\n",
> > refcount_read(&bo->cmap.vaddr_use_count));
> > drm_printf_indent(p, indent, "vaddr=%p\n", bo->cmap.vaddr);
> > + drm_printf_indent(p, indent, "mmap_count=%u\n", refcount_read(&bo->cmap.mmap_count));
> > }
> >
> > static int panthor_gem_pin_locked(struct drm_gem_object *obj)
> > @@ -606,6 +607,13 @@ static int panthor_gem_mmap(struct drm_gem_object *obj, struct vm_area_struct *v
> > if (is_cow_mapping(vma->vm_flags))
> > return -EINVAL;
> >
> > + if (!refcount_inc_not_zero(&bo->cmap.mmap_count)) {
> > + dma_resv_lock(obj->resv, NULL);
> > + if (!refcount_inc_not_zero(&bo->cmap.mmap_count))
> > + refcount_set(&bo->cmap.mmap_count, 1);
>
> It could make sense to put a call to
> panthor_gem_update_reclaim_state_locked() in here as we could transition
> from UNUSED to MMAPPED. Things should work out due to the call in
> panthor_gem_try_evict(), but the shrinker will have to work harder.
Sure, I'll add that to the next commit.
>
> Thanks,
> Steve
>
> > + dma_resv_unlock(obj->resv);
> > + }
> > +
> > vm_flags_set(vma, VM_PFNMAP | VM_DONTEXPAND | VM_DONTDUMP);
> > vma->vm_page_prot = vm_get_page_prot(vma->vm_flags);
> > if (should_map_wc(bo))
> > @@ -732,10 +740,43 @@ static vm_fault_t panthor_gem_fault(struct vm_fault *vmf)
> > return blocking_page_setup(vmf, bo, page_offset, true);
> > }
> >
> > +static void panthor_gem_vm_open(struct vm_area_struct *vma)
> > +{
> > + struct panthor_gem_object *bo = to_panthor_bo(vma->vm_private_data);
> > +
> > + /* mmap_count must have been incremented at mmap time, so it can't be
> > + * zero here.
> > + */
> > + if (!drm_gem_is_imported(&bo->base))
> > + drm_WARN_ON(bo->base.dev, !refcount_inc_not_zero(&bo->cmap.mmap_count));
> > +
> > + drm_gem_vm_open(vma);
> > +}
> > +
> > +static void panthor_gem_vm_close(struct vm_area_struct *vma)
> > +{
> > + struct panthor_gem_object *bo = to_panthor_bo(vma->vm_private_data);
> > +
> > + if (drm_gem_is_imported(&bo->base))
> > + goto out;
> > +
> > + if (refcount_dec_not_one(&bo->cmap.mmap_count))
> > + goto out;
> > +
> > + dma_resv_lock(bo->base.resv, NULL);
> > + if (refcount_dec_and_test(&bo->cmap.mmap_count)) {
> > + /* Nothing to do, pages are reclaimed lazily. */
> > + }
> > + dma_resv_unlock(bo->base.resv);
> > +
> > +out:
> > + drm_gem_object_put(&bo->base);
> > +}
> > +
> > const struct vm_operations_struct panthor_gem_vm_ops = {
> > .fault = panthor_gem_fault,
> > - .open = drm_gem_vm_open,
> > - .close = drm_gem_vm_close,
> > + .open = panthor_gem_vm_open,
> > + .close = panthor_gem_vm_close,
> > };
> >
> > static const struct drm_gem_object_funcs panthor_gem_funcs = {
> > diff --git a/drivers/gpu/drm/panthor/panthor_gem.h b/drivers/gpu/drm/panthor/panthor_gem.h
> > index b66478c9590c..c0a18dca732c 100644
> > --- a/drivers/gpu/drm/panthor/panthor_gem.h
> > +++ b/drivers/gpu/drm/panthor/panthor_gem.h
> > @@ -80,6 +80,9 @@ struct panthor_gem_cpu_map {
> >
> > /** @vaddr_use_count: Number of active vmap() requests on this GEM */
> > refcount_t vaddr_use_count;
> > +
> > + /** @mmap_count: Number of active mmap() requests on this GEM */
> > + refcount_t mmap_count;
> > };
> >
> > /**
>
next prev parent reply other threads:[~2026-02-12 11:08 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-11 8:03 [PATCH v3 0/9] drm/panthor: Add a GEM shrinker Boris Brezillon
2026-02-11 8:03 ` [PATCH v3 1/9] drm/gem: Consider GEM object reclaimable if shrinking fails Boris Brezillon
2026-02-11 8:03 ` [PATCH v3 2/9] drm/panthor: Move panthor_gems_debugfs_init() to panthor_gem.c Boris Brezillon
2026-02-11 8:03 ` [PATCH v3 3/9] drm/panthor: Group panthor_kernel_bo_xxx() helpers Boris Brezillon
2026-02-11 8:03 ` [PATCH v3 4/9] drm/panthor: Don't call drm_gpuvm_bo_extobj_add() if the object is private Boris Brezillon
2026-02-11 15:57 ` Steven Price
2026-02-12 11:04 ` Liviu Dudau
2026-02-11 8:03 ` [PATCH v3 5/9] drm/panthor: Part ways with drm_gem_shmem_object Boris Brezillon
2026-02-11 15:58 ` Steven Price
2026-02-12 11:07 ` Boris Brezillon
2026-02-12 14:20 ` Liviu Dudau
2026-02-12 19:46 ` Chia-I Wu
2026-02-13 18:01 ` Adrián Larumbe
2026-02-16 9:06 ` Boris Brezillon
2026-02-11 8:03 ` [PATCH v3 6/9] drm/panthor: Lazily allocate pages on mmap() Boris Brezillon
2026-02-11 8:03 ` [PATCH v3 7/9] drm/panthor: Split panthor_vm_prepare_map_op_ctx() to prepare for reclaim Boris Brezillon
2026-02-11 8:03 ` [PATCH v3 8/9] drm/panthor: Track the number of mmap on a BO Boris Brezillon
2026-02-11 16:08 ` Steven Price
2026-02-12 11:08 ` Boris Brezillon [this message]
2026-02-12 17:16 ` Liviu Dudau
2026-02-11 8:03 ` [PATCH v3 9/9] drm/panthor: Add a GEM shrinker Boris Brezillon
2026-02-13 0:43 ` Chia-I Wu
2026-02-13 9:12 ` Boris Brezillon
2026-02-16 8:50 ` Boris Brezillon
2026-02-13 1:19 ` Chia-I Wu
2026-02-16 8:51 ` Boris Brezillon
2026-02-13 18:23 ` Adrián Larumbe
2026-02-16 8:57 ` Boris Brezillon
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=20260212120800.25a45426@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=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.