From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752152AbdC0TNi (ORCPT ); Mon, 27 Mar 2017 15:13:38 -0400 Received: from hermes.aosc.io ([172.82.152.187]:59473 "EHLO hermes.aosc.io" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751396AbdC0TNg (ORCPT ); Mon, 27 Mar 2017 15:13:36 -0400 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Date: Tue, 28 Mar 2017 03:13:26 +0800 From: icenowy@aosc.io To: Maxime Ripard Cc: Icenowy Zheng , Rob Herring , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-sunxi@googlegroups.com, devicetree@vger.kernel.org, Chen-Yu Tsai , linux-kernel-owner@vger.kernel.org Subject: Re: [PATCH v2 1/5] dt-bindings: update device tree binding for Allwinner PRCM CCUs In-Reply-To: <20170327134719.g6l3hzbba6cxkhb7@lukather> References: <20170327091147.6B24A7C19A5@relay.mailchannels.net> <20170327134719.g6l3hzbba6cxkhb7@lukather> Message-ID: User-Agent: Roundcube Webmail/1.3-beta Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 在 2017-03-27 21:47,Maxime Ripard 写道: > On Mon, Mar 27, 2017 at 05:11:29PM +0800, Icenowy Zheng wrote: >> >> 2017年3月26日 21:10于 Maxime Ripard 写道: >> > >> > On Thu, Mar 23, 2017 at 07:17:03AM +0800, Icenowy Zheng wrote: >> > > >> > > >> > > 23.03.2017, 04:09, "Maxime Ripard" : >> > > > On Wed, Mar 22, 2017 at 02:22:22AM +0800, Icenowy Zheng wrote: >> > > >>  21.03.2017, 15:41, "Maxime Ripard" : >> > > >>  > On Thu, Mar 16, 2017 at 01:28:04AM +0800, Icenowy Zheng wrote: >> > > >>  >>  Many Allwinner SoCs after A31 have a CCU in PRCM block. >> > > >>  >> >> > > >>  >>  Give the ones on H3 and A64 compatible strings. >> > > >>  >> >> > > >>  >>  Signed-off-by: Icenowy Zheng >> > > >>  >>  --- >> > > >>  >>  Changes in v2: >> > > >>  >>  - Add iosc for R_CCU's on H3/A64. (A31, A23 and A33 seem to have different >> > > >>  >>    clock for mux 3 of ar100 clk. Investgations are needed for them.) >> > > >>  >> >> > > >>  >>   Documentation/devicetree/bindings/clock/sunxi-ccu.txt | 18 +++++++++++++++++- >> > > >>  >>   1 file changed, 17 insertions(+), 1 deletion(-) >> > > >>  >> >> > > >>  >>  diff --git a/Documentation/devicetree/bindings/clock/sunxi-ccu.txt b/Documentation/devicetree/bindings/clock/sunxi-ccu.txt >> > > >>  >>  index 68512aa398a9..4a4addff595d 100644 >> > > >>  >>  --- a/Documentation/devicetree/bindings/clock/sunxi-ccu.txt >> > > >>  >>  +++ b/Documentation/devicetree/bindings/clock/sunxi-ccu.txt >> > > >>  >>  @@ -7,9 +7,11 @@ Required properties : >> > > >>  >>                   - "allwinner,sun8i-a23-ccu" >> > > >>  >>                   - "allwinner,sun8i-a33-ccu" >> > > >>  >>                   - "allwinner,sun8i-h3-ccu" >> > > >>  >>  + - "allwinner,sun8i-h3-r-ccu" >> > > >>  >>                   - "allwinner,sun8i-v3s-ccu" >> > > >>  >>                   - "allwinner,sun9i-a80-ccu" >> > > >>  >>                   - "allwinner,sun50i-a64-ccu" >> > > >>  >>  + - "allwinner,sun50i-a64-r-ccu" >> > > >>  >>                   - "allwinner,sun50i-h5-ccu" >> > > >>  >> >> > > >>  >>   - reg: Must contain the registers base address and length >> > > >>  >>  @@ -20,7 +22,11 @@ Required properties : >> > > >>  >>   - #clock-cells : must contain 1 >> > > >>  >>   - #reset-cells : must contain 1 >> > > >>  >> >> > > >>  >>  -Example: >> > > >>  >>  +For the PRCM CCUs on H3/A64, one more clock is needed: >> > > >>  >>  +- "iosc": another frequency oscillator used for CPUS (usually at 32000Hz, >> > > >>  >>  + not the same with losc) >> > > >>  > >> > > >>  > This is called the internal oscillator in the datasheet, it would >> > > >>  > probably make more sense to call it that way in the documentation too. >> > > >>  > >> > > >>  > This oscillator seems to be clocked at 16MHz, so we should represent >> > > >>  > it as such. >> > > >>  > >> > > >>  > And I'm wondering, are you *sure* that it's fed directly from the >> > > >>  > internal oscillator, or goes through the registers in the RTC, with >> > > >>  > the 32 divider and 16 prescaler by default that makes it at roughly >> > > >>  > the same rate (31.25kHz). >> > > >> >> > > >>  In fact I know nothing about it -- I only represented the code in BSP >> > > >>  clock driver. >> > > >> >> > > >>  The mux value 3 varies from SoC to SoC. For A64/H5 it's 32000, >> > > >>  for A33 it's 667000 (seems to be directly the internal OSC, as the >> > > >>  user manual says the internal OSC is 600~700kHz; but it's named >> > > >>  cpuosc rather than iosc in A33 BSP clock driver); for A80 it's even >> > > >>  PLL_AUDIO. >> > > > >> > > > Where are you getting those info from? >> > > > >> > > > As far as I know, the A33 PRCM takes the hosc, losc, pll6 and CPU >> > > > (internal) oscillator: >> > > > https://github.com/allwinner-zh/linux-3.4-sunxi/blob/master/drivers/clk/sunxi/clk-sun8iw5.c#L508 >> > > > >> > > > The H3 takes the hosc and losc: >> > > > https://github.com/allwinner-zh/linux-3.4-sunxi/blob/master/drivers/clk/sunxi/clk-sun8iw7.c#L379 >> > > > >> > > > The A80 takes the hosc and losc: >> > > > https://github.com/allwinner-zh/linux-3.4-sunxi/blob/master/drivers/clk/sunxi/clk-sun9iw1.c#L281 >> > > > >> > > > The A64 takes the hosc, losc, pll-periph0 and the iosc, which indeed >> > > > seems to be fed from the internal oscillator with the divider in the >> > > > RTC: >> > > > https://github.com/longsleep/linux-pine64/blob/lichee-dev-v3.10.65-bsp2.0/arch/arm64/boot/dts/sun50iw1p1-clk.dtsi#L19 >> > > > https://github.com/longsleep/linux-pine64/blob/lichee-dev-v3.10.65-bsp2.0/drivers/clk/sunxi/clk-sun50iw1.c#L603 >> > > >> > > But then in sunxi_init_clocks function, the iosc clock is initialized >> > > as a fixed clock with 32000Hz. >> > > >> > > The clock node in BSP device tree have a compatible of >> > > allwinner,fixed-clock, but not fixed-clock, which makes it not able >> > > to be really probed. >> > >> > That clock is registered: >> > https://github.com/longsleep/linux-pine64/blob/lichee-dev-v3.10.65-bsp2.0/drivers/clk/sunxi/clk-sun50iw1.c#L1193 >> > >> >> Oh yes, but conflicts exist between the iosc registered in >> clk-sun50iw1.c and described in sun50iw1p1-clk.dtsi . The former is >> 32000, and the latter is 16000000. > > No, it is 16MHz / 32 / 16 = 31.25 kHz > >> What should we do then? >> >> (Maybe it will be better to temporarily ignore this mux, as it's >> difficult to finally find out this correct mux...) > > That is not an option, we will not be able to fix it afterwards. > > What we should do is getting an actual idea of what's going on, and > not just hacking something together hoping it will work. > > You can start by figuring out how the Allwinner clock driver actually > works and / or by trying the various muxing options with something you > can measure the frequency with. The i2c or uart coupled with a scope > or logical analyzer would be a great fit for that. > > Using the PRCM timer is another option and you can measure the > frequency it counts at. The MUX 3 of AR100 is surely Internal OSC on A64/H3/H5. Some measurement done with AR100 (all in Hz): H5 (Orange Pi PC2): 16351952 16347120 16343624 A64 (Pine64+): 11192560 11174128 11174992 H3 (Orange Pi One): 15676016 15625088 15600144 H2+ (Orange Pi Zero): 15907560 15823768 15805144 Seems that on H3/H5 the IOSC is ~16MHz, but on A64 it's... ~12MHz? (Although the usermanual says 16Mhz in the chapter of RTC) Maybe some further investigations should be done on more boards. A fork of ar100-info is at https://github.com/Icenowy/ar100-info/tree/hz-test , which contains IOSC frequency calculation and show in Hz. (and of course H5/A64 support) > > Maxime