aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/rtc/rtc-s3c.c
diff options
context:
space:
mode:
authorJoonyoung Shim <jy0922.shim@samsung.com>2015-08-11 07:28:19 -0400
committerAlexandre Belloni <alexandre.belloni@free-electrons.com>2015-09-05 07:19:13 -0400
commit7f23a93661eb5caa373f75a145cec14331a8caaa (patch)
treef2acdd2523cc889cc7e0c778addeccc8fab787c8 /drivers/rtc/rtc-s3c.c
parent1fb1c35f56bb6ab4a65920c648154b0f78f634a5 (diff)
rtc: s3c: add missing clk control
It's missed to call clk_unprepare() about info->rtc_src_clk in s3c_rtc_remove and to call clk_disable_unprepare about info->rtc_clk in error routine of s3c_rtc_probe. Signed-off-by: Joonyoung Shim <jy0922.shim@samsung.com> Reviewed-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
Diffstat (limited to 'drivers/rtc/rtc-s3c.c')
-rw-r--r--drivers/rtc/rtc-s3c.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/rtc/rtc-s3c.c b/drivers/rtc/rtc-s3c.c
index 2e709e239dbc..3ee961529b5b 100644
--- a/drivers/rtc/rtc-s3c.c
+++ b/drivers/rtc/rtc-s3c.c
@@ -422,6 +422,8 @@ static int s3c_rtc_remove(struct platform_device *pdev)
422 422
423 s3c_rtc_setaie(info->dev, 0); 423 s3c_rtc_setaie(info->dev, 0);
424 424
425 if (info->data->needs_src_clk)
426 clk_unprepare(info->rtc_src_clk);
425 clk_unprepare(info->rtc_clk); 427 clk_unprepare(info->rtc_clk);
426 info->rtc_clk = NULL; 428 info->rtc_clk = NULL;
427 429
@@ -494,6 +496,7 @@ static int s3c_rtc_probe(struct platform_device *pdev)
494 if (IS_ERR(info->rtc_src_clk)) { 496 if (IS_ERR(info->rtc_src_clk)) {
495 dev_err(&pdev->dev, 497 dev_err(&pdev->dev,
496 "failed to find rtc source clock\n"); 498 "failed to find rtc source clock\n");
499 clk_disable_unprepare(info->rtc_clk);
497 return PTR_ERR(info->rtc_src_clk); 500 return PTR_ERR(info->rtc_src_clk);
498 } 501 }
499 clk_prepare_enable(info->rtc_src_clk); 502 clk_prepare_enable(info->rtc_src_clk);