Re: [PATCH] drm/exynos: fix ref count leak in mic_pre_enable

From: Navid Emamdoost
Date: Mon Jun 15 2020 - 01:57:29 EST


On Sun, Jun 14, 2020 at 7:47 PM Inki Dae <inki.dae@xxxxxxxxxxx> wrote:
>
> Hi,
>
> 20. 6. 14. ìí 3:23ì Navid Emamdoost ì(ê) ì ê:
> > in mic_pre_enable, pm_runtime_get_sync is called which
> > increments the counter even in case of failure, leading to incorrect
> > ref count. In case of failure, decrement the ref count before returning.
> >
> > Signed-off-by: Navid Emamdoost <navid.emamdoost@xxxxxxxxx>
> > ---
> > drivers/gpu/drm/exynos/exynos_drm_mic.c | 2 +-
> > 1 file changed, 1 insertion(+), 1 deletion(-)
> >
> > diff --git a/drivers/gpu/drm/exynos/exynos_drm_mic.c b/drivers/gpu/drm/exynos/exynos_drm_mic.c
> > index a86abc173605..69ff74c2ceb5 100644
> > --- a/drivers/gpu/drm/exynos/exynos_drm_mic.c
> > +++ b/drivers/gpu/drm/exynos/exynos_drm_mic.c
> > @@ -270,7 +270,7 @@ static void mic_pre_enable(struct drm_bridge *bridge)
> >
> > ret = pm_runtime_get_sync(mic->dev);
> > if (ret < 0)
> > - goto unlock;
> > + goto turn_off;
>
> How about just calling pm_runtime_put_noidle()?
>
> if (ret < 0) {
> pm_runtime_put_noidle(mic->dev);
> goto unlock;
> }
>
v2 was sent.

> Thanks,
> Inki Dae
>
> >
> > mic_set_path(mic, 1);
> >
> >



--
Navid.