From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756290AbdESSMU convert rfc822-to-8bit (ORCPT ); Fri, 19 May 2017 14:12:20 -0400 Received: from hermes.aosc.io ([199.195.250.187]:55716 "EHLO hermes.aosc.io" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756170AbdESSKx (ORCPT ); Fri, 19 May 2017 14:10:53 -0400 Date: Sat, 20 May 2017 02:10:35 +0800 In-Reply-To: <20170519180616.vzrlu2avuucsjkiu@flea.home> References: <20170517164354.16399-1-icenowy@aosc.io> <20170517164354.16399-11-icenowy@aosc.io> <20170519180616.vzrlu2avuucsjkiu@flea.home> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8BIT Subject: Re: [linux-sunxi] Re: [RFC PATCH 10/11] ARM: sun8i: h3: add display engine pipeline for TVE To: maxime.ripard@free-electrons.com, Maxime Ripard CC: Rob Herring , Chen-Yu Tsai , dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-clk@vger.kernel.org, linux-sunxi@googlegroups.com From: Icenowy Zheng Message-ID: Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 于 2017年5月20日 GMT+08:00 上午2:06:16, Maxime Ripard 写到: >On Thu, May 18, 2017 at 12:43:53AM +0800, Icenowy Zheng wrote: >> As we have already the support for the TV encoder on Allwinner H3, >add >> the display engine pipeline device tree nodes to its DTSI file. >> >> The H5 pipeline has some differences and will be enabled later. >> >> The currently-unused mixer0 and tcon0 are also needed, for the >> completement of the pipeline. >> >> Signed-off-by: Icenowy Zheng >> --- >> arch/arm/boot/dts/sun8i-h3.dtsi | 189 >++++++++++++++++++++++++++++++++++++++++ >> 1 file changed, 189 insertions(+) >> >> diff --git a/arch/arm/boot/dts/sun8i-h3.dtsi >b/arch/arm/boot/dts/sun8i-h3.dtsi >> index b36f9f423c39..20172ef92415 100644 >> --- a/arch/arm/boot/dts/sun8i-h3.dtsi >> +++ b/arch/arm/boot/dts/sun8i-h3.dtsi >> @@ -41,6 +41,8 @@ >> */ >> >> #include "sunxi-h3-h5.dtsi" >> +#include >> +#include >> >> / { >> cpus { >> @@ -72,6 +74,193 @@ >> }; >> }; >> >> + de: display-engine { >> + compatible = "allwinner,sun8i-h3-display-engine"; >> + allwinner,pipelines = <&mixer0>, >> + <&mixer1>; >> + status = "disabled"; >> + }; >> + >> + soc { >> + display_clocks: clock@1000000 { >> + compatible = "allwinner,sun8i-a83t-de2-clk"; >> + reg = <0x01000000 0x100000>; >> + clocks = <&ccu CLK_BUS_DE>, >> + <&ccu CLK_DE>; >> + clock-names = "bus", >> + "mod"; >> + resets = <&ccu RST_BUS_DE>; >> + #clock-cells = <1>; >> + #reset-cells = <1>; >> + assigned-clocks = <&ccu CLK_DE>; >> + assigned-clock-parents = <&ccu CLK_PLL_DE>; >> + assigned-clock-rates = <432000000>; > >This shouldn't be set in the DT, but evaluated at runtime when calling >clk_set_rate. Nope, DE2 clock doesn't need evalution, as the clock is decoupled with DE2 mixers' output signal. (Although it seems that SoCs with larger plane size will use higher clock.) And setting it to 432MHz is also needed for properly 216MHz clock to TVE. > >> + tve0: tv-encoder@1e00000 { >> + compatible = "allwinner,sun8i-h3-tv-encoder"; >> + reg = <0x01e00000 0x1000>; >> + clocks = <&ccu CLK_BUS_TVE>, <&ccu CLK_TVE>; >> + clock-names = "bus", "mod"; >> + resets = <&ccu RST_BUS_TVE>; >> + status = "disabled"; >> + >> + assigned-clocks = <&ccu CLK_TVE>; >> + assigned-clock-parents = <&ccu CLK_PLL_DE>; > >Same thing here. clk_set_rate should just do the right thing. > >> + assigned-clock-rates = <216000000>; > >And why are you setting it in the driver and in the DT? > >Maxime