From: Tomas Elf <tomas.elf@intel.com>
To: Chris Wilson <chris@chris-wilson.co.uk>,
Mika Kuoppala <mika.kuoppala@linux.intel.com>,
intel-gfx@lists.freedesktop.org
Subject: Re: [PATCH 1/1] drm/i915: Reset request handling for gen9+
Date: Tue, 16 Jun 2015 21:15:56 +0100 [thread overview]
Message-ID: <558083FC.1070104@intel.com> (raw)
In-Reply-To: <20150616171012.GL11933@nuc-i3427.alporthouse.com>
On 16/06/2015 18:10, Chris Wilson wrote:
> On Tue, Jun 16, 2015 at 04:39:23PM +0300, Mika Kuoppala wrote:
>> In order for skl+ hardware to guarantee that no context switch
>> takes place during reset and that current context is properly
>> saved, the driver needs to notify and query hw before commencing
>> with reset.
>>
>> We will only proceed with reset if all engines report that they
>> are ready for reset.
>>
>> As we skip the reset if any single engine reports not ready, this
>> commit prevents system hang skl in some situations where the
>> gpu/blitter is hanged and in such state that any write to generic
>
> s/is hanged/is wedged/ reads better
>
>> reset register (GEN6_GDRST) causes immediate system hang.
>>
>> References: https://bugs.freedesktop.org/show_bug.cgi?id=89959
>> References: https://bugs.freedesktop.org/show_bug.cgi?id=90854
>> Signed-off-by: Mika Kuoppala <mika.kuoppala@intel.com>
>> ---
>> drivers/gpu/drm/i915/i915_reg.h | 3 +++
>> drivers/gpu/drm/i915/intel_uncore.c | 32 +++++++++++++++++++++++++++++++-
>> 2 files changed, 34 insertions(+), 1 deletion(-)
>>
>> diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h
>> index 0b979ad..3684f92 100644
>> --- a/drivers/gpu/drm/i915/i915_reg.h
>> +++ b/drivers/gpu/drm/i915/i915_reg.h
>> @@ -1461,6 +1461,9 @@ enum skl_disp_power_wells {
>> #define RING_MAX_IDLE(base) ((base)+0x54)
>> #define RING_HWS_PGA(base) ((base)+0x80)
>> #define RING_HWS_PGA_GEN6(base) ((base)+0x2080)
>> +#define RING_RESET_CTL(base) ((base)+0xd0)
>> +#define RESET_CTL_REQUEST_RESET (1 << 0)
>> +#define RESET_CTL_READY_TO_RESET (1 << 1)
>>
>> #define HSW_GTT_CACHE_EN 0x4024
>> #define GTT_CACHE_EN_ALL 0xF0007FFF
>> diff --git a/drivers/gpu/drm/i915/intel_uncore.c b/drivers/gpu/drm/i915/intel_uncore.c
>> index 4a86cf0..404bce2 100644
>> --- a/drivers/gpu/drm/i915/intel_uncore.c
>> +++ b/drivers/gpu/drm/i915/intel_uncore.c
>> @@ -1455,9 +1455,39 @@ static int gen6_do_reset(struct drm_device *dev)
>> return ret;
>> }
>>
>> +static int wait_for_bits_set(struct drm_i915_private *dev_priv,
>> + const u32 reg, const u32 mask, const int timeout)
>> +{
>> + return wait_for((I915_READ(reg) & mask) == mask, timeout);
>> +}
>> +
>> +static int gen9_do_reset(struct drm_device *dev)
>> +{
>> + struct drm_i915_private *dev_priv = dev->dev_private;
>> + struct intel_engine_cs *engine;
>> + int ret, i;
>> +
>> + for_each_ring(engine, dev_priv, i) {
>> + I915_WRITE(RING_RESET_CTL(engine->mmio_base),
>> + _MASKED_BIT_ENABLE(RESET_CTL_REQUEST_RESET));
>> +
>> + ret = wait_for_bits_set(dev_priv,
>> + RING_RESET_CTL(engine->mmio_base),
>> + RESET_CTL_READY_TO_RESET, 700);
>> + if (ret) {
>> + DRM_ERROR("%s: reset request timeout\n", engine->name);
>> + return -ENODEV;
>
> return -EIO; since the reset didn't happen due to hardware issues
> (ENODEV is that we don't have the implementation for the GPU rather than
> it failed).
>
> Do we need any recovery? Do you guarrantee that the GPU reset resets the
> CTL register?
> -Chris
According to the bspec (if I remember correctly from the last time I had
to deal with it - Mika, correct me if I'm way off here):
If the reset request succeeds the reset request bit is cleared and
ready_to_reset is set. Following the engine reset both ready_to_reset
and reset request bits are set to 0. If the reset request fails the
reset_request bit is obviously still set.
Then again, all of this is assuming engine resets rather than a full GPU
reset. The bspec does not say anything about what the effect of a full
gpu reset is on the reset control registers. It's always seemed to me
like the reset control register is only relevant when doing a per-engine
reset rather than a full GPU reset but I might very well be wrong about
that, especially since you guys have seen problems when not involving
this reset handshake before doing full GPU resets.
Thanks,
Tomas
>
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/intel-gfx
next prev parent reply other threads:[~2015-06-16 20:15 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-06-16 13:39 [PATCH 1/1] drm/i915: Reset request handling for gen9+ Mika Kuoppala
2015-06-16 14:09 ` Chris Wilson
2015-06-16 17:10 ` Chris Wilson
2015-06-16 20:15 ` Tomas Elf [this message]
2015-06-17 6:33 ` Mika Kuoppala
2015-06-16 19:57 ` Tomas Elf
2015-06-17 12:35 ` [PATCH] drm/i915: Reset request handling for gen8+ Mika Kuoppala
2015-06-18 8:36 ` Mika Kuoppala
2015-06-18 8:50 ` Chris Wilson
2015-06-18 9:51 ` Mika Kuoppala
2015-06-18 10:03 ` Chris Wilson
2015-06-18 10:22 ` Mika Kuoppala
2015-06-18 15:00 ` Daniel Vetter
2015-06-18 10:11 ` Tomas Elf
2015-06-18 10:31 ` Mika Kuoppala
2015-06-18 10:36 ` Chris Wilson
2015-06-18 11:18 ` Tomas Elf
2015-06-18 11:42 ` Chris Wilson
2015-06-18 14:58 ` Daniel Vetter
2015-06-19 16:30 ` Chris Wilson
2015-06-22 12:50 ` Daniel Vetter
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=558083FC.1070104@intel.com \
--to=tomas.elf@intel.com \
--cc=chris@chris-wilson.co.uk \
--cc=intel-gfx@lists.freedesktop.org \
--cc=mika.kuoppala@linux.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox