[Intel-gfx] [PATCH] drm/i915: New vfunc prepare_request
Chris Wilson
chris at chris-wilson.co.uk
Sat Apr 29 08:31:16 UTC 2017
On Fri, Apr 28, 2017 at 05:26:09PM +0000, Oscar Mateo wrote:
> This will be more useful later to support platforms that need to emit
> HW commands at the beginning of every request (more general than emitting
> things at the beginning of every batchbuffer, which is already covered by
> emit_bb_start).
We already have one... You are presenting this without a good reason and
failing to transform similar code, which indicates to me that this vfunc
isn't that general.
> Cc: Chris Wilson <chris at chris-wilson.co.uk>
> Cc: Joonas Lahtinen <joonas.lahtinen at linux.intel.com>
> Signed-off-by: Oscar Mateo <oscar.mateo at intel.com>
> ---
> drivers/gpu/drm/i915/intel_lrc.c | 17 ++++++++++++-----
> drivers/gpu/drm/i915/intel_ringbuffer.h | 1 +
> 2 files changed, 13 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_lrc.c b/drivers/gpu/drm/i915/intel_lrc.c
> index 9488578..a5c055a 100644
> --- a/drivers/gpu/drm/i915/intel_lrc.c
> +++ b/drivers/gpu/drm/i915/intel_lrc.c
> @@ -687,6 +687,15 @@ static bool insert_request(struct i915_priotree *pt, struct rb_root *root)
> return first;
> }
>
> +static int execlists_prepare_request(struct drm_i915_gem_request *request)
> +{
> + u32 *cs = intel_ring_begin(request, 0);
> + if (IS_ERR(cs))
> + return PTR_ERR(cs);
> +
> + return 0;
> +}
> +
> static void execlists_submit_request(struct drm_i915_gem_request *request)
> {
> struct intel_engine_cs *engine = request->engine;
> @@ -879,7 +888,6 @@ static int execlists_request_alloc(struct drm_i915_gem_request *request)
> {
> struct intel_engine_cs *engine = request->engine;
> struct intel_context *ce = &request->ctx->engine[engine->id];
> - u32 *cs;
> int ret;
>
> GEM_BUG_ON(!ce->pin_count);
> @@ -904,11 +912,9 @@ static int execlists_request_alloc(struct drm_i915_gem_request *request)
> goto err;
> }
>
> - cs = intel_ring_begin(request, 0);
> - if (IS_ERR(cs)) {
> - ret = PTR_ERR(cs);
> + ret = engine->prepare_request(request);
> + if (ret)
> goto err_unreserve;
> - }
>
> if (!ce->initialised) {
> ret = engine->init_context(request);
> @@ -1650,6 +1656,7 @@ void intel_logical_ring_cleanup(struct intel_engine_cs *engine)
>
> static void execlists_set_default_submission(struct intel_engine_cs *engine)
> {
> + engine->prepare_request = execlists_prepare_request;
> engine->submit_request = execlists_submit_request;
> engine->schedule = execlists_schedule;
> engine->irq_tasklet.func = intel_lrc_irq_handler;
> diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.h b/drivers/gpu/drm/i915/intel_ringbuffer.h
> index d901831..67de978 100644
> --- a/drivers/gpu/drm/i915/intel_ringbuffer.h
> +++ b/drivers/gpu/drm/i915/intel_ringbuffer.h
> @@ -303,6 +303,7 @@ struct intel_engine_cs {
> void (*emit_breadcrumb)(struct drm_i915_gem_request *req,
> u32 *cs);
> int emit_breadcrumb_sz;
> + int (*prepare_request)(struct drm_i915_gem_request *req);
Why in the emit group?
-Chris
--
Chris Wilson, Intel Open Source Technology Centre
More information about the Intel-gfx
mailing list