[PATCH] drm: fix mutex leak in drm_dp_get_mst_branch_device

Daniel Vetter daniel at ffwll.ch
Fri Oct 16 10:24:16 PDT 2015


On Fri, Oct 16, 2015 at 03:33:02AM -0700, Adam Richter wrote:
> In Linux 4.3-rc5, there is an error case in drm_dp_get_branch_device
> that returns without releasing mgr->lock, resulting a spew of kernel
> messages about a kernel work function possibly having leaked a mutex
> and presumably more serious adverse consequences later.  This patch
> changes the error to "goto out" to unlock the mutex before returning.
> 
> Signed-off-by: Adam J. Richter <adam_richter2004 at yahoo.com>

Patch was whitespace mangled (don't past them into your mailer but instead
send them with git send-email directly, that's safer), so I had to
recreate it.

Applied to drm-misc, thanks.
-Daniel

> ---
> 
> bugzilla.freedesktop.org ticket:
> https://bugs.freedesktop.org/show_bug.cgi?id=92480
> 
> This patch is against the latest
> git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git .  I
> apologize in advance in I should be submitting patches against some
> other reference.  Please feel free to let me know if I should use some
> other reference for submitting future patches.
> 
> My request to subscribe to dri-devel at lists.freedesktop.org is pending,
> so I apologize if it takes a while for this message to be posted on
> the mailing list.
> 
> diff --git a/drivers/gpu/drm/drm_dp_mst_topology.c
> b/drivers/gpu/drm/drm_dp_mst_topology.c
> index bf27a07..018ad7f 100644
> --- a/drivers/gpu/drm/drm_dp_mst_topology.c
> +++ b/drivers/gpu/drm/drm_dp_mst_topology.c
> @@ -1194,17 +1194,18 @@ static struct drm_dp_mst_branch
> *drm_dp_get_mst_branch_device(struct drm_dp_mst_
> 
>                 list_for_each_entry(port, &mstb->ports, next) {
>                         if (port->port_num == port_num) {
> -                               if (!port->mstb) {
> +                               mstb = port->mstb;
> +                               if (!mstb) {
>                                         DRM_ERROR("failed to lookup
> MSTB with lct %d, rad %02x\n", lct, rad[0]);
> -                                       return NULL;
> +                                       goto out;
>                                 }
> 
> -                               mstb = port->mstb;
>                                 break;
>                         }
>                 }
>         }
>         kref_get(&mstb->kref);
> + out:
>         mutex_unlock(&mgr->lock);
>         return mstb;
>  }
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel

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


More information about the dri-devel mailing list