[Intel-gfx] [PATCH] drm/i915: fold wait_for_atomic_us into wait_for_atomic
Ville Syrjälä
ville.syrjala at linux.intel.com
Thu Mar 28 11:53:05 CET 2013
On Thu, Mar 28, 2013 at 11:31:04AM +0100, Daniel Vetter wrote:
> Since
>
> commit bcf9dcc1e6269fac674e41f25d007ff75f76e840
> Author: Chris Wilson <chris at chris-wilson.co.uk>
> Date: Sun Jul 15 09:42:38 2012 +0100
>
> drm/i915: Workaround hang with BSD and forcewake on SandyBridge
>
> and
>
> commit 0cc2764cc4a4bd73df55f8893c871778cf7ddd0f
> Author: Ben Widawsky <ben at bwidawsk.net>
> Date: Sat Sep 1 22:59:48 2012 -0700
>
> drm/i915: use cpu_relax() in wait_for_atomic
>
> these two macros are essentially the same, so unify them. We keep the
> _us version since it's a nice documentation for smaller timeouts.
>
> v2: Fixup time unit conversion, _wait_for takes ms (Ville).
>
> Cc: Jack Winter <jbh at alchemy.lu>
> Cc: Ville Syrjälä <ville.syrjala at linux.intel.com>
> Signed-off-by: Daniel Vetter <daniel.vetter at ffwll.ch>
Reviewed-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
> ---
> drivers/gpu/drm/i915/intel_drv.h | 15 ++-------------
> 1 file changed, 2 insertions(+), 13 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h
> index 54bc2ea..8e76f52f 100644
> --- a/drivers/gpu/drm/i915/intel_drv.h
> +++ b/drivers/gpu/drm/i915/intel_drv.h
> @@ -50,21 +50,10 @@
> ret__; \
> })
>
> -#define wait_for_atomic_us(COND, US) ({ \
> - unsigned long timeout__ = jiffies + usecs_to_jiffies(US); \
> - int ret__ = 0; \
> - while (!(COND)) { \
> - if (time_after(jiffies, timeout__)) { \
> - ret__ = -ETIMEDOUT; \
> - break; \
> - } \
> - cpu_relax(); \
> - } \
> - ret__; \
> -})
> -
> #define wait_for(COND, MS) _wait_for(COND, MS, 1)
> #define wait_for_atomic(COND, MS) _wait_for(COND, MS, 0)
> +#define wait_for_atomic_us(COND, US) _wait_for((COND), \
> + DIV_ROUND_UP((US), 1000), 0)
>
> #define KHz(x) (1000*x)
> #define MHz(x) KHz(1000*x)
> --
> 1.7.11.7
--
Ville Syrjälä
Intel OTC
More information about the Intel-gfx
mailing list