In case of error at init time, rollback iomapping and unprepare clk.

Signed-off-by: Arvind Yadav <[email protected]>
---
 drivers/clocksource/timer-u300.c | 21 +++++++++++++++------
 1 file changed, 15 insertions(+), 6 deletions(-)

diff --git a/drivers/clocksource/timer-u300.c b/drivers/clocksource/timer-u300.c
index 704e40c..e3b29ae 100644
--- a/drivers/clocksource/timer-u300.c
+++ b/drivers/clocksource/timer-u300.c
@@ -376,19 +376,22 @@ static int __init u300_timer_init_of(struct device_node 
*np)
        irq = irq_of_parse_and_map(np, 2);
        if (!irq) {
                pr_err("no IRQ for system timer\n");
-               return -EINVAL;
+               ret = -EINVAL;
+               goto err_iounmap;
        }
 
        pr_info("U300 GP1 timer @ base: %p, IRQ: %u\n", u300_timer_base, irq);
 
        /* Clock the interrupt controller */
        clk = of_clk_get(np, 0);
-       if (IS_ERR(clk))
-               return PTR_ERR(clk);
+       if (IS_ERR(clk)) {
+               ret = PTR_ERR(clk);
+               goto err_iounmap;
+       }
 
        ret = clk_prepare_enable(clk);
        if (ret)
-               return ret;
+               goto err_iounmap;
 
        rate = clk_get_rate(clk);
 
@@ -422,7 +425,7 @@ static int __init u300_timer_init_of(struct device_node *np)
        /* Set up the IRQ handler */
        ret = setup_irq(irq, &u300_timer_irq);
        if (ret)
-               return ret;
+               goto err_unprepare;
 
        /* Reset the General Purpose timer 2 */
        writel(U300_TIMER_APP_RGPT2_TIMER_RESET,
@@ -444,7 +447,7 @@ static int __init u300_timer_init_of(struct device_node *np)
                                    "GPT2", rate, 300, 32, 
clocksource_mmio_readl_up);
        if (ret) {
                pr_err("timer: failed to initialize U300 clock source\n");
-               return ret;
+               goto err_unprepare;
        }
 
        /* Configure and register the clockevent */
@@ -456,6 +459,12 @@ static int __init u300_timer_init_of(struct device_node 
*np)
         * used by hrtimers!
         */
        return 0;
+
+err_unprepare:
+       clk_disable_unprepare(clk);
+err_iounmap:
+       iounmap(u300_timer_base);
+       return ret;
 }
 
 CLOCKSOURCE_OF_DECLARE(u300_timer, "stericsson,u300-apptimer",
-- 
1.9.1

Reply via email to