From: Tony Lindgren <tony@atomide.com>
To: Tero Kristo <t-kristo@ti.com>
Cc: linux-omap@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
Mike Turquette <mturquette@linaro.org>,
Paul Walmsley <paul@pwsan.com>,
Mark Rutland <mark.rutland@arm.com>,
Peter Ujfalusi <peter.ujfalusi@ti.com>,
Jyri Sarha <jsarha@ti.com>, Stefan Assmann <sassmann@kpanic.de>
Subject: Re: [PATCH] clk: ti: change clock init to use generic of_clk_init
Date: Thu, 18 Sep 2014 10:17:26 -0700 [thread overview]
Message-ID: <20140918171725.GL14505@atomide.com> (raw)
In-Reply-To: <1408628959-32442-1-git-send-email-t-kristo@ti.com>
* Tero Kristo <t-kristo@ti.com> [140821 06:52]:
> Previously, the TI clock driver initialized all the clocks hierarchically
> under each separate clock provider node. Now, each clock that requires
> IO access will instead check their parent node to find out which IO range
> to use.
>
> This patch allows the TI clock driver to use a few new features provided
> by the generic of_clk_init, and also allows registration of clock nodes
> outside the clock hierarchy (for example, any external clocks.)
Paul, any comments on this one?
Regards,
Tony
> Signed-off-by: Tero Kristo <t-kristo@ti.com>
> Cc: Mike Turquette <mturquette@linaro.org>
> Cc: Paul Walmsley <paul@pwsan.com>
> Cc: Tony Lindgren <tony@atomide.com>
> Cc: Mark Rutland <mark.rutland@arm.com>
> Cc: Peter Ujfalusi <peter.ujfalusi@ti.com>
> Cc: Jyri Sarha <jsarha@ti.com>
> Cc: Stefan Assmann <sassmann@kpanic.de>
> ---
> arch/arm/mach-omap2/io.c | 10 ++++++++--
> arch/arm/mach-omap2/prm_common.c | 2 --
> drivers/clk/ti/clk.c | 31 ++++++++++++++++---------------
> 3 files changed, 24 insertions(+), 19 deletions(-)
>
> diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c
> index 5d0667c..3325df6 100644
> --- a/arch/arm/mach-omap2/io.c
> +++ b/arch/arm/mach-omap2/io.c
> @@ -734,8 +734,14 @@ int __init omap_clk_init(void)
> ti_clk_init_features();
>
> ret = of_prcm_init();
> - if (!ret)
> - ret = omap_clk_soc_init();
> + if (ret)
> + return ret;
> +
> + of_clk_init(NULL);
> +
> + ti_dt_clockdomains_setup();
> +
> + ret = omap_clk_soc_init();
>
> return ret;
> }
> diff --git a/arch/arm/mach-omap2/prm_common.c b/arch/arm/mach-omap2/prm_common.c
> index 76ca320..3b89080 100644
> --- a/arch/arm/mach-omap2/prm_common.c
> +++ b/arch/arm/mach-omap2/prm_common.c
> @@ -525,8 +525,6 @@ int __init of_prcm_init(void)
> memmap_index++;
> }
>
> - ti_dt_clockdomains_setup();
> -
> return 0;
> }
>
> diff --git a/drivers/clk/ti/clk.c b/drivers/clk/ti/clk.c
> index b1a6f71..f7201d0 100644
> --- a/drivers/clk/ti/clk.c
> +++ b/drivers/clk/ti/clk.c
> @@ -25,8 +25,8 @@
> #undef pr_fmt
> #define pr_fmt(fmt) "%s: " fmt, __func__
>
> -static int ti_dt_clk_memmap_index;
> struct ti_clk_ll_ops *ti_clk_ll_ops;
> +static struct device_node *clocks_node_ptr[CLK_MAX_MEMMAPS];
>
> /**
> * ti_dt_clocks_register - register DT alias clocks during boot
> @@ -108,9 +108,21 @@ void __iomem *ti_clk_get_reg_addr(struct device_node *node, int index)
> struct clk_omap_reg *reg;
> u32 val;
> u32 tmp;
> + int i;
>
> reg = (struct clk_omap_reg *)&tmp;
> - reg->index = ti_dt_clk_memmap_index;
> +
> + for (i = 0; i < CLK_MAX_MEMMAPS; i++) {
> + if (clocks_node_ptr[i] == node->parent)
> + break;
> + }
> +
> + if (i == CLK_MAX_MEMMAPS) {
> + pr_err("clk-provider not found for %s!\n", node->name);
> + return NULL;
> + }
> +
> + reg->index = i;
>
> if (of_property_read_u32_index(node, "reg", index, &val)) {
> pr_err("%s must have reg[%d]!\n", node->name, index);
> @@ -133,15 +145,10 @@ void __iomem *ti_clk_get_reg_addr(struct device_node *node, int index)
> */
> void ti_dt_clk_init_provider(struct device_node *parent, int index)
> {
> - const struct of_device_id *match;
> - struct device_node *np;
> struct device_node *clocks;
> - of_clk_init_cb_t clk_init_cb;
> struct clk_init_item *retry;
> struct clk_init_item *tmp;
>
> - ti_dt_clk_memmap_index = index;
> -
> /* get clocks for this parent */
> clocks = of_get_child_by_name(parent, "clocks");
> if (!clocks) {
> @@ -149,14 +156,8 @@ void ti_dt_clk_init_provider(struct device_node *parent, int index)
> return;
> }
>
> - for_each_child_of_node(clocks, np) {
> - match = of_match_node(&__clk_of_table, np);
> - if (!match)
> - continue;
> - clk_init_cb = (of_clk_init_cb_t)match->data;
> - pr_debug("%s: initializing: %s\n", __func__, np->name);
> - clk_init_cb(np);
> - }
> + /* add clocks node info */
> + clocks_node_ptr[index] = clocks;
>
> list_for_each_entry_safe(retry, tmp, &retry_list, link) {
> pr_debug("retry-init: %s\n", retry->node->name);
> --
> 1.7.9.5
>
WARNING: multiple messages have this Message-ID (diff)
From: tony@atomide.com (Tony Lindgren)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH] clk: ti: change clock init to use generic of_clk_init
Date: Thu, 18 Sep 2014 10:17:26 -0700 [thread overview]
Message-ID: <20140918171725.GL14505@atomide.com> (raw)
In-Reply-To: <1408628959-32442-1-git-send-email-t-kristo@ti.com>
* Tero Kristo <t-kristo@ti.com> [140821 06:52]:
> Previously, the TI clock driver initialized all the clocks hierarchically
> under each separate clock provider node. Now, each clock that requires
> IO access will instead check their parent node to find out which IO range
> to use.
>
> This patch allows the TI clock driver to use a few new features provided
> by the generic of_clk_init, and also allows registration of clock nodes
> outside the clock hierarchy (for example, any external clocks.)
Paul, any comments on this one?
Regards,
Tony
> Signed-off-by: Tero Kristo <t-kristo@ti.com>
> Cc: Mike Turquette <mturquette@linaro.org>
> Cc: Paul Walmsley <paul@pwsan.com>
> Cc: Tony Lindgren <tony@atomide.com>
> Cc: Mark Rutland <mark.rutland@arm.com>
> Cc: Peter Ujfalusi <peter.ujfalusi@ti.com>
> Cc: Jyri Sarha <jsarha@ti.com>
> Cc: Stefan Assmann <sassmann@kpanic.de>
> ---
> arch/arm/mach-omap2/io.c | 10 ++++++++--
> arch/arm/mach-omap2/prm_common.c | 2 --
> drivers/clk/ti/clk.c | 31 ++++++++++++++++---------------
> 3 files changed, 24 insertions(+), 19 deletions(-)
>
> diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c
> index 5d0667c..3325df6 100644
> --- a/arch/arm/mach-omap2/io.c
> +++ b/arch/arm/mach-omap2/io.c
> @@ -734,8 +734,14 @@ int __init omap_clk_init(void)
> ti_clk_init_features();
>
> ret = of_prcm_init();
> - if (!ret)
> - ret = omap_clk_soc_init();
> + if (ret)
> + return ret;
> +
> + of_clk_init(NULL);
> +
> + ti_dt_clockdomains_setup();
> +
> + ret = omap_clk_soc_init();
>
> return ret;
> }
> diff --git a/arch/arm/mach-omap2/prm_common.c b/arch/arm/mach-omap2/prm_common.c
> index 76ca320..3b89080 100644
> --- a/arch/arm/mach-omap2/prm_common.c
> +++ b/arch/arm/mach-omap2/prm_common.c
> @@ -525,8 +525,6 @@ int __init of_prcm_init(void)
> memmap_index++;
> }
>
> - ti_dt_clockdomains_setup();
> -
> return 0;
> }
>
> diff --git a/drivers/clk/ti/clk.c b/drivers/clk/ti/clk.c
> index b1a6f71..f7201d0 100644
> --- a/drivers/clk/ti/clk.c
> +++ b/drivers/clk/ti/clk.c
> @@ -25,8 +25,8 @@
> #undef pr_fmt
> #define pr_fmt(fmt) "%s: " fmt, __func__
>
> -static int ti_dt_clk_memmap_index;
> struct ti_clk_ll_ops *ti_clk_ll_ops;
> +static struct device_node *clocks_node_ptr[CLK_MAX_MEMMAPS];
>
> /**
> * ti_dt_clocks_register - register DT alias clocks during boot
> @@ -108,9 +108,21 @@ void __iomem *ti_clk_get_reg_addr(struct device_node *node, int index)
> struct clk_omap_reg *reg;
> u32 val;
> u32 tmp;
> + int i;
>
> reg = (struct clk_omap_reg *)&tmp;
> - reg->index = ti_dt_clk_memmap_index;
> +
> + for (i = 0; i < CLK_MAX_MEMMAPS; i++) {
> + if (clocks_node_ptr[i] == node->parent)
> + break;
> + }
> +
> + if (i == CLK_MAX_MEMMAPS) {
> + pr_err("clk-provider not found for %s!\n", node->name);
> + return NULL;
> + }
> +
> + reg->index = i;
>
> if (of_property_read_u32_index(node, "reg", index, &val)) {
> pr_err("%s must have reg[%d]!\n", node->name, index);
> @@ -133,15 +145,10 @@ void __iomem *ti_clk_get_reg_addr(struct device_node *node, int index)
> */
> void ti_dt_clk_init_provider(struct device_node *parent, int index)
> {
> - const struct of_device_id *match;
> - struct device_node *np;
> struct device_node *clocks;
> - of_clk_init_cb_t clk_init_cb;
> struct clk_init_item *retry;
> struct clk_init_item *tmp;
>
> - ti_dt_clk_memmap_index = index;
> -
> /* get clocks for this parent */
> clocks = of_get_child_by_name(parent, "clocks");
> if (!clocks) {
> @@ -149,14 +156,8 @@ void ti_dt_clk_init_provider(struct device_node *parent, int index)
> return;
> }
>
> - for_each_child_of_node(clocks, np) {
> - match = of_match_node(&__clk_of_table, np);
> - if (!match)
> - continue;
> - clk_init_cb = (of_clk_init_cb_t)match->data;
> - pr_debug("%s: initializing: %s\n", __func__, np->name);
> - clk_init_cb(np);
> - }
> + /* add clocks node info */
> + clocks_node_ptr[index] = clocks;
>
> list_for_each_entry_safe(retry, tmp, &retry_list, link) {
> pr_debug("retry-init: %s\n", retry->node->name);
> --
> 1.7.9.5
>
next prev parent reply other threads:[~2014-09-18 17:17 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-08-21 13:49 [PATCH] clk: ti: change clock init to use generic of_clk_init Tero Kristo
2014-08-21 13:49 ` Tero Kristo
2014-08-27 15:15 ` Jyri Sarha
2014-08-27 15:15 ` Jyri Sarha
2014-09-18 17:17 ` Tony Lindgren [this message]
2014-09-18 17:17 ` Tony Lindgren
2014-09-19 16:33 ` Paul Walmsley
2014-09-19 16:33 ` Paul Walmsley
2014-09-22 6:52 ` Tero Kristo
2014-09-22 6:52 ` Tero Kristo
2014-09-22 7:55 ` Tero Kristo
2014-09-22 7:55 ` Tero Kristo
2014-09-23 15:49 ` Tony Lindgren
2014-09-23 15:49 ` Tony Lindgren
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140918171725.GL14505@atomide.com \
--to=tony@atomide.com \
--cc=jsarha@ti.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-omap@vger.kernel.org \
--cc=mark.rutland@arm.com \
--cc=mturquette@linaro.org \
--cc=paul@pwsan.com \
--cc=peter.ujfalusi@ti.com \
--cc=sassmann@kpanic.de \
--cc=t-kristo@ti.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.