From: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
To: "Dixit, Ashutosh" <ashutosh.dixit@intel.com>
Cc: intel-gfx@lists.freedesktop.org
Subject: Re: [Intel-gfx] [PATCH v2] drm/i915/perf: Do not parse context image for HSW
Date: Wed, 23 Nov 2022 12:17:49 -0800 [thread overview]
Message-ID: <Y35/7Qc530jik3FH@unerlige-ril> (raw)
In-Reply-To: <87sfiawdvz.wl-ashutosh.dixit@intel.com>
On Tue, Nov 22, 2022 at 07:25:36PM -0800, Dixit, Ashutosh wrote:
>On Tue, 22 Nov 2022 18:07:00 -0800, Umesh Nerlige Ramappa wrote:
>>
>
>Hi Umesh,
>
>> An earlier commit introduced a mechanism to parse the context image to
>> find the OA context control offset. This resulted in an NPD on haswell
>> when gem_context was passed into i915_perf_open_ioctl params. Haswell
>> does not support logical ring contexts, so ensure that the context image
>> is parsed only for platforms with logical ring contexts and also
>> validate lrc_reg_state.
>>
>> v2: Fix build failure
>>
>> Closes: https://gitlab.freedesktop.org/drm/intel/-/issues/7432
>> Fixes: a5c3a3cbf029 ("drm/i915/perf: Determine gen12 oa ctx offset at runtime")
>> Signed-off-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
>> ---
>> drivers/gpu/drm/i915/i915_perf.c | 6 +++++-
>> 1 file changed, 5 insertions(+), 1 deletion(-)
>>
>> diff --git a/drivers/gpu/drm/i915/i915_perf.c b/drivers/gpu/drm/i915/i915_perf.c
>> index 00e09bb18b13..dbd785974f20 100644
>> --- a/drivers/gpu/drm/i915/i915_perf.c
>> +++ b/drivers/gpu/drm/i915/i915_perf.c
>> @@ -1383,6 +1383,9 @@ static u32 oa_context_image_offset(struct intel_context *ce, u32 reg)
>> u32 offset, len = (ce->engine->context_size - PAGE_SIZE) / 4;
>> u32 *state = ce->lrc_reg_state;
>>
>> + if (drm_WARN_ON(&ce->engine->i915->drm, state == NULL))
>> + return U32_MAX;
>> +
>
>So if we didn't add the HAS_LOGICAL_RING_CONTEXTS check below state would
>be NULL correct? I couldn't figure out how it is NULL on HSW looking at the
>code (with the context image pin/unpin).
Ref: intel_engines_init()
Haswell is using ring submission. While it does have a context image or
ce->state, there is no lrc state offset here. I think lrc is an execlist
concept (used only for execlist and guc submission).
>> /*
>> @@ -1447,7 +1450,8 @@ static int oa_get_render_ctx_id(struct i915_perf_stream *stream)
>> if (IS_ERR(ce))
>> return PTR_ERR(ce);
>>
>> - if (engine_supports_mi_query(stream->engine)) {
>> + if (engine_supports_mi_query(stream->engine) &&
>> + HAS_LOGICAL_RING_CONTEXTS(stream->perf->i915)) {
>
>This check looks fine since we seem to be looking inside ce->lrc_reg_state
>for oactxctrl.
The earlier code also does not define perf->ctx_oactxctrl_offset for
haswell. Ref: i915_perf_init().
>
>Overall looks fine so this is:
>
>Reviewed-by: Ashutosh Dixit <ashutosh.dixit@intel.com>
Thanks,
Umesh
>
>
>> /*
>> * We are enabling perf query here. If we don't find the context
>> * offset here, just return an error.
>> --
>> 2.36.1
>>
next prev parent reply other threads:[~2022-11-23 20:18 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-11-23 2:07 [Intel-gfx] [PATCH v2] drm/i915/perf: Do not parse context image for HSW Umesh Nerlige Ramappa
2022-11-23 2:48 ` [Intel-gfx] ✗ Fi.CI.CHECKPATCH: warning for drm/i915/perf: Do not parse context image for HSW (rev2) Patchwork
2022-11-23 2:48 ` [Intel-gfx] ✗ Fi.CI.DOCS: " Patchwork
2022-11-23 3:14 ` [Intel-gfx] ✓ Fi.CI.BAT: success " Patchwork
2022-11-23 3:25 ` [Intel-gfx] [PATCH v2] drm/i915/perf: Do not parse context image for HSW Dixit, Ashutosh
2022-11-23 20:17 ` Umesh Nerlige Ramappa [this message]
2022-11-23 19:22 ` [Intel-gfx] ✗ Fi.CI.IGT: failure for drm/i915/perf: Do not parse context image for HSW (rev2) Patchwork
2022-11-23 23:01 ` Umesh Nerlige Ramappa
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=Y35/7Qc530jik3FH@unerlige-ril \
--to=umesh.nerlige.ramappa@intel.com \
--cc=ashutosh.dixit@intel.com \
--cc=intel-gfx@lists.freedesktop.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox