From: Jani Nikula <jani.nikula@linux.intel.com>
To: Yunxiang Li <Yunxiang.Li@amd.com>,
amd-gfx@lists.freedesktop.org, christian.koenig@amd.com,
tvrtko.ursulin@igalia.com
Cc: Alexander.Deucher@amd.com, Yunxiang Li <Yunxiang.Li@amd.com>,
dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org
Subject: Re: [PATCH v7 2/4] drm: make drm-active- stats optional
Date: Mon, 11 Nov 2024 11:14:43 +0200 [thread overview]
Message-ID: <87ttcecet8.fsf@intel.com> (raw)
In-Reply-To: <20241110154152.592-3-Yunxiang.Li@amd.com>
On Sun, 10 Nov 2024, Yunxiang Li <Yunxiang.Li@amd.com> wrote:
> Make drm-active- optional just like drm-resident- and drm-purgeable-.
Why? What does it mean?
This is what the commit message should answer.
>
> Signed-off-by: Yunxiang Li <Yunxiang.Li@amd.com>
> CC: dri-devel@lists.freedesktop.org
> CC: intel-gfx@lists.freedesktop.org
> CC: amd-gfx@lists.freedesktop.org
> ---
> drivers/gpu/drm/amd/amdgpu/amdgpu_fdinfo.c | 1 +
> drivers/gpu/drm/drm_file.c | 13 +++++++------
> drivers/gpu/drm/i915/i915_drm_client.c | 1 +
> drivers/gpu/drm/xe/xe_drm_client.c | 1 +
> include/drm/drm_gem.h | 14 ++++++++------
> 5 files changed, 18 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_fdinfo.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_fdinfo.c
> index df2cf5c339255..7717e3e4f05b5 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_fdinfo.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_fdinfo.c
> @@ -97,6 +97,7 @@ void amdgpu_show_fdinfo(struct drm_printer *p, struct drm_file *file)
>
> drm_print_memory_stats(p,
> &stats[i].drm,
> + DRM_GEM_OBJECT_ACTIVE |
> DRM_GEM_OBJECT_RESIDENT |
> DRM_GEM_OBJECT_PURGEABLE,
> pl_name[i]);
> diff --git a/drivers/gpu/drm/drm_file.c b/drivers/gpu/drm/drm_file.c
> index e285fcc28c59c..fd06671054723 100644
> --- a/drivers/gpu/drm/drm_file.c
> +++ b/drivers/gpu/drm/drm_file.c
> @@ -884,7 +884,9 @@ void drm_print_memory_stats(struct drm_printer *p,
> {
> print_size(p, "total", region, stats->private + stats->shared);
> print_size(p, "shared", region, stats->shared);
> - print_size(p, "active", region, stats->active);
> +
> + if (supported_status & DRM_GEM_OBJECT_ACTIVE)
> + print_size(p, "active", region, stats->active);
>
> if (supported_status & DRM_GEM_OBJECT_RESIDENT)
> print_size(p, "resident", region, stats->resident);
> @@ -917,15 +919,13 @@ void drm_show_memory_stats(struct drm_printer *p, struct drm_file *file)
>
> if (obj->funcs && obj->funcs->status) {
> s = obj->funcs->status(obj);
> - supported_status = DRM_GEM_OBJECT_RESIDENT |
> - DRM_GEM_OBJECT_PURGEABLE;
> + supported_status |= s;
> }
>
> - if (drm_gem_object_is_shared_for_memory_stats(obj)) {
> + if (drm_gem_object_is_shared_for_memory_stats(obj))
> status.shared += obj->size;
> - } else {
> + else
> status.private += obj->size;
> - }
>
> if (s & DRM_GEM_OBJECT_RESIDENT) {
> status.resident += add_size;
> @@ -938,6 +938,7 @@ void drm_show_memory_stats(struct drm_printer *p, struct drm_file *file)
>
> if (!dma_resv_test_signaled(obj->resv, dma_resv_usage_rw(true))) {
> status.active += add_size;
> + supported_status |= DRM_GEM_OBJECT_ACTIVE;
>
> /* If still active, don't count as purgeable: */
> s &= ~DRM_GEM_OBJECT_PURGEABLE;
> diff --git a/drivers/gpu/drm/i915/i915_drm_client.c b/drivers/gpu/drm/i915/i915_drm_client.c
> index f586825054918..168d7375304bc 100644
> --- a/drivers/gpu/drm/i915/i915_drm_client.c
> +++ b/drivers/gpu/drm/i915/i915_drm_client.c
> @@ -102,6 +102,7 @@ static void show_meminfo(struct drm_printer *p, struct drm_file *file)
> for_each_memory_region(mr, i915, id)
> drm_print_memory_stats(p,
> &stats[id],
> + DRM_GEM_OBJECT_ACTIVE |
> DRM_GEM_OBJECT_RESIDENT |
> DRM_GEM_OBJECT_PURGEABLE,
> mr->uabi_name);
> diff --git a/drivers/gpu/drm/xe/xe_drm_client.c b/drivers/gpu/drm/xe/xe_drm_client.c
> index 6a26923fa10e0..54941b4e850c4 100644
> --- a/drivers/gpu/drm/xe/xe_drm_client.c
> +++ b/drivers/gpu/drm/xe/xe_drm_client.c
> @@ -229,6 +229,7 @@ static void show_meminfo(struct drm_printer *p, struct drm_file *file)
> if (man) {
> drm_print_memory_stats(p,
> &stats[mem_type],
> + DRM_GEM_OBJECT_ACTIVE |
> DRM_GEM_OBJECT_RESIDENT |
> (mem_type != XE_PL_SYSTEM ? 0 :
> DRM_GEM_OBJECT_PURGEABLE),
> diff --git a/include/drm/drm_gem.h b/include/drm/drm_gem.h
> index bae4865b2101a..584ffdf5c2542 100644
> --- a/include/drm/drm_gem.h
> +++ b/include/drm/drm_gem.h
> @@ -48,19 +48,21 @@ struct drm_gem_object;
> * enum drm_gem_object_status - bitmask of object state for fdinfo reporting
> * @DRM_GEM_OBJECT_RESIDENT: object is resident in memory (ie. not unpinned)
> * @DRM_GEM_OBJECT_PURGEABLE: object marked as purgeable by userspace
> + * @DRM_GEM_OBJECT_ACTIVE: object is currently used by an active submission
> *
> * Bitmask of status used for fdinfo memory stats, see &drm_gem_object_funcs.status
> - * and drm_show_fdinfo(). Note that an object can DRM_GEM_OBJECT_PURGEABLE if
> - * it still active or not resident, in which case drm_show_fdinfo() will not
> + * and drm_show_fdinfo(). Note that an object can report DRM_GEM_OBJECT_PURGEABLE
> + * and be active or not resident, in which case drm_show_fdinfo() will not
> * account for it as purgeable. So drivers do not need to check if the buffer
> - * is idle and resident to return this bit. (Ie. userspace can mark a buffer
> - * as purgeable even while it is still busy on the GPU.. it does not _actually_
> - * become puregeable until it becomes idle. The status gem object func does
> - * not need to consider this.)
> + * is idle and resident to return this bit, i.e. userspace can mark a buffer as
> + * purgeable even while it is still busy on the GPU. It whill not get reported
> + * in the puregeable stats until it becomes idle. The status gem object func
> + * does not need to consider this.
> */
> enum drm_gem_object_status {
> DRM_GEM_OBJECT_RESIDENT = BIT(0),
> DRM_GEM_OBJECT_PURGEABLE = BIT(1),
> + DRM_GEM_OBJECT_ACTIVE = BIT(2),
> };
>
> /**
--
Jani Nikula, Intel
next prev parent reply other threads:[~2024-11-11 9:14 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-11-10 15:41 [PATCH v7 0/4] rework bo mem stats tracking Yunxiang Li
2024-11-10 15:41 ` [PATCH v7 1/4] drm: add drm_memory_stats_is_zero Yunxiang Li
2024-11-10 15:41 ` [PATCH v7 2/4] drm: make drm-active- stats optional Yunxiang Li
2024-11-11 9:14 ` Jani Nikula [this message]
2024-11-11 14:28 ` [PATCH v8 " Yunxiang Li
2024-11-11 10:29 ` [PATCH v7 " Tvrtko Ursulin
2024-11-18 15:17 ` Li, Yunxiang (Teddy)
2024-11-18 15:42 ` Tvrtko Ursulin
2024-11-10 15:41 ` [PATCH v7 3/4] drm/amdgpu: remove unused function parameter Yunxiang Li
2024-11-10 15:41 ` [PATCH v7 4/4] drm/amdgpu: track bo memory stats at runtime Yunxiang Li
2024-11-12 10:54 ` Christian König
2024-11-12 18:16 ` Li, Yunxiang (Teddy)
2024-11-13 8:49 ` Christian König
2024-11-13 10:25 ` Tvrtko Ursulin
2024-11-13 11:38 ` Christian König
2024-11-13 13:53 ` Li, Yunxiang (Teddy)
2024-11-13 14:22 ` Christian König
2024-11-13 17:01 ` Li, Yunxiang (Teddy)
2024-11-13 17:30 ` Tvrtko Ursulin
2024-11-14 9:06 ` Matthew Auld
2024-11-14 15:52 ` Li, Yunxiang (Teddy)
2024-11-13 14:09 ` Li, Yunxiang (Teddy)
2024-11-13 14:19 ` Christian König
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=87ttcecet8.fsf@intel.com \
--to=jani.nikula@linux.intel.com \
--cc=Alexander.Deucher@amd.com \
--cc=Yunxiang.Li@amd.com \
--cc=amd-gfx@lists.freedesktop.org \
--cc=christian.koenig@amd.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=intel-gfx@lists.freedesktop.org \
--cc=tvrtko.ursulin@igalia.com \
/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.