clk: hisilicon: add hisi_clk_alloc function.
authorJiancheng Xue <xuejiancheng@hisilicon.com>
Wed, 15 Jun 2016 06:26:35 +0000 (14:26 +0800)
committerStephen Boyd <sboyd@codeaurora.org>
Thu, 30 Jun 2016 19:34:19 +0000 (12:34 -0700)
Before, there was an ordering issue that the clock provider
had been published in hisi_clk_init before it could provide
valid clocks to consumers. hisi_clk_alloc is just used to
allocate memory space for struct hisi_clock_data. It makes
it possible to publish the provider after the clocks are ready.

Signed-off-by: Jiancheng Xue <xuejiancheng@hisilicon.com>
Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
drivers/clk/hisilicon/clk.c
drivers/clk/hisilicon/clk.h

index 9b15adbfc30c3daa93f31785dffebf600b3f4659..78675d172a658249ab05211565dca5229ffd5800 100644 (file)
 
 static DEFINE_SPINLOCK(hisi_clk_lock);
 
+struct hisi_clock_data *hisi_clk_alloc(struct platform_device *pdev,
+                                               int nr_clks)
+{
+       struct hisi_clock_data *clk_data;
+       struct resource *res;
+       struct clk **clk_table;
+
+       clk_data = devm_kmalloc(&pdev->dev, sizeof(*clk_data), GFP_KERNEL);
+       if (!clk_data)
+               return NULL;
+
+       res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
+       clk_data->base = devm_ioremap(&pdev->dev,
+                               res->start, resource_size(res));
+       if (!clk_data->base)
+               return NULL;
+
+       clk_table = devm_kmalloc(&pdev->dev, sizeof(struct clk *) * nr_clks,
+                               GFP_KERNEL);
+       if (!clk_table)
+               return NULL;
+
+       clk_data->clk_data.clks = clk_table;
+       clk_data->clk_data.clk_num = nr_clks;
+
+       return clk_data;
+}
+EXPORT_SYMBOL_GPL(hisi_clk_alloc);
+
 struct hisi_clock_data *hisi_clk_init(struct device_node *np,
                                             int nr_clks)
 {
index 20d64afe4ad8413b30c52383f24e82bafe3e9529..5fc644f4799fbdfeb385d7c2b1d85d5fc92df2ac 100644 (file)
@@ -30,6 +30,8 @@
 #include <linux/io.h>
 #include <linux/spinlock.h>
 
+struct platform_device;
+
 struct hisi_clock_data {
        struct clk_onecell_data clk_data;
        void __iomem            *base;
@@ -110,6 +112,7 @@ struct clk *hi6220_register_clkdiv(struct device *dev, const char *name,
        const char *parent_name, unsigned long flags, void __iomem *reg,
        u8 shift, u8 width, u32 mask_bit, spinlock_t *lock);
 
+struct hisi_clock_data *hisi_clk_alloc(struct platform_device *, int);
 struct hisi_clock_data *hisi_clk_init(struct device_node *, int);
 void hisi_clk_register_fixed_rate(const struct hisi_fixed_rate_clock *,
                                int, struct hisi_clock_data *);