From: Matthew Brost <matthew.brost@intel.com>
To: Rodrigo Vivi <rodrigo.vivi@intel.com>
Cc: intel-xe@lists.freedesktop.org, dri-devel@lists.freedesktop.org
Subject: Re: [Intel-xe] [PATCH 06/14] drm/xe: Add GuC CT snapshot to xe_devcoredump.
Date: Tue, 2 May 2023 14:55:18 +0000 [thread overview]
Message-ID: <ZFEkVsRkpnUVUGoQ@DUT025-TGLU.fm.intel.com> (raw)
In-Reply-To: <20230426205713.512695-7-rodrigo.vivi@intel.com>
On Wed, Apr 26, 2023 at 04:57:05PM -0400, Rodrigo Vivi wrote:
> Let's start to move our existent logs to devcoredump one by
> one. Any format change should come on follow-up work.
>
> Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Reviewed-by: Matthew Brost <matthew.brost@intel.com>
> ---
> drivers/gpu/drm/xe/xe_devcoredump.c | 14 ++++++++++++++
> drivers/gpu/drm/xe/xe_devcoredump_types.h | 4 ++++
> 2 files changed, 18 insertions(+)
>
> diff --git a/drivers/gpu/drm/xe/xe_devcoredump.c b/drivers/gpu/drm/xe/xe_devcoredump.c
> index a08929c01b75..795581c58d90 100644
> --- a/drivers/gpu/drm/xe/xe_devcoredump.c
> +++ b/drivers/gpu/drm/xe/xe_devcoredump.c
> @@ -11,6 +11,7 @@
>
> #include "xe_engine.h"
> #include "xe_gt.h"
> +#include "xe_guc_ct.h"
>
> /**
> * DOC: Xe device coredump
> @@ -47,6 +48,11 @@ static struct xe_device *coredump_to_xe(const struct xe_devcoredump *coredump)
> return container_of(coredump, struct xe_device, devcoredump);
> }
>
> +static struct xe_guc *engine_to_guc(struct xe_engine *e)
> +{
> + return &e->gt->uc.guc;
> +}
> +
> static ssize_t xe_devcoredump_read(char *buffer, loff_t offset,
> size_t count, void *data, size_t datalen)
> {
> @@ -81,6 +87,9 @@ static ssize_t xe_devcoredump_read(char *buffer, loff_t offset,
> ts = ktime_to_timespec64(ktime_sub(ss->snapshot_time, ss->boot_time));
> drm_printf(&p, "Uptime: %lld.%09ld\n", ts.tv_sec, ts.tv_nsec);
>
> + drm_printf(&p, "\n**** GuC CT ****\n");
> + xe_guc_ct_snapshot_print(coredump->snapshot.ct, &p);
> +
> mutex_unlock(&coredump->lock);
>
> return count - iter.remain;
> @@ -96,6 +105,8 @@ static void xe_devcoredump_free(void *data)
>
> mutex_lock(&coredump->lock);
>
> + xe_guc_ct_snapshot_free(coredump->snapshot.ct);
> +
> coredump->faulty_engine = NULL;
> drm_info(&coredump_to_xe(coredump)->drm,
> "Xe device coredump has been deleted.\n");
> @@ -106,10 +117,13 @@ static void xe_devcoredump_free(void *data)
> static void devcoredump_snapshot(struct xe_devcoredump *coredump)
> {
> struct xe_devcoredump_snapshot *ss = &coredump->snapshot;
> + struct xe_guc *guc = engine_to_guc(coredump->faulty_engine);
>
> lockdep_assert_held(&coredump->lock);
> ss->snapshot_time = ktime_get_real();
> ss->boot_time = ktime_get_boottime();
> +
> + coredump->snapshot.ct = xe_guc_ct_snapshot_capture(&guc->ct);
> }
>
> /**
> diff --git a/drivers/gpu/drm/xe/xe_devcoredump_types.h b/drivers/gpu/drm/xe/xe_devcoredump_types.h
> index 3f395fa9104e..1e44d5346364 100644
> --- a/drivers/gpu/drm/xe/xe_devcoredump_types.h
> +++ b/drivers/gpu/drm/xe/xe_devcoredump_types.h
> @@ -23,6 +23,10 @@ struct xe_devcoredump_snapshot {
> ktime_t snapshot_time;
> /** @boot_time: Relative boot time so the uptime can be calculated. */
> ktime_t boot_time;
> +
> + /* GuC snapshots */
> + /** @ct_snapshot: GuC CT snapshot */
> + struct xe_guc_ct_snapshot *ct;
> };
>
> /**
> --
> 2.39.2
>
WARNING: multiple messages have this Message-ID (diff)
From: Matthew Brost <matthew.brost@intel.com>
To: Rodrigo Vivi <rodrigo.vivi@intel.com>
Cc: intel-xe@lists.freedesktop.org, dri-devel@lists.freedesktop.org
Subject: Re: [PATCH 06/14] drm/xe: Add GuC CT snapshot to xe_devcoredump.
Date: Tue, 2 May 2023 14:55:18 +0000 [thread overview]
Message-ID: <ZFEkVsRkpnUVUGoQ@DUT025-TGLU.fm.intel.com> (raw)
In-Reply-To: <20230426205713.512695-7-rodrigo.vivi@intel.com>
On Wed, Apr 26, 2023 at 04:57:05PM -0400, Rodrigo Vivi wrote:
> Let's start to move our existent logs to devcoredump one by
> one. Any format change should come on follow-up work.
>
> Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Reviewed-by: Matthew Brost <matthew.brost@intel.com>
> ---
> drivers/gpu/drm/xe/xe_devcoredump.c | 14 ++++++++++++++
> drivers/gpu/drm/xe/xe_devcoredump_types.h | 4 ++++
> 2 files changed, 18 insertions(+)
>
> diff --git a/drivers/gpu/drm/xe/xe_devcoredump.c b/drivers/gpu/drm/xe/xe_devcoredump.c
> index a08929c01b75..795581c58d90 100644
> --- a/drivers/gpu/drm/xe/xe_devcoredump.c
> +++ b/drivers/gpu/drm/xe/xe_devcoredump.c
> @@ -11,6 +11,7 @@
>
> #include "xe_engine.h"
> #include "xe_gt.h"
> +#include "xe_guc_ct.h"
>
> /**
> * DOC: Xe device coredump
> @@ -47,6 +48,11 @@ static struct xe_device *coredump_to_xe(const struct xe_devcoredump *coredump)
> return container_of(coredump, struct xe_device, devcoredump);
> }
>
> +static struct xe_guc *engine_to_guc(struct xe_engine *e)
> +{
> + return &e->gt->uc.guc;
> +}
> +
> static ssize_t xe_devcoredump_read(char *buffer, loff_t offset,
> size_t count, void *data, size_t datalen)
> {
> @@ -81,6 +87,9 @@ static ssize_t xe_devcoredump_read(char *buffer, loff_t offset,
> ts = ktime_to_timespec64(ktime_sub(ss->snapshot_time, ss->boot_time));
> drm_printf(&p, "Uptime: %lld.%09ld\n", ts.tv_sec, ts.tv_nsec);
>
> + drm_printf(&p, "\n**** GuC CT ****\n");
> + xe_guc_ct_snapshot_print(coredump->snapshot.ct, &p);
> +
> mutex_unlock(&coredump->lock);
>
> return count - iter.remain;
> @@ -96,6 +105,8 @@ static void xe_devcoredump_free(void *data)
>
> mutex_lock(&coredump->lock);
>
> + xe_guc_ct_snapshot_free(coredump->snapshot.ct);
> +
> coredump->faulty_engine = NULL;
> drm_info(&coredump_to_xe(coredump)->drm,
> "Xe device coredump has been deleted.\n");
> @@ -106,10 +117,13 @@ static void xe_devcoredump_free(void *data)
> static void devcoredump_snapshot(struct xe_devcoredump *coredump)
> {
> struct xe_devcoredump_snapshot *ss = &coredump->snapshot;
> + struct xe_guc *guc = engine_to_guc(coredump->faulty_engine);
>
> lockdep_assert_held(&coredump->lock);
> ss->snapshot_time = ktime_get_real();
> ss->boot_time = ktime_get_boottime();
> +
> + coredump->snapshot.ct = xe_guc_ct_snapshot_capture(&guc->ct);
> }
>
> /**
> diff --git a/drivers/gpu/drm/xe/xe_devcoredump_types.h b/drivers/gpu/drm/xe/xe_devcoredump_types.h
> index 3f395fa9104e..1e44d5346364 100644
> --- a/drivers/gpu/drm/xe/xe_devcoredump_types.h
> +++ b/drivers/gpu/drm/xe/xe_devcoredump_types.h
> @@ -23,6 +23,10 @@ struct xe_devcoredump_snapshot {
> ktime_t snapshot_time;
> /** @boot_time: Relative boot time so the uptime can be calculated. */
> ktime_t boot_time;
> +
> + /* GuC snapshots */
> + /** @ct_snapshot: GuC CT snapshot */
> + struct xe_guc_ct_snapshot *ct;
> };
>
> /**
> --
> 2.39.2
>
next prev parent reply other threads:[~2023-05-02 14:55 UTC|newest]
Thread overview: 64+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-04-26 20:56 [Intel-xe] [PATCH 00/14] Introduce xe_devcoredump Rodrigo Vivi
2023-04-26 20:56 ` Rodrigo Vivi
2023-04-26 20:57 ` [Intel-xe] [PATCH 01/14] drm/xe: Fix print of RING_EXECLIST_SQ_CONTENTS_HI Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-04-26 21:40 ` [Intel-xe] " Lucas De Marchi
2023-04-26 21:59 ` Rodrigo Vivi
2023-04-26 20:57 ` [Intel-xe] [PATCH 02/14] drm/xe: Introduce the dev_coredump infrastructure Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-04-27 8:28 ` [Intel-xe] " Thomas Hellström
2023-05-02 7:57 ` Matthew Brost
2023-05-02 18:06 ` Rodrigo Vivi
2023-05-02 18:06 ` Rodrigo Vivi
2023-05-02 20:29 ` Matthew Brost
2023-05-02 20:29 ` Matthew Brost
2023-05-02 7:55 ` Jani Nikula
2023-05-02 17:25 ` Rodrigo Vivi
2023-04-26 20:57 ` [Intel-xe] [PATCH 03/14] drm/xe: Do not take any action if our device was removed Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 15:40 ` [Intel-xe] " Matthew Brost
2023-05-02 17:21 ` Rodrigo Vivi
2023-05-02 23:06 ` Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 04/14] drm/xe: Extract non mapped regions out of GuC CTB into its own struct Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 5:12 ` [Intel-xe] " Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 05/14] drm/xe: Convert GuC CT print to snapshot capture and print Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 5:27 ` [Intel-xe] " Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 06/14] drm/xe: Add GuC CT snapshot to xe_devcoredump Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 14:55 ` Matthew Brost [this message]
2023-05-02 14:55 ` Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 07/14] drm/xe: Introduce guc_submit_types.h with relevant structs Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 7:44 ` [Intel-xe] " Matthew Brost
2023-05-02 7:44 ` Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 08/14] drm/xe: Convert GuC Engine print to snapshot capture and print Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 15:01 ` [Intel-xe] " Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 09/14] drm/xe: Add GuC Submit Engine snapshot to xe_devcoredump Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 15:03 ` [Intel-xe] " Matthew Brost
2023-05-02 15:03 ` Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 10/14] drm/xe: Convert Xe HW Engine print to snapshot capture and print Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 15:20 ` [Intel-xe] " Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 11/14] drm/xe: Add HW Engine snapshot to xe_devcoredump Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 15:30 ` [Intel-xe] " Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 12/14] drm/xe: Limit CONFIG_DRM_XE_SIMPLE_ERROR_CAPTURE to itself Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 15:35 ` [Intel-xe] " Matthew Brost
2023-05-02 15:35 ` Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 13/14] drm/xe: Convert VM print to snapshot capture and print Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 7:50 ` [Intel-xe] " Matthew Brost
2023-05-02 8:07 ` Matthew Brost
2023-04-26 20:57 ` [Intel-xe] [PATCH 14/14] drm/xe: Add VM snapshot to xe_devcoredump Rodrigo Vivi
2023-04-26 20:57 ` Rodrigo Vivi
2023-05-02 15:38 ` [Intel-xe] " Matthew Brost
2023-04-26 21:01 ` [Intel-xe] ✓ CI.Patch_applied: success for Introduce xe_devcoredump Patchwork
2023-04-26 21:02 ` [Intel-xe] ✓ CI.KUnit: " Patchwork
2023-04-26 21:06 ` [Intel-xe] ✓ CI.Build: " Patchwork
2023-04-26 21:29 ` [Intel-xe] ○ CI.BAT: info " Patchwork
2023-05-02 8:11 ` [Intel-xe] [PATCH 00/14] " Matthew Brost
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=ZFEkVsRkpnUVUGoQ@DUT025-TGLU.fm.intel.com \
--to=matthew.brost@intel.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=intel-xe@lists.freedesktop.org \
--cc=rodrigo.vivi@intel.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.