[Intel-gfx] [PATCH] drm/i915: use hrtimer in wait for vblank

Daniel Vetter daniel at ffwll.ch
Mon Mar 24 11:00:50 CET 2014


On Mon, Mar 24, 2014 at 09:34:35AM +0000, Murthy, Arun R wrote:
> >> diff --git a/drivers/gpu/drm/i915/intel_drv.h 
> >> b/drivers/gpu/drm/i915/intel_drv.h
> >> index 44067bc..079280a 100644
> >> --- a/drivers/gpu/drm/i915/intel_drv.h
> >> +++ b/drivers/gpu/drm/i915/intel_drv.h
> >> @@ -52,7 +52,7 @@
> >>  			break;						\
> >>  		}							\
> >>  		if (W && drm_can_sleep())  {				\
> >> -			msleep(W);					\
> >> +			usleep_range(W * 1000, W * 2 * 1000);		\
> >>  		} else {						\
> >>  			cpu_relax();					\
> >>  		}							\
> >
> > Ok. But W is still just a random value we picked for being the mininum 
> > legal value for msleep(). So just usleep_range(500, 2000) or somesuch 
> > will be fine. We can rename W to CAN_SLEEP it that helps.
> 
> We do use _wait_for directly from intel_dp.c with W == 10 to not retry so many times on what's expected to be a long wait.
> 
> Its not expected to be too long, we tend to get vblank every 16ms.  With using usleep_range
> with min and max as 1-2ms, we have observed that this function consuming 4ms to 17ms.
> Having 10ms sleep timer, we might tend to be blocking for 6ms in some cases.(from the above data)
> Moreover 10ms usleep doesn't guarantee that we get a chance to execute after 10ms, it might
> get increased due to scheduling. So ideal solution would be to use useep_range which uses hrtimers.

Can you please do proper quoting when replying? It makes it fairly hard to
figure out what's your response when you reply in-line, especially in more
complicated threads. And top-posting isn't an option either, especially
for more in-depth discussions where the different issues need to be
treated as separate points.

You need a real mail client for this, Outlook won't cut it. Jesse is
floating slides internal with all the details and tons of links to
resources.

Thanks, Daniel
-- 
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch



More information about the Intel-gfx mailing list