Commit c8a76df6 authored by John Harrison's avatar John Harrison

drm/i915: Include timeline seqno in error capture

The seqno value actually written out to memory is no longer in the
regular HWSP. Instead, it is now in its own private timeline buffer.
Thus, it is no longer visible in an error capture. So, explicitly read
the value and include that in the capture.

v2: %d -> %u (Alan)
Signed-off-by: default avatarJohn Harrison <John.C.Harrison@Intel.com>
Reviewed-by: default avatarAlan Previn <alan.previn.teres.alexis@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230311063714.570389-4-John.C.Harrison@Intel.com
parent 53c4e64c
...@@ -505,6 +505,7 @@ static void error_print_context(struct drm_i915_error_state_buf *m, ...@@ -505,6 +505,7 @@ static void error_print_context(struct drm_i915_error_state_buf *m,
header, ctx->comm, ctx->pid, ctx->sched_attr.priority, header, ctx->comm, ctx->pid, ctx->sched_attr.priority,
ctx->guilty, ctx->active, ctx->guilty, ctx->active,
ctx->total_runtime, ctx->avg_runtime); ctx->total_runtime, ctx->avg_runtime);
err_printf(m, " context timeline seqno %u\n", ctx->hwsp_seqno);
} }
static struct i915_vma_coredump * static struct i915_vma_coredump *
...@@ -1395,6 +1396,8 @@ static bool record_context(struct i915_gem_context_coredump *e, ...@@ -1395,6 +1396,8 @@ static bool record_context(struct i915_gem_context_coredump *e,
e->sched_attr = ctx->sched; e->sched_attr = ctx->sched;
e->guilty = atomic_read(&ctx->guilty_count); e->guilty = atomic_read(&ctx->guilty_count);
e->active = atomic_read(&ctx->active_count); e->active = atomic_read(&ctx->active_count);
e->hwsp_seqno = (ce->timeline && ce->timeline->hwsp_seqno) ?
*ce->timeline->hwsp_seqno : ~0U;
e->total_runtime = intel_context_get_total_runtime_ns(ce); e->total_runtime = intel_context_get_total_runtime_ns(ce);
e->avg_runtime = intel_context_get_avg_runtime_ns(ce); e->avg_runtime = intel_context_get_avg_runtime_ns(ce);
......
...@@ -107,6 +107,7 @@ struct intel_engine_coredump { ...@@ -107,6 +107,7 @@ struct intel_engine_coredump {
int active; int active;
int guilty; int guilty;
struct i915_sched_attr sched_attr; struct i915_sched_attr sched_attr;
u32 hwsp_seqno;
} context; } context;
struct i915_vma_coredump *vma; struct i915_vma_coredump *vma;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment