Skip to content

Commit

Permalink
clk: prima2: declare OF clock provider
Browse files Browse the repository at this point in the history
Common clock framework allows to register clock providers to get called
on of_clk_init() by using CLK_OF_DECLARE. This converts prima2 clock
provider to make use of it and get rid of the mach specific clk init
call.

Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
Acked-by: Barry Song <baohua.song@csr.com>
Acked-by: Mike Turquette <mturquette@linaro.org>
  • Loading branch information
Sebastian Hesselbarth committed Sep 29, 2013
1 parent 74227e6 commit 27966ff
Show file tree
Hide file tree
Showing 3 changed files with 8 additions and 26 deletions.
4 changes: 2 additions & 2 deletions arch/arm/mach-prima2/common.c
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
* Licensed under GPLv2 or later.
*/

#include <linux/clk-provider.h>
#include <linux/clocksource.h>
#include <linux/init.h>
#include <linux/kernel.h>
Expand All @@ -23,8 +24,7 @@ void __init sirfsoc_init_late(void)

static __init void sirfsoc_init_time(void)
{
/* initialize clocking early, we want to set the OS timer */
sirfsoc_of_clk_init();
of_clk_init(NULL);
clocksource_of_init();
}

Expand Down
1 change: 0 additions & 1 deletion arch/arm/mach-prima2/common.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ extern void sirfsoc_secondary_startup(void);
extern void sirfsoc_cpu_die(unsigned int cpu);

extern void __init sirfsoc_of_irq_init(void);
extern void __init sirfsoc_of_clk_init(void);
extern void sirfsoc_restart(enum reboot_mode, const char *);
extern asmlinkage void __exception_irq_entry sirfsoc_handle_irq(struct pt_regs *regs);

Expand Down
29 changes: 6 additions & 23 deletions drivers/clk/clk-prima2.c
Original file line number Diff line number Diff line change
Expand Up @@ -1015,16 +1015,6 @@ static struct clk_std clk_usb1 = {
},
};

static struct of_device_id clkc_ids[] = {
{ .compatible = "sirf,prima2-clkc" },
{},
};

static struct of_device_id rsc_ids[] = {
{ .compatible = "sirf,prima2-rsc" },
{},
};

enum prima2_clk_index {
/* 0 1 2 3 4 5 6 7 8 9 */
rtc, osc, pll1, pll2, pll3, mem, sys, security, dsp, gps,
Expand Down Expand Up @@ -1082,24 +1072,16 @@ static struct clk_hw *prima2_clk_hw_array[maxclk] __initdata = {
static struct clk *prima2_clks[maxclk];
static struct clk_onecell_data clk_data;

void __init sirfsoc_of_clk_init(void)
static void __init sirfsoc_clk_init(struct device_node *np)
{
struct device_node *np;
struct device_node *rscnp;
int i;

np = of_find_matching_node(NULL, rsc_ids);
if (!np)
panic("unable to find compatible rsc node in dtb\n");

sirfsoc_rsc_vbase = of_iomap(np, 0);
rscnp = of_find_compatible_node(NULL, NULL, "sirf,prima2-rsc");
sirfsoc_rsc_vbase = of_iomap(rscnp, 0);
if (!sirfsoc_rsc_vbase)
panic("unable to map rsc registers\n");

of_node_put(np);

np = of_find_matching_node(NULL, clkc_ids);
if (!np)
return;
of_node_put(rscnp);

sirfsoc_clk_vbase = of_iomap(np, 0);
if (!sirfsoc_clk_vbase)
Expand All @@ -1124,3 +1106,4 @@ void __init sirfsoc_of_clk_init(void)

of_clk_add_provider(np, of_clk_src_onecell_get, &clk_data);
}
CLK_OF_DECLARE(sirfsoc_clk, "sirf,prima2-clkc", sirfsoc_clk_init);

0 comments on commit 27966ff

Please sign in to comment.