Merge branches 'clk-mediatek', 'clk-sunplus', 'clk-loongson' and 'clk-socfpga' into...
[linux-block.git] / drivers / clk / mediatek / clk-pllfh.c
index 7b6e051443f4887f205d44b06933656f9b7a49f4..3a2b3f90be25d5925a19890c82823784791dd70a 100644 (file)
@@ -75,13 +75,13 @@ void fhctl_parse_dt(const u8 *compatible_node, struct mtk_pllfh_data *pllfhs,
        base = of_iomap(node, 0);
        if (!base) {
                pr_err("%s(): ioremap failed\n", __func__);
-               return;
+               goto out_node_put;
        }
 
        num_clocks = of_clk_get_parent_count(node);
        if (!num_clocks) {
                pr_err("%s(): failed to get clocks property\n", __func__);
-               return;
+               goto err;
        }
 
        for (i = 0; i < num_clocks; i++) {
@@ -102,6 +102,13 @@ void fhctl_parse_dt(const u8 *compatible_node, struct mtk_pllfh_data *pllfhs,
                pllfh->state.ssc_rate = ssc_rate;
                pllfh->state.base = base;
        }
+
+out_node_put:
+       of_node_put(node);
+       return;
+err:
+       iounmap(base);
+       goto out_node_put;
 }
 EXPORT_SYMBOL_GPL(fhctl_parse_dt);