All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Danilo Krummrich" <dakr@kernel.org>
To: "Boris Brezillon" <boris.brezillon@collabora.com>
Cc: "Steven Price" <steven.price@arm.com>,
	"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>,
	"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 v1 2/9] drm/gpuvm: Validate BOs in the extobj list when VM is resv protected
Date: Fri, 09 Jan 2026 20:38:37 +0100	[thread overview]
Message-ID: <DFKB9OUFLT3A.2TJ21YPFZPATD@kernel.org> (raw)
In-Reply-To: <20260109130801.1239558-3-boris.brezillon@collabora.com>

On Fri Jan 9, 2026 at 2:07 PM CET, Boris Brezillon wrote:
> When the VM is protected with the root object resv, evicted extobjs
> are not inserted in the evict list.

I'd rather say: "When the evicted object list is protected with the root object
reservation lock, ...".

> Make sure we record when the extobj
> list contains evicted BOs that are not already in the evict list so we
> can validate those when drm_gpuvm_validate() is called.

Why is this necessary in the first place? drm_gpuvm_prepare_objects() picks up
the affected external objects already.

> Signed-off-by: Boris Brezillon <boris.brezillon@collabora.com>
> ---
>  drivers/gpu/drm/drm_gpuvm.c | 23 ++++++++++++++++++++++-
>  include/drm/drm_gpuvm.h     |  6 ++++++
>  2 files changed, 28 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/gpu/drm/drm_gpuvm.c b/drivers/gpu/drm/drm_gpuvm.c
> index 0bb115b6b59c..95f0a1c843ad 100644
> --- a/drivers/gpu/drm/drm_gpuvm.c
> +++ b/drivers/gpu/drm/drm_gpuvm.c
> @@ -1505,6 +1505,22 @@ drm_gpuvm_validate_locked(struct drm_gpuvm *gpuvm, struct drm_exec *exec)
>  			drm_gpuvm_bo_list_del_init(vm_bo, evict, false);
>  	}
>  
> +	if (READ_ONCE(gpuvm->extobj.check_evicted)) {
> +		list_for_each_entry_safe(vm_bo, next, &gpuvm->extobj.list,
> +					 list.entry.extobj) {

Running the external object list (again) seems wasteful given that this case can
never happen when drm_gpuvm_prepare_objects() is called before (which has to be
the case, given that somehow the objects have to be locked).

And even if for some reason you open code this, it would be much better to add a
helper doing the check when the object is locked.

> +			dma_resv_assert_held(vm_bo->obj->resv);
> +
> +			if (!vm_bo->evicted)
> +				continue;
> +
> +			ret = ops->vm_bo_validate(vm_bo, exec);
> +			if (ret)
> +				break;
> +		}
> +
> +		WRITE_ONCE(gpuvm->extobj.check_evicted, false);

Why do we need READ_ONCE() and WRITE_ONCE() here? Don't we hold the object's
reservation lock whenever we touch check_evicted anyways?


  reply	other threads:[~2026-01-09 19:38 UTC|newest]

Thread overview: 62+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-01-09 13:07 [PATCH v1 0/9] drm/panthor: Add a GEM shrinker Boris Brezillon
2026-01-09 13:07 ` [PATCH v1 1/9] drm/gem: Consider GEM object reclaimable if shrinking fails Boris Brezillon
2026-01-12  9:25   ` Alice Ryhl
2026-01-12 10:02     ` Boris Brezillon
2026-01-15 13:28   ` Liviu Dudau
2026-01-09 13:07 ` [PATCH v1 2/9] drm/gpuvm: Validate BOs in the extobj list when VM is resv protected Boris Brezillon
2026-01-09 19:38   ` Danilo Krummrich [this message]
2026-01-12  7:30     ` Boris Brezillon
2026-01-09 13:07 ` [PATCH v1 3/9] drm/panthor: Move panthor_gems_debugfs_init() to panthor_gem.c Boris Brezillon
2026-01-12 11:27   ` Steven Price
2026-01-15 13:39   ` Liviu Dudau
2026-01-09 13:07 ` [PATCH v1 4/9] drm/panthor: Group panthor_kernel_bo_xxx() helpers Boris Brezillon
2026-01-12 11:29   ` Steven Price
2026-01-15 13:41   ` Liviu Dudau
2026-01-09 13:07 ` [PATCH v1 5/9] drm/panthor: Part ways with drm_gem_shmem_object Boris Brezillon
2026-01-12 12:06   ` Steven Price
2026-01-12 14:17     ` Boris Brezillon
2026-01-12 16:03       ` Steven Price
2026-01-12 16:45         ` Boris Brezillon
2026-01-21 11:11       ` Akash Goel
2026-01-21 15:17         ` Boris Brezillon
2026-01-15 16:51   ` Liviu Dudau
2026-01-15 17:27     ` Boris Brezillon
2026-01-15 17:45       ` Liviu Dudau
2026-01-16 12:09         ` Steven Price
2026-01-09 13:07 ` [PATCH v1 6/9] drm/panthor: Lazily allocate pages on mmap() Boris Brezillon
2026-01-12 12:15   ` Steven Price
2026-01-12 14:32     ` Boris Brezillon
2026-01-12 16:41       ` Steven Price
2026-01-12 16:50         ` Boris Brezillon
2026-01-15 17:34   ` Liviu Dudau
2026-01-15 19:27     ` Boris Brezillon
2026-01-16  8:19   ` kernel test robot
2026-01-09 13:07 ` [PATCH v1 7/9] drm/panthor: Split panthor_vm_prepare_map_op_ctx() to prepare for reclaim Boris Brezillon
2026-01-12 12:21   ` Steven Price
2026-01-15 17:40   ` Liviu Dudau
2026-01-09 13:08 ` [PATCH v1 8/9] drm/panthor: Track the number of mmap on a BO Boris Brezillon
2026-01-12 12:33   ` Steven Price
2026-01-12 14:39     ` Boris Brezillon
2026-01-12 15:19       ` Alice Ryhl
2026-01-12 15:49         ` Boris Brezillon
2026-01-12 15:51           ` Alice Ryhl
2026-01-12 16:06             ` Boris Brezillon
2026-01-12 16:49       ` Steven Price
2026-01-12 16:59         ` Boris Brezillon
2026-01-12 17:10           ` Steven Price
2026-01-12 17:18             ` Boris Brezillon
2026-01-13 12:26             ` Boris Brezillon
2026-01-09 13:08 ` [PATCH v1 9/9] drm/panthor: Add a GEM shrinker Boris Brezillon
2026-01-14 15:05   ` Steven Price
2026-01-15 10:50     ` Boris Brezillon
2026-01-15 11:24       ` Steven Price
2026-01-15 12:01         ` Boris Brezillon
2026-01-15 13:56   ` Akash Goel
2026-01-15 14:36     ` Boris Brezillon
2026-01-15 14:37     ` Boris Brezillon
2026-01-21 11:49   ` Akash Goel
2026-01-21 14:52     ` Boris Brezillon
2026-01-28 11:21       ` Akash Goel
2026-01-28 15:52         ` Boris Brezillon
2026-01-28 16:26           ` Akash Goel
2026-01-12  8:37 ` [PATCH v1 0/9] " 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=DFKB9OUFLT3A.2TJ21YPFZPATD@kernel.org \
    --to=dakr@kernel.org \
    --cc=adrian.larumbe@collabora.com \
    --cc=airlied@gmail.com \
    --cc=akash.goel@arm.com \
    --cc=akhilpo@oss.qualcomm.com \
    --cc=aliceryhl@google.com \
    --cc=boris.brezillon@collabora.com \
    --cc=chris.diamand@arm.com \
    --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.