[Intel-gfx] [PATCH 1/2] drm/i915: Squelch smatch warning for statement with no effect

Jani Nikula jani.nikula at linux.intel.com
Wed Jan 25 11:25:24 UTC 2017


On Fri, 20 Jan 2017, Chris Wilson <chris at chris-wilson.co.uk> wrote:
> The sgt iterators cause an
>
> drivers/gpu/drm/i915/i915_gpu_error.c:846 i915_error_object_create() warn: statement has no effect 7
>
> everywhere they are used. If we change the code slightly, we can achieve
> the same increment without altering the output or raising a warning.

I've never liked using logical OR short circuiting for assignments like
this anyway, so I think this is an improvement no matter what.

Reviewed-by: Jani Nikula <jani.nikula at intel.com>


>
>    text	   data	    bss	    dec	    hex	filename
> 1267906	  20587	   3168	1291661	 13b58d	before
> 1267906	  20587	   3168	1291661	 13b58d	after
>
> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> ---
>  drivers/gpu/drm/i915/i915_drv.h | 8 ++++----
>  1 file changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h
> index 1b340eb0db19..ebe2f6c737f7 100644
> --- a/drivers/gpu/drm/i915/i915_drv.h
> +++ b/drivers/gpu/drm/i915/i915_drv.h
> @@ -2620,8 +2620,8 @@ static inline struct scatterlist *__sg_next(struct scatterlist *sg)
>  #define for_each_sgt_dma(__dmap, __iter, __sgt)				\
>  	for ((__iter) = __sgt_iter((__sgt)->sgl, true);			\
>  	     ((__dmap) = (__iter).dma + (__iter).curr);			\
> -	     (((__iter).curr += PAGE_SIZE) < (__iter).max) ||		\
> -	     ((__iter) = __sgt_iter(__sg_next((__iter).sgp), true), 0))
> +	     (((__iter).curr += PAGE_SIZE) >= (__iter).max) ?		\
> +	     (__iter) = __sgt_iter(__sg_next((__iter).sgp), true), 0 : 0)
>  
>  /**
>   * for_each_sgt_page - iterate over the pages of the given sg_table
> @@ -2633,8 +2633,8 @@ static inline struct scatterlist *__sg_next(struct scatterlist *sg)
>  	for ((__iter) = __sgt_iter((__sgt)->sgl, false);		\
>  	     ((__pp) = (__iter).pfn == 0 ? NULL :			\
>  	      pfn_to_page((__iter).pfn + ((__iter).curr >> PAGE_SHIFT))); \
> -	     (((__iter).curr += PAGE_SIZE) < (__iter).max) ||		\
> -	     ((__iter) = __sgt_iter(__sg_next((__iter).sgp), false), 0))
> +	     (((__iter).curr += PAGE_SIZE) >= (__iter).max) ?		\
> +	     (__iter) = __sgt_iter(__sg_next((__iter).sgp), false), 0 : 0)
>  
>  static inline const struct intel_device_info *
>  intel_info(const struct drm_i915_private *dev_priv)

-- 
Jani Nikula, Intel Open Source Technology Center


More information about the Intel-gfx mailing list