[PATCH] dma-buf: fix unintended pin/unpin warnings

Alex Deucher alexdeucher at gmail.com
Mon May 17 14:09:13 UTC 2021


On Mon, May 17, 2021 at 7:57 AM Christian König
<ckoenig.leichtzumerken at gmail.com> wrote:
>
> DMA-buf internal users call the pin/unpin functions without having a
> dynamic attachment. Avoid the warning and backtrace in the logs.
>
> Signed-off-by: Christian König <christian.koenig at amd.com>
> Bugs: https://gitlab.freedesktop.org/drm/intel/-/issues/3481
> Fixes: c545781e1c55 ("dma-buf: doc polish for pin/unpin")
> CC: stable at kernel.org

Reviewed-by: Alex Deucher <alexander.deucher at amd.com>

> ---
>  drivers/dma-buf/dma-buf.c | 10 +++++-----
>  1 file changed, 5 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/dma-buf/dma-buf.c b/drivers/dma-buf/dma-buf.c
> index f264b70c383e..eadd1eaa2fb5 100644
> --- a/drivers/dma-buf/dma-buf.c
> +++ b/drivers/dma-buf/dma-buf.c
> @@ -760,7 +760,7 @@ dma_buf_dynamic_attach(struct dma_buf *dmabuf, struct device *dev,
>
>                 if (dma_buf_is_dynamic(attach->dmabuf)) {
>                         dma_resv_lock(attach->dmabuf->resv, NULL);
> -                       ret = dma_buf_pin(attach);
> +                       ret = dmabuf->ops->pin(attach);
>                         if (ret)
>                                 goto err_unlock;
>                 }
> @@ -786,7 +786,7 @@ dma_buf_dynamic_attach(struct dma_buf *dmabuf, struct device *dev,
>
>  err_unpin:
>         if (dma_buf_is_dynamic(attach->dmabuf))
> -               dma_buf_unpin(attach);
> +               dmabuf->ops->unpin(attach);
>
>  err_unlock:
>         if (dma_buf_is_dynamic(attach->dmabuf))
> @@ -843,7 +843,7 @@ void dma_buf_detach(struct dma_buf *dmabuf, struct dma_buf_attachment *attach)
>                 __unmap_dma_buf(attach, attach->sgt, attach->dir);
>
>                 if (dma_buf_is_dynamic(attach->dmabuf)) {
> -                       dma_buf_unpin(attach);
> +                       dmabuf->ops->unpin(attach);
>                         dma_resv_unlock(attach->dmabuf->resv);
>                 }
>         }
> @@ -956,7 +956,7 @@ struct sg_table *dma_buf_map_attachment(struct dma_buf_attachment *attach,
>         if (dma_buf_is_dynamic(attach->dmabuf)) {
>                 dma_resv_assert_held(attach->dmabuf->resv);
>                 if (!IS_ENABLED(CONFIG_DMABUF_MOVE_NOTIFY)) {
> -                       r = dma_buf_pin(attach);
> +                       r = attach->dmabuf->ops->pin(attach);
>                         if (r)
>                                 return ERR_PTR(r);
>                 }
> @@ -968,7 +968,7 @@ struct sg_table *dma_buf_map_attachment(struct dma_buf_attachment *attach,
>
>         if (IS_ERR(sg_table) && dma_buf_is_dynamic(attach->dmabuf) &&
>              !IS_ENABLED(CONFIG_DMABUF_MOVE_NOTIFY))
> -               dma_buf_unpin(attach);
> +               attach->dmabuf->ops->unpin(attach);
>
>         if (!IS_ERR(sg_table) && attach->dmabuf->ops->cache_sgt_mapping) {
>                 attach->sgt = sg_table;
> --
> 2.25.1
>


More information about the dri-devel mailing list