[Intel-gfx] [PATCH 1/1] drm/i915: intel_ring_initialized() must be simple and inline
Daniel Vetter
daniel at ffwll.ch
Thu Dec 10 02:24:54 PST 2015
On Tue, Dec 08, 2015 at 03:02:36PM +0000, Dave Gordon wrote:
> Based on Chris Wilson's patch from 6 months ago, rebased and adapted.
>
> The current implementation of intel_ring_initialized() is too heavyweight;
> it's a non-inlined function that chases several levels of pointers. This
> wouldn't matter too much if it were rarely called, but it's used inside
> the iterator test of for_each_ring() and is therefore called quite
> frequently. So let's make it simple and inline ...
>
> The idea here is to use ring->dev as an indicator showing which engines
> have been initialised and are therefore to be included in iterations that
> use for_each_ring(). This allows us to avoid multiple memory references
> and a (non-inlined) function call on each iteration of each such loop.
>
> Fixes regression from
> commit 48d823878d64f93163f5a949623346748bbce1b4
> Author: Oscar Mateo <oscar.mateo at intel.com>
> Date: Thu Jul 24 17:04:23 2014 +0100
>
> drm/i915/bdw: Generic logical ring init and cleanup
>
> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> Signed-off-by: Dave Gordon <david.s.gordon at intel.com>
Queued for -next, thanks for the patch.
-Daniel
> ---
> drivers/gpu/drm/i915/intel_lrc.c | 17 +++++++++-----
> drivers/gpu/drm/i915/intel_ringbuffer.c | 39 +++++++++++----------------------
> drivers/gpu/drm/i915/intel_ringbuffer.h | 6 ++++-
> 3 files changed, 30 insertions(+), 32 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_lrc.c b/drivers/gpu/drm/i915/intel_lrc.c
> index 4ebafab..7644c48 100644
> --- a/drivers/gpu/drm/i915/intel_lrc.c
> +++ b/drivers/gpu/drm/i915/intel_lrc.c
> @@ -1894,8 +1894,10 @@ void intel_logical_ring_cleanup(struct intel_engine_cs *ring)
>
> dev_priv = ring->dev->dev_private;
>
> - intel_logical_ring_stop(ring);
> - WARN_ON((I915_READ_MODE(ring) & MODE_IDLE) == 0);
> + if (ring->buffer) {
> + intel_logical_ring_stop(ring);
> + WARN_ON((I915_READ_MODE(ring) & MODE_IDLE) == 0);
> + }
>
> if (ring->cleanup)
> ring->cleanup(ring);
> @@ -1909,6 +1911,7 @@ void intel_logical_ring_cleanup(struct intel_engine_cs *ring)
> }
>
> lrc_destroy_wa_ctx_obj(ring);
> + ring->dev = NULL;
> }
>
> static int logical_ring_init(struct drm_device *dev, struct intel_engine_cs *ring)
> @@ -1931,11 +1934,11 @@ static int logical_ring_init(struct drm_device *dev, struct intel_engine_cs *rin
>
> ret = i915_cmd_parser_init_ring(ring);
> if (ret)
> - return ret;
> + goto error;
>
> ret = intel_lr_context_deferred_alloc(ring->default_context, ring);
> if (ret)
> - return ret;
> + goto error;
>
> /* As this is the default context, always pin it */
> ret = intel_lr_context_do_pin(
> @@ -1946,9 +1949,13 @@ static int logical_ring_init(struct drm_device *dev, struct intel_engine_cs *rin
> DRM_ERROR(
> "Failed to pin and map ringbuffer %s: %d\n",
> ring->name, ret);
> - return ret;
> + goto error;
> }
>
> + return 0;
> +
> +error:
> + intel_logical_ring_cleanup(ring);
> return ret;
> }
>
> diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.c b/drivers/gpu/drm/i915/intel_ringbuffer.c
> index 57d78f2..921c8a6 100644
> --- a/drivers/gpu/drm/i915/intel_ringbuffer.c
> +++ b/drivers/gpu/drm/i915/intel_ringbuffer.c
> @@ -33,23 +33,6 @@
> #include "i915_trace.h"
> #include "intel_drv.h"
>
> -bool
> -intel_ring_initialized(struct intel_engine_cs *ring)
> -{
> - struct drm_device *dev = ring->dev;
> -
> - if (!dev)
> - return false;
> -
> - if (i915.enable_execlists) {
> - struct intel_context *dctx = ring->default_context;
> - struct intel_ringbuffer *ringbuf = dctx->engine[ring->id].ringbuf;
> -
> - return ringbuf->obj;
> - } else
> - return ring->buffer && ring->buffer->obj;
> -}
> -
> int __intel_ring_space(int head, int tail, int size)
> {
> int space = head - tail;
> @@ -2167,8 +2150,10 @@ static int intel_init_ring_buffer(struct drm_device *dev,
> init_waitqueue_head(&ring->irq_queue);
>
> ringbuf = intel_engine_create_ringbuffer(ring, 32 * PAGE_SIZE);
> - if (IS_ERR(ringbuf))
> - return PTR_ERR(ringbuf);
> + if (IS_ERR(ringbuf)) {
> + ret = PTR_ERR(ringbuf);
> + goto error;
> + }
> ring->buffer = ringbuf;
>
> if (I915_NEED_GFX_HWS(dev)) {
> @@ -2197,8 +2182,7 @@ static int intel_init_ring_buffer(struct drm_device *dev,
> return 0;
>
> error:
> - intel_ringbuffer_free(ringbuf);
> - ring->buffer = NULL;
> + intel_cleanup_ring_buffer(ring);
> return ret;
> }
>
> @@ -2211,12 +2195,14 @@ void intel_cleanup_ring_buffer(struct intel_engine_cs *ring)
>
> dev_priv = to_i915(ring->dev);
>
> - intel_stop_ring_buffer(ring);
> - WARN_ON(!IS_GEN2(ring->dev) && (I915_READ_MODE(ring) & MODE_IDLE) == 0);
> + if (ring->buffer) {
> + intel_stop_ring_buffer(ring);
> + WARN_ON(!IS_GEN2(ring->dev) && (I915_READ_MODE(ring) & MODE_IDLE) == 0);
>
> - intel_unpin_ringbuffer_obj(ring->buffer);
> - intel_ringbuffer_free(ring->buffer);
> - ring->buffer = NULL;
> + intel_unpin_ringbuffer_obj(ring->buffer);
> + intel_ringbuffer_free(ring->buffer);
> + ring->buffer = NULL;
> + }
>
> if (ring->cleanup)
> ring->cleanup(ring);
> @@ -2225,6 +2211,7 @@ void intel_cleanup_ring_buffer(struct intel_engine_cs *ring)
>
> i915_cmd_parser_fini_ring(ring);
> i915_gem_batch_pool_fini(&ring->batch_pool);
> + ring->dev = NULL;
> }
>
> static int ring_wait_for_space(struct intel_engine_cs *ring, int n)
> diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.h b/drivers/gpu/drm/i915/intel_ringbuffer.h
> index 5d1eb20..49574ff 100644
> --- a/drivers/gpu/drm/i915/intel_ringbuffer.h
> +++ b/drivers/gpu/drm/i915/intel_ringbuffer.h
> @@ -350,7 +350,11 @@ struct intel_engine_cs {
> u32 (*get_cmd_length_mask)(u32 cmd_header);
> };
>
> -bool intel_ring_initialized(struct intel_engine_cs *ring);
> +static inline bool
> +intel_ring_initialized(struct intel_engine_cs *ring)
> +{
> + return ring->dev != NULL;
> +}
>
> static inline unsigned
> intel_ring_flag(struct intel_engine_cs *ring)
> --
> 1.9.1
>
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/intel-gfx
--
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
More information about the Intel-gfx
mailing list