On Thu, Jul 24, 2014 at 05:04:43PM +0100, Thomas Daniel wrote:
> From: Oscar Mateo <oscar.ma...@intel.com>
> 
> Since the ringbuffer does not belong per engine anymore, we have to
> make sure that we are always recording the correct ringbuffer.
> 
> TODO: This is only a small fix to keep basic error capture working, but
> we need to add more information for it to be useful (e.g. dump the
> context being executed).
> 
> v2: Reorder how the ringbuffer is chosen to clarify the change and
> rename the variable, both changes suggested by Chris Wilson. Also,
> add the TODO comment to the code, as suggested by Daniel.
> 
> Signed-off-by: Oscar Mateo <oscar.ma...@intel.com>

There's a bit too much stuff in-flight to fix up error capture for ppgtt.
I think it's better to stall this patch here until that work is completed.
Please coordinate with Mika here.
-Daniel

> ---
>  drivers/gpu/drm/i915/i915_gpu_error.c |   22 ++++++++++++++++++----
>  1 file changed, 18 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/i915_gpu_error.c 
> b/drivers/gpu/drm/i915/i915_gpu_error.c
> index 45b6191..1e38576 100644
> --- a/drivers/gpu/drm/i915/i915_gpu_error.c
> +++ b/drivers/gpu/drm/i915/i915_gpu_error.c
> @@ -874,9 +874,6 @@ static void i915_record_ring_state(struct drm_device *dev,
>               ering->hws = I915_READ(mmio);
>       }
>  
> -     ering->cpu_ring_head = ring->buffer->head;
> -     ering->cpu_ring_tail = ring->buffer->tail;
> -
>       ering->hangcheck_score = ring->hangcheck.score;
>       ering->hangcheck_action = ring->hangcheck.action;
>  
> @@ -936,6 +933,7 @@ static void i915_gem_record_rings(struct drm_device *dev,
>  
>       for (i = 0; i < I915_NUM_RINGS; i++) {
>               struct intel_engine_cs *ring = &dev_priv->ring[i];
> +             struct intel_ringbuffer *rbuf;
>  
>               error->ring[i].pid = -1;
>  
> @@ -979,8 +977,24 @@ static void i915_gem_record_rings(struct drm_device *dev,
>                       }
>               }
>  
> +             if (i915.enable_execlists) {
> +                     /* TODO: This is only a small fix to keep basic error
> +                      * capture working, but we need to add more information
> +                      * for it to be useful (e.g. dump the context being
> +                      * executed).
> +                      */
> +                     if (request)
> +                             rbuf = request->ctx->engine[ring->id].ringbuf;
> +                     else
> +                             rbuf = 
> ring->default_context->engine[ring->id].ringbuf;
> +             } else
> +                     rbuf = ring->buffer;
> +
> +             error->ring[i].cpu_ring_head = rbuf->head;
> +             error->ring[i].cpu_ring_tail = rbuf->tail;
> +
>               error->ring[i].ringbuffer =
> -                     i915_error_ggtt_object_create(dev_priv, 
> ring->buffer->obj);
> +                     i915_error_ggtt_object_create(dev_priv, rbuf->obj);
>  
>               if (ring->status_page.obj)
>                       error->ring[i].hws_page =
> -- 
> 1.7.9.5
> 
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx@lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/intel-gfx

-- 
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to