<br><br>On Wednesday, 26 December 2012, Inki Dae <<a href="mailto:inki.dae@samsung.com">inki.dae@samsung.com</a>> wrote:<br>><br>><br>> 2012/12/24 Sachin Kamat <<a href="mailto:sachin.kamat@linaro.org">sachin.kamat@linaro.org</a>><br>
>><br>>> This eliminates the need for explicit clk_put and makes the<br>>> cleanup and exit path code simpler.<br>>><br>>> Cc: Eunchul Kim <<a href="mailto:chulspro.kim@samsung.com">chulspro.kim@samsung.com</a>><br>
>> Signed-off-by: Sachin Kamat <<a href="mailto:sachin.kamat@linaro.org">sachin.kamat@linaro.org</a>><br>>> ---<br>>>  drivers/gpu/drm/exynos/exynos_drm_fimc.c |   46 ++++++-----------------------<br>
>>  1 files changed, 10 insertions(+), 36 deletions(-)<br>>><br>>> diff --git a/drivers/gpu/drm/exynos/exynos_drm_fimc.c b/drivers/gpu/drm/exynos/exynos_drm_fimc.c<br>>> index 972aa70..c4006b8 100644<br>
>> --- a/drivers/gpu/drm/exynos/exynos_drm_fimc.c<br>>> +++ b/drivers/gpu/drm/exynos/exynos_drm_fimc.c<br>>> @@ -1739,64 +1739,50 @@ static int __devinit fimc_probe(struct platform_device *pdev)<br>>>                 platform_get_device_id(pdev)->driver_data;<br>
>><br>>>         /* clock control */<br>>> -       ctx->sclk_fimc_clk = clk_get(dev, "sclk_fimc");<br>>> +       ctx->sclk_fimc_clk = devm_clk_get(dev, "sclk_fimc");<br>>>         if (IS_ERR(ctx->sclk_fimc_clk)) {<br>
>>                 dev_err(dev, "failed to get src fimc clock.\n");<br>>>                 return PTR_ERR(ctx->sclk_fimc_clk);<br>>>         }<br>>>         clk_enable(ctx->sclk_fimc_clk);<br>
>><br>>> -       ctx->fimc_clk = clk_get(dev, "fimc");<br>>> +       ctx->fimc_clk = devm_clk_get(dev, "fimc");<br>>>         if (IS_ERR(ctx->fimc_clk)) {<br>>>                 dev_err(dev, "failed to get fimc clock.\n");<br>
>>                 clk_disable(ctx->sclk_fimc_clk);<br>>> -               clk_put(ctx->sclk_fimc_clk);<br>>>                 return PTR_ERR(ctx->fimc_clk);<br>>>         }<br>>><br>>> -       ctx->wb_clk = clk_get(dev, "pxl_async0");<br>
>> +       ctx->wb_clk = devm_clk_get(dev, "pxl_async0");<br>>>         if (IS_ERR(ctx->wb_clk)) {<br>>>                 dev_err(dev, "failed to get writeback a clock.\n");<br>>>                 clk_disable(ctx->sclk_fimc_clk);<br>
>> -               clk_put(ctx->sclk_fimc_clk);<br>>> -               clk_put(ctx->fimc_clk);<br>>>                 return PTR_ERR(ctx->wb_clk);<br>>>         }<br>>><br>>> -       ctx->wb_b_clk = clk_get(dev, "pxl_async1");<br>
>> +       ctx->wb_b_clk = devm_clk_get(dev, "pxl_async1");<br>>>         if (IS_ERR(ctx->wb_b_clk)) {<br>>>                 dev_err(dev, "failed to get writeback b clock.\n");<br>
>>                 clk_disable(ctx->sclk_fimc_clk);<br>>> -               clk_put(ctx->sclk_fimc_clk);<br>>> -               clk_put(ctx->fimc_clk);<br>>> -               clk_put(ctx->wb_clk);<br>
>>                 return PTR_ERR(ctx->wb_b_clk);<br>>>         }<br>>><br>>> -       parent_clk = clk_get(dev, ddata->parent_clk);<br>>> +       parent_clk = devm_clk_get(dev, ddata->parent_clk);<br>
>><br>>>         if (IS_ERR(parent_clk)) {<br>>>                 dev_err(dev, "failed to get parent clock.\n");<br>>>                 clk_disable(ctx->sclk_fimc_clk);<br>>> -               clk_put(ctx->sclk_fimc_clk);<br>
>> -               clk_put(ctx->fimc_clk);<br>>> -               clk_put(ctx->wb_clk);<br>>> -               clk_put(ctx->wb_b_clk);<br>>>                 return PTR_ERR(parent_clk);<br>>>         }<br>
>><br>>>         if (clk_set_parent(ctx->sclk_fimc_clk, parent_clk)) {<br>>>                 dev_err(dev, "failed to set parent.\n");<br>>> -               clk_put(parent_clk);<br>>> +               devm_clk_put(dev, parent_clk);<br>
><br>> remove the above call. is there any reason that devm_clk_put should be called here?<br><br>Devm resources are freed/released automatically only when the device detaches. In the above case the clock was released explicitly (for whatever reasons) earlier. Hence i have used devm call to keep the code logic same as i do not know the behavior if this clock is 'put' when the device detaches instead of here.<br>
<br>>  <br>>><br>>>                 clk_disable(ctx->sclk_fimc_clk);<br>>> -               clk_put(ctx->sclk_fimc_clk);<br>>> -               clk_put(ctx->fimc_clk);<br>>> -               clk_put(ctx->wb_clk);<br>
>> -               clk_put(ctx->wb_b_clk);<br>>>                 return -EINVAL;<br>>>         }<br>>><br>>> -       clk_put(parent_clk);<br>>> +       devm_clk_put(dev, parent_clk);<br>
><br>> ditto.<br>>  <br>>><br>>>         clk_set_rate(ctx->sclk_fimc_clk, pdata->clk_rate);<br>>><br>>>         /* resource memory */<br>>> @@ -1804,16 +1790,14 @@ static int __devinit fimc_probe(struct platform_device *pdev)<br>
>>         ctx->regs = devm_request_and_ioremap(dev, ctx->regs_res);<br>>>         if (!ctx->regs) {<br>>>                 dev_err(dev, "failed to map registers.\n");<br>>> -               ret = -ENXIO;<br>
>> -               goto err_clk;<br>>> +               return -ENXIO;<br>>>         }<br>>><br>>>         /* resource irq */<br>>>         res = platform_get_resource(pdev, IORESOURCE_IRQ, 0);<br>
>>         if (!res) {<br>>>                 dev_err(dev, "failed to request irq resource.\n");<br>>> -               ret = -ENOENT;<br>>> -               goto err_clk;<br>>> +               return -ENOENT;<br>
>>         }<br>>><br>>>         ctx->irq = res->start;<br>>> @@ -1821,7 +1805,7 @@ static int __devinit fimc_probe(struct platform_device *pdev)<br>>>                 IRQF_ONESHOT, "drm_fimc", ctx);<br>
>>         if (ret < 0) {<br>>>                 dev_err(dev, "failed to request irq.\n");<br>>> -               goto err_clk;<br>>> +               return ret;<br>>>         }<br>
>><br>>>         /* context initailization */<br>>> @@ -1867,11 +1851,6 @@ err_ippdrv_register:<br>>>         pm_runtime_disable(dev);<br>>>  err_get_irq:<br>>>         free_irq(ctx->irq, ctx);<br>
>> -err_clk:<br>>> -       clk_put(ctx->sclk_fimc_clk);<br>>> -       clk_put(ctx->fimc_clk);<br>>> -       clk_put(ctx->wb_clk);<br>>> -       clk_put(ctx->wb_b_clk);<br>>><br>
>>         return ret;<br>>>  }<br>>> @@ -1891,11 +1870,6 @@ static int __devexit fimc_remove(struct platform_device *pdev)<br>>><br>>>         free_irq(ctx->irq, ctx);<br>>><br>>> -       clk_put(ctx->sclk_fimc_clk);<br>
>> -       clk_put(ctx->fimc_clk);<br>>> -       clk_put(ctx->wb_clk);<br>>> -       clk_put(ctx->wb_b_clk);<br>>> -<br>>>         return 0;<br>>>  }<br>>><br>>> --<br>
>> 1.7.4.1<br>>><br>>> _______________________________________________<br>>> dri-devel mailing list<br>>> <a href="mailto:dri-devel@lists.freedesktop.org">dri-devel@lists.freedesktop.org</a><br>
>> <a href="http://lists.freedesktop.org/mailman/listinfo/dri-devel">http://lists.freedesktop.org/mailman/listinfo/dri-devel</a><br>><br>><br><br>-- <br><div>With warm regards,</div>
<div>Sachin</div><br>