Re: [PATCH] drm/i915/userptr: Keep spin_lock/unlock in the same block

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



All of the NULL tests are a bit complicated but since they are there
anyway, I guess it is reasonable to take advantage of them.

julia

On Thu, 24 Jul 2014, Chris Wilson wrote:

> Move the code around in order to acquire and release the spinlock in the
> same function and in the same block. This keeps static analysers happy
> and the reader sane.
>
> Suggested-by: Julia Lawall <julia.lawall@xxxxxxx>
> Signed-off-by: Chris Wilson <chris@xxxxxxxxxxxxxxxxxx>
> Cc: Julia Lawall <julia.lawall@xxxxxxx>
> ---
>  drivers/gpu/drm/i915/i915_gem_userptr.c | 17 ++++++++---------
>  1 file changed, 8 insertions(+), 9 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/i915_gem_userptr.c b/drivers/gpu/drm/i915/i915_gem_userptr.c
> index 12358fd..4ef5a92 100644
> --- a/drivers/gpu/drm/i915/i915_gem_userptr.c
> +++ b/drivers/gpu/drm/i915/i915_gem_userptr.c
> @@ -96,10 +96,10 @@ static unsigned long cancel_userptr(struct drm_i915_gem_object *obj)
>  	return end;
>  }
>
> -static void invalidate_range__linear(struct i915_mmu_notifier *mn,
> -				     struct mm_struct *mm,
> -				     unsigned long start,
> -				     unsigned long end)
> +static void *invalidate_range__linear(struct i915_mmu_notifier *mn,
> +				      struct mm_struct *mm,
> +				      unsigned long start,
> +				      unsigned long end)
>  {
>  	struct i915_mmu_object *mo;
>  	unsigned long serial;
> @@ -123,7 +123,7 @@ restart:
>  			goto restart;
>  	}
>
> -	spin_unlock(&mn->lock);
> +	return NULL;
>  }
>
>  static void i915_gem_userptr_mn_invalidate_range_start(struct mmu_notifier *_mn,
> @@ -138,13 +138,12 @@ static void i915_gem_userptr_mn_invalidate_range_start(struct mmu_notifier *_mn,
>
>  	end--; /* interval ranges are inclusive, but invalidate range is exclusive */
>  	while (next < end) {
> -		struct drm_i915_gem_object *obj;
> +		struct drm_i915_gem_object *obj = NULL;
>
> -		obj = NULL;
>  		spin_lock(&mn->lock);
>  		if (mn->has_linear)
> -			return invalidate_range__linear(mn, mm, start, end);
> -		if (serial == mn->serial)
> +			it = invalidate_range__linear(mn, mm, start, end);
> +		else if (serial == mn->serial)
>  			it = interval_tree_iter_next(it, next, end);
>  		else
>  			it = interval_tree_iter_first(&mn->objects, start, end);
> --
> 1.9.1
>
>
_______________________________________________
Intel-gfx mailing list
Intel-gfx@xxxxxxxxxxxxxxxxxxxxx
http://lists.freedesktop.org/mailman/listinfo/intel-gfx




[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux