[PATCH 1/3] drm/nouveau: wait for moving fence after pinning v2

Daniel Vetter daniel.vetter at ffwll.ch
Tue Jun 22 12:12:43 UTC 2021


On Tue, Jun 22, 2021 at 1:45 PM Christian König
<ckoenig.leichtzumerken at gmail.com> wrote:
>
> We actually need to wait for the moving fence after pinning
> the BO to make sure that the pin is completed.
>
> v2: grab the lock while waiting
>
> Signed-off-by: Christian König <christian.koenig at amd.com>
> References: https://lore.kernel.org/dri-devel/20210621151758.2347474-1-daniel.vetter@ffwll.ch/
> CC: stable at kernel.org

Reviewed-by: Daniel Vetter <daniel.vetter at ffwll.ch>

> ---
>  drivers/gpu/drm/nouveau/nouveau_prime.c | 17 ++++++++++++++++-
>  1 file changed, 16 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/gpu/drm/nouveau/nouveau_prime.c b/drivers/gpu/drm/nouveau/nouveau_prime.c
> index 347488685f74..60019d0532fc 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_prime.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_prime.c
> @@ -93,7 +93,22 @@ int nouveau_gem_prime_pin(struct drm_gem_object *obj)
>         if (ret)
>                 return -EINVAL;
>
> -       return 0;
> +       ret = ttm_bo_reserve(&nvbo->bo, false, false, NULL);
> +       if (ret)
> +               goto error;
> +
> +       if (nvbo->bo.moving)
> +               ret = dma_fence_wait(nvbo->bo.moving, true);
> +
> +       ttm_bo_unreserve(&nvbo->bo);
> +       if (ret)
> +               goto error;
> +
> +       return ret;
> +
> +error:
> +       nouveau_bo_unpin(nvbo);
> +       return ret;
>  }
>
>  void nouveau_gem_prime_unpin(struct drm_gem_object *obj)
> --
> 2.25.1
>


-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch


More information about the dri-devel mailing list