[Intel-gfx] [PATCH 2/3] drm/i915: Move fiddling with engine->last_retired_context

Tvrtko Ursulin tvrtko.ursulin at linux.intel.com
Thu Apr 19 10:45:40 UTC 2018


On 19/04/2018 08:17, Chris Wilson wrote:
> Move the knowledge about resetting the current context tracking on the
> engine from inside i915_gem_context.c into intel_engine_cs.c
> 
> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> ---
>   drivers/gpu/drm/i915/i915_gem_context.c | 12 ++----------
>   drivers/gpu/drm/i915/intel_engine_cs.c  | 24 ++++++++++++++++++++++++
>   drivers/gpu/drm/i915/intel_ringbuffer.h |  2 ++
>   3 files changed, 28 insertions(+), 10 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/i915_gem_context.c b/drivers/gpu/drm/i915/i915_gem_context.c
> index 74435affe23f..2fe779cab298 100644
> --- a/drivers/gpu/drm/i915/i915_gem_context.c
> +++ b/drivers/gpu/drm/i915/i915_gem_context.c
> @@ -514,16 +514,8 @@ void i915_gem_contexts_lost(struct drm_i915_private *dev_priv)
>   
>   	lockdep_assert_held(&dev_priv->drm.struct_mutex);
>   
> -	for_each_engine(engine, dev_priv, id) {
> -		engine->legacy_active_context = NULL;
> -		engine->legacy_active_ppgtt = NULL;
> -
> -		if (!engine->last_retired_context)
> -			continue;
> -
> -		engine->context_unpin(engine, engine->last_retired_context);
> -		engine->last_retired_context = NULL;
> -	}
> +	for_each_engine(engine, dev_priv, id)
> +		intel_engine_lost_context(engine);
>   }
>   
>   void i915_gem_contexts_fini(struct drm_i915_private *i915)
> diff --git a/drivers/gpu/drm/i915/intel_engine_cs.c b/drivers/gpu/drm/i915/intel_engine_cs.c
> index 0248d64c2a72..4749426f9cad 100644
> --- a/drivers/gpu/drm/i915/intel_engine_cs.c
> +++ b/drivers/gpu/drm/i915/intel_engine_cs.c
> @@ -1084,6 +1084,30 @@ void intel_engines_unpark(struct drm_i915_private *i915)
>   	}
>   }
>   
> +
> +/**
> + * intel_engine_lost_context: called when the GPU is reset into unknown state
> + * @engine: the engine
> + *
> + * We have either reset the GPU or otherwise about to lose state tracking of
> + * the current GPU logical state (e.g. suspend). On next use, it is therefore
> + * imperative that we make no presumptions about the current state and load
> + * from scratch.
> + */
> +void intel_engine_lost_context(struct intel_engine_cs *engine)
> +{
> +	struct i915_gem_context *ctx;
> +
> +	lockdep_assert_held(&engine->i915->drm.struct_mutex);
> +
> +	engine->legacy_active_context = NULL;
> +	engine->legacy_active_ppgtt = NULL;
> +
> +	ctx = fetch_and_zero(&engine->last_retired_context);
> +	if (ctx)
> +		engine->context_unpin(engine, ctx);
> +}
> +
>   bool intel_engine_can_store_dword(struct intel_engine_cs *engine)
>   {
>   	switch (INTEL_GEN(engine->i915)) {
> diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.h b/drivers/gpu/drm/i915/intel_ringbuffer.h
> index c5e27905b0e1..1231695fb4da 100644
> --- a/drivers/gpu/drm/i915/intel_ringbuffer.h
> +++ b/drivers/gpu/drm/i915/intel_ringbuffer.h
> @@ -1044,6 +1044,8 @@ bool intel_engine_has_kernel_context(const struct intel_engine_cs *engine);
>   void intel_engines_park(struct drm_i915_private *i915);
>   void intel_engines_unpark(struct drm_i915_private *i915);
>   
> +void intel_engine_lost_context(struct intel_engine_cs *engine);
> +
>   void intel_engines_reset_default_submission(struct drm_i915_private *i915);
>   unsigned int intel_engines_has_context_isolation(struct drm_i915_private *i915);
>   
> 

Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin at intel.com>

Regards,

Tvrtko


More information about the Intel-gfx mailing list