All of lore.kernel.org
 help / color / mirror / Atom feed
From: Mike Turquette <mturquette@linaro.org>
To: Tero Kristo <t-kristo@ti.com>,
	linux-omap@vger.kernel.org, paul@pwsan.com, tony@atomide.com,
	nm@ti.com, rnayak@ti.com, bcousson@baylibre.com
Cc: linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org
Subject: Re: [PATCHv10 00/41] ARM: TI SoC clock DT conversion
Date: Sat, 14 Dec 2013 20:35:47 -0800	[thread overview]
Message-ID: <20131215043547.23538.63736@quantum> (raw)
In-Reply-To: <1385453182-24421-1-git-send-email-t-kristo@ti.com>

Quoting Tero Kristo (2013-11-26 00:05:41)
> Hi,
> 

Hi Tero,

Thanks for your long suffering patience on this series. The clock
patches look very good to me with exception of a few small comments. Let
me know how I can help with the hierarchal DT stuff since I think that
has been the gating factor for this series for the past few revisions.

> Changes compared to v9:
> - rebased on top of 3.13-rc1
> - modified the low level clk register API to provide SoC specific clk_readl
>   and clk_writel support which can be registered during boot, TI SoC variant
>   uses regmap on low level

Regarding regmap, will that be dropped for V11? I don't care whether it
stays or goes but the approach you took is probably too top-level. Patch
#1 sets clk_reg_ops system-wide which probably isn't right. Different
clock drivers might compete to set those ops and the last one to write
wins.

A better approach is to support regmap ops on a per-clock basis (for
clocks that use the generic implementations like clk-divider and
clk-gate; obviously this is overkill for entirely hardware-specific
clocks). Stephen Boyd's approach is a better solution[1][2] but
unfortunately that approach dumps crap into struct clk_hw which is bad.

Anyways if you decide against regmap for V11 then the whole issue is
avoided.

Regards,
Mike

[1] http://article.gmane.org/gmane.linux.ports.arm.kernel/273742
[2] http://article.gmane.org/gmane.linux.ports.arm.kernel/273744

> - dropped regmap parameter from clock init calls, instead a helper is used
>   for getting regmap index along with the register offset from DT
> - dropped regmap parameter from clock structs, instead platform specific
>   clk_readl / clk_writel are used to parse reg parameter according to
>   platform, for TI SoC:s, this is encoded as:
>   struct clk_omap_reg {
>     u16 offset; /* register offset */
>     u16 index; /* regmap index */
>   }
> - Nishanth's comments to v9 mostly addressed, except for the CLK_OF_DECLARE
>   tweak which I would actually want some feedback upon, basically the problem
>   is I need to return status from the clk init functions so I can see if
>   -EAGAIN is passed, in which case init will be retried later, maybe some of
>   this can be made generic, like converting all the CLK_OF_DECLARE type
>   functions to return status
> 
> Testing done:
> - omap3-beagle : boot + suspend/resume
> - omap3-beagle-xm : boot (thanks to Nishanth)
> - omap4-panda-es : boot + suspend/resume
> - omap5-uevm : boot
> - dra7-evm : boot
> - am335x-bone : boot
> 
> Separate branches available at https://github.com/t-kristo/linux-pm.git
> 
> - full: 3.13-rc1-dt-clks-v10 (should be merged last, contains everything)
> - clk driver only: 3.13-rc1-dt-clks-v10-for-mike
> - DT data only: 3.13-rc1-dt-clks-v10-for-benoit
> 
> -Tero
> 

WARNING: multiple messages have this Message-ID (diff)
From: mturquette@linaro.org (Mike Turquette)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCHv10 00/41] ARM: TI SoC clock DT conversion
Date: Sat, 14 Dec 2013 20:35:47 -0800	[thread overview]
Message-ID: <20131215043547.23538.63736@quantum> (raw)
In-Reply-To: <1385453182-24421-1-git-send-email-t-kristo@ti.com>

Quoting Tero Kristo (2013-11-26 00:05:41)
> Hi,
> 

Hi Tero,

Thanks for your long suffering patience on this series. The clock
patches look very good to me with exception of a few small comments. Let
me know how I can help with the hierarchal DT stuff since I think that
has been the gating factor for this series for the past few revisions.

> Changes compared to v9:
> - rebased on top of 3.13-rc1
> - modified the low level clk register API to provide SoC specific clk_readl
>   and clk_writel support which can be registered during boot, TI SoC variant
>   uses regmap on low level

Regarding regmap, will that be dropped for V11? I don't care whether it
stays or goes but the approach you took is probably too top-level. Patch
#1 sets clk_reg_ops system-wide which probably isn't right. Different
clock drivers might compete to set those ops and the last one to write
wins.

A better approach is to support regmap ops on a per-clock basis (for
clocks that use the generic implementations like clk-divider and
clk-gate; obviously this is overkill for entirely hardware-specific
clocks). Stephen Boyd's approach is a better solution[1][2] but
unfortunately that approach dumps crap into struct clk_hw which is bad.

Anyways if you decide against regmap for V11 then the whole issue is
avoided.

Regards,
Mike

[1] http://article.gmane.org/gmane.linux.ports.arm.kernel/273742
[2] http://article.gmane.org/gmane.linux.ports.arm.kernel/273744

> - dropped regmap parameter from clock init calls, instead a helper is used
>   for getting regmap index along with the register offset from DT
> - dropped regmap parameter from clock structs, instead platform specific
>   clk_readl / clk_writel are used to parse reg parameter according to
>   platform, for TI SoC:s, this is encoded as:
>   struct clk_omap_reg {
>     u16 offset; /* register offset */
>     u16 index; /* regmap index */
>   }
> - Nishanth's comments to v9 mostly addressed, except for the CLK_OF_DECLARE
>   tweak which I would actually want some feedback upon, basically the problem
>   is I need to return status from the clk init functions so I can see if
>   -EAGAIN is passed, in which case init will be retried later, maybe some of
>   this can be made generic, like converting all the CLK_OF_DECLARE type
>   functions to return status
> 
> Testing done:
> - omap3-beagle : boot + suspend/resume
> - omap3-beagle-xm : boot (thanks to Nishanth)
> - omap4-panda-es : boot + suspend/resume
> - omap5-uevm : boot
> - dra7-evm : boot
> - am335x-bone : boot
> 
> Separate branches available at https://github.com/t-kristo/linux-pm.git
> 
> - full: 3.13-rc1-dt-clks-v10 (should be merged last, contains everything)
> - clk driver only: 3.13-rc1-dt-clks-v10-for-mike
> - DT data only: 3.13-rc1-dt-clks-v10-for-benoit
> 
> -Tero
> 

  parent reply	other threads:[~2013-12-15  4:35 UTC|newest]

Thread overview: 162+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-11-26  8:05 [PATCHv10 00/41] ARM: TI SoC clock DT conversion Tero Kristo
2013-11-26  8:05 ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 01/41] clk: add support for platform specific clock I/O wrapper functions Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-12-15  0:48   ` Mike Turquette
2013-12-15  0:48     ` Mike Turquette
2013-12-16  8:06     ` Tero Kristo
2013-12-16  8:06       ` Tero Kristo
2013-12-17 12:34   ` Paul Walmsley
2013-12-17 12:34     ` Paul Walmsley
2013-12-18  3:33     ` Paul Walmsley
2013-12-18  3:33       ` Paul Walmsley
2013-11-26  8:05 ` [PATCHv10 02/41] CLK: TI: add DT alias clock registration mechanism Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 03/41] CLK: ti: add init support for clock IP blocks Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-12-17  8:14   ` Paul Walmsley
2013-12-17  8:14     ` Paul Walmsley
2013-12-17  8:21     ` Tero Kristo
2013-12-17  8:21       ` Tero Kristo
2013-12-17  8:32       ` Paul Walmsley
2013-12-17  8:32         ` Paul Walmsley
2013-11-26  8:05 ` [PATCHv10 04/41] CLK: TI: Add DPLL clock support Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-12-17  8:37   ` Paul Walmsley
2013-12-17  8:37     ` Paul Walmsley
2013-12-17  8:40   ` Paul Walmsley
2013-12-17  8:40     ` Paul Walmsley
2013-11-26  8:05 ` [PATCHv10 05/41] CLK: TI: add autoidle support Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 06/41] clk: ti: add composite clock support Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 07/41] CLK: ti: add support for ti divider-clock Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 08/41] clk: ti: add support for TI fixed factor clock Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 09/41] CLK: TI: add support for gate clock Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 11/41] clk: ti: add support for basic mux clock Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 12/41] CLK: TI: add omap4 clock init file Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-12-17  9:30   ` Paul Walmsley
2013-12-17  9:30     ` Paul Walmsley
2013-11-26  8:05 ` [PATCHv10 14/41] CLK: TI: omap5: Initialize USB_DPLL at boot Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 15/41] CLK: TI: DRA7: Add APLL support Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:51   ` Alexander Aring
2013-11-26  8:51     ` Alexander Aring
2013-11-29 19:00     ` Tero Kristo
2013-11-29 19:00       ` Tero Kristo
2013-11-29 20:52       ` Alexander Aring
2013-11-29 20:52         ` Alexander Aring
2013-11-26  8:05 ` [PATCHv10 16/41] CLK: TI: add dra7 clock init file Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:05 ` [PATCHv10 17/41] CLK: TI: add am33xx " Tero Kristo
2013-11-26  8:05   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 19/41] CLK: TI: add omap3 " Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 20/41] CLK: TI: add am43xx " Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 21/41] ARM: dts: omap4 clock data Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-12-17  9:44   ` Paul Walmsley
2013-12-17  9:44     ` Paul Walmsley
2013-12-17  9:57     ` Tero Kristo
2013-12-17  9:57       ` Tero Kristo
2013-12-20 11:15       ` Paul Walmsley
2013-12-20 11:15         ` Paul Walmsley
2013-11-26  8:06 ` [PATCHv10 23/41] ARM: dts: dra7 " Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-12-17  9:46   ` Paul Walmsley
2013-12-17  9:46     ` Paul Walmsley
2013-11-26  8:06 ` [PATCHv10 24/41] ARM: dts: clk: Add apll related clocks Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 26/41] ARM: dts: DRA7: Add PCIe related clock nodes Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 27/41] ARM: dts: am33xx clock data Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-12-17  9:48   ` Paul Walmsley
2013-12-17  9:48     ` Paul Walmsley
2013-11-26  8:06 ` [PATCHv10 28/41] ARM: dts: omap3 " Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-12-17  9:50   ` Paul Walmsley
2013-12-17  9:50     ` Paul Walmsley
2013-11-26  8:06 ` [PATCHv10 29/41] ARM: dts: AM35xx: use DT " Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 30/41] ARM: dts: am43xx " Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-12-17  9:52   ` Paul Walmsley
2013-12-17  9:52     ` Paul Walmsley
2013-11-26  8:06 ` [PATCHv10 31/41] ARM: OMAP2+: clock: add support for regmap Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26 17:40   ` Tony Lindgren
2013-11-26 17:40     ` Tony Lindgren
2013-11-27  9:08     ` Tero Kristo
2013-11-27  9:08       ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 32/41] ARM: OMAP2+: clock: use driver API instead of direct memory read/write Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 33/41] ARM: OMAP: hwmod: fix an incorrect clk type cast with _get_clkdm Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 34/41] ARM: OMAP3: hwmod: initialize clkdm from clkdm_name Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 35/41] ARM: OMAP2+: PRM: add support for initializing PRCM clock modules from DT Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 37/41] ARM: OMAP4: remove old clock data and link in new clock init code Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 38/41] ARM: OMAP: DRA7: Enable clock init Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 39/41] ARM: AM43xx: " Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 40/41] ARM: AM33xx: remove old clock data and link in new clock init code Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26  8:06 ` [PATCHv10 41/41] ARM: OMAP3: use DT clock init if DT data is available Tero Kristo
2013-11-26  8:06   ` Tero Kristo
2013-11-26 17:44   ` Tony Lindgren
2013-11-26 17:44     ` Tony Lindgren
2013-11-27  9:06     ` Tero Kristo
2013-11-27  9:06       ` Tero Kristo
2013-11-26 17:57 ` [PATCHv10 00/41] ARM: TI SoC clock DT conversion Tony Lindgren
2013-11-26 17:57   ` Tony Lindgren
     [not found] ` <1385453182-24421-1-git-send-email-t-kristo-l0cyMroinI0@public.gmane.org>
2013-11-26  8:05   ` [PATCHv10 10/41] CLK: TI: add support for clockdomain binding Tero Kristo
2013-11-26  8:05     ` Tero Kristo
2013-12-15  4:23     ` Mike Turquette
2013-12-15  4:23       ` Mike Turquette
2013-12-16  8:13       ` Tero Kristo
2013-12-16  8:13         ` Tero Kristo
2013-12-18  3:07         ` Mike Turquette
2013-12-18  3:07           ` Mike Turquette
2013-11-26  8:05   ` [PATCHv10 13/41] CLK: TI: add omap5 clock init file Tero Kristo
2013-11-26  8:05     ` Tero Kristo
2013-11-26  8:05   ` [PATCHv10 18/41] CLK: TI: add interface clock support for OMAP3 Tero Kristo
2013-11-26  8:05     ` Tero Kristo
2013-11-26  8:06   ` [PATCHv10 22/41] ARM: dts: omap5 clock data Tero Kristo
2013-11-26  8:06     ` Tero Kristo
2013-12-16 10:51     ` Paul Walmsley
2013-12-16 10:51       ` Paul Walmsley
2013-12-16 10:57       ` Tero Kristo
2013-12-16 10:57         ` Tero Kristo
2013-12-17  9:46     ` Paul Walmsley
2013-12-17  9:46       ` Paul Walmsley
2013-11-26  8:06   ` [PATCHv10 25/41] ARM: dts: DRA7: Change apll_pcie_m2_ck to fixed factor clock Tero Kristo
2013-11-26  8:06     ` Tero Kristo
2013-11-26  8:06   ` [PATCHv10 36/41] ARM: OMAP2+: io: use new clock init API Tero Kristo
2013-11-26  8:06     ` Tero Kristo
2013-11-28  0:49   ` [PATCHv10 00/41] ARM: TI SoC clock DT conversion Nishanth Menon
2013-11-28  0:49     ` Nishanth Menon
     [not found]     ` <52969313.6090207-l0cyMroinI0@public.gmane.org>
2013-11-28 18:58       ` Paul Walmsley
2013-11-28 18:58         ` Paul Walmsley
2013-11-29 17:12         ` Tony Lindgren
2013-11-29 17:12           ` Tony Lindgren
2013-11-29 18:59           ` Tero Kristo
2013-11-29 18:59             ` Tero Kristo
2013-12-15  0:51 ` Mike Turquette
2013-12-15  0:51   ` Mike Turquette
2013-12-15  4:35 ` Mike Turquette [this message]
2013-12-15  4:35   ` Mike Turquette
2013-12-16  8:12   ` Tero Kristo
2013-12-16  8:12     ` Tero Kristo
2013-12-20 16:10 ` Felipe Balbi
2013-12-20 16:10   ` Felipe Balbi

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=20131215043547.23538.63736@quantum \
    --to=mturquette@linaro.org \
    --cc=bcousson@baylibre.com \
    --cc=devicetree@vger.kernel.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-omap@vger.kernel.org \
    --cc=nm@ti.com \
    --cc=paul@pwsan.com \
    --cc=rnayak@ti.com \
    --cc=t-kristo@ti.com \
    --cc=tony@atomide.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.