[Intel-gfx] [PATCH 40/55] drm/i915: Refactor blocking waits
Chris Wilson
chris at chris-wilson.co.uk
Wed Jul 27 07:07:48 UTC 2016
On Wed, Jul 27, 2016 at 09:04:03AM +0300, Joonas Lahtinen wrote:
> On ma, 2016-07-25 at 18:32 +0100, Chris Wilson wrote:
> > Tidy up the for loops that handle waiting for read/write vs read-only
> > access.
> >
> > Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> > ---
> > drivers/gpu/drm/i915/i915_gem.c | 158 +++++++++++++++++++---------------------
> > 1 file changed, 75 insertions(+), 83 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
> > index 3f6b69dcaccb..2d86a0c3f295 100644
> > --- a/drivers/gpu/drm/i915/i915_gem.c
> > +++ b/drivers/gpu/drm/i915/i915_gem.c
> > @@ -1339,6 +1339,23 @@ put_rpm:
> > return ret;
> > }
> >
> > +static void
> > +i915_gem_object_retire_request(struct drm_i915_gem_object *obj,
> > + struct drm_i915_gem_request *req)
> > +{
> > + int idx = req->engine->id;
> > +
> > + if (i915_gem_active_peek(&obj->last_read[idx],
> > + &obj->base.dev->struct_mutex) == req)
> > + i915_gem_object_retire__read(obj, idx);
> > + else if (i915_gem_active_peek(&obj->last_write,
> > + &obj->base.dev->struct_mutex) == req)
> > + i915_gem_object_retire__write(obj);
>
> If these functions will use same mutex (be it different than
> struct_mutex) in all invocations, I'd make an alias for it.
>
> > +
> > + if (!i915_reset_in_progress(&req->i915->gpu_error))
> > + i915_gem_request_retire_upto(req);
> > +}
> > +
> > /**
> > * Ensures that all rendering to the object has completed and the object is
> > * safe to unbind from the GTT or access from the CPU.
> > @@ -1349,39 +1366,34 @@ int
> > i915_gem_object_wait_rendering(struct drm_i915_gem_object *obj,
> > bool readonly)
> > {
> > - struct drm_i915_gem_request *request;
> > struct reservation_object *resv;
> > - int ret, i;
> > + struct i915_gem_active *active;
> > + unsigned long active_mask;
> > + int idx, ret;
> >
>
> We could do early exit here based on the active_mask, like with the
> nonblocking version.
Nope. Because here we have to worry about third parties, we can't exit
early.
> > - if (readonly) {
> > - request = i915_gem_active_peek(&obj->last_write,
> > - &obj->base.dev->struct_mutex);
> > - if (request) {
> > - ret = i915_wait_request(request);
> > - if (ret)
> > - return ret;
> > + lockdep_assert_held(&obj->base.dev->struct_mutex);
> >
> > - i = request->engine->id;
> > - if (i915_gem_active_peek(&obj->last_read[i],
> > - &obj->base.dev->struct_mutex) == request)
> > - i915_gem_object_retire__read(obj, i);
> > - else
> > - i915_gem_object_retire__write(obj);
> > - }
> > + if (!readonly) {
>
> Not sure why not just swap and keep this if (readonly)...
Consistency. The others did !readonly, and this was the odd one out.
>
> > + active = obj->last_read;
> > + active_mask = obj->active;
> > } else {
> > - for (i = 0; i < I915_NUM_ENGINES; i++) {
> > - request = i915_gem_active_peek(&obj->last_read[i],
> > - &obj->base.dev->struct_mutex);
> > - if (!request)
> > - continue;
> > + active_mask = 1;
>
> Wouldn't we have RENDER_RING define for this and other instances?
?
-Chris
--
Chris Wilson, Intel Open Source Technology Centre
More information about the Intel-gfx
mailing list