Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3939391yba; Tue, 9 Apr 2019 07:53:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqzSAa3+4cAHxATbtfhb0N2NF4plHxR8jziSfbCbNPGWRoHycC/PGvVBtal6dMQJbCFwLxcQ X-Received: by 2002:a17:902:1003:: with SMTP id b3mr36668181pla.306.1554821605983; Tue, 09 Apr 2019 07:53:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554821605; cv=none; d=google.com; s=arc-20160816; b=x5tOm0CEyZ8G3b/yANf6Zr2JwEN09hkvUSlx/d0vaeaHeun8RpdPAFvxIKhXmCv3bY GGIrqCWnodHrPBzRU9F/AuCT4ERVH1xf5lDQci4g6cjXgTTcIBlK3ICqCDeGZOfUBIWi FanSXWgRidaKqL7gG+S1qEj19DOv0H/7+gIvgXqO5O/ee/qdctYS+SPyX9hytU91QPiI XPViCrFpfbk5v3hgFzKV6qPpTwQev/Vw0Ike8Tqij44HvC4bkcF7O0xwB0s8newem7gk WTRz4HL4K/FUvQzJZUQ48Q73B3Pqqe9SdwVzkWcBMDfvehn+5ccn1iOzcfRy+QJodjut 6zCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=pebdDOBtU8AiyDlSWMAdvqUnz8qwBztXT6Ugv5aT3LY=; b=COwmfU18pyQ7ahuUxx0Pfb3fg054n23591BNMoLGS2ct5qtYpH6SjCYO8GOWJIjix5 NqxeySvbHSzaZVhqR8FKbUKrBIgdOwk93J3KN73ddbOSSznB/ZDKlkCeG4xM0GsDOrdY LtxZ+Nw9pFOQObuVwGsQ72amhI/CZ92AjhKrqs9tDgI/rGcg786pDJksq/XVPFiMY+Rj ++e1+Npdx0sL2duHu/CYGhoEtAMEjFhw4n/t5vtHg+wUuBYWW4GFZMLjszrtzbBOAFI5 06eW2/j+a4EqY7/G3HUwHYKFB5ONxG6wFsNpeDNGaD3J1o6jfv2tX02SNqh6kVvjk2IX FYEA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h40si7281805plb.261.2019.04.09.07.53.09; Tue, 09 Apr 2019 07:53:25 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726535AbfDIOwb (ORCPT + 99 others); Tue, 9 Apr 2019 10:52:31 -0400 Received: from relay8-d.mail.gandi.net ([217.70.183.201]:58687 "EHLO relay8-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726240AbfDIOwb (ORCPT ); Tue, 9 Apr 2019 10:52:31 -0400 X-Originating-IP: 90.88.18.121 Received: from localhost (aaubervilliers-681-1-63-121.w90-88.abo.wanadoo.fr [90.88.18.121]) (Authenticated sender: maxime.ripard@bootlin.com) by relay8-d.mail.gandi.net (Postfix) with ESMTPSA id A34D91BF212; Tue, 9 Apr 2019 14:52:25 +0000 (UTC) Date: Tue, 9 Apr 2019 16:52:25 +0200 From: Maxime Ripard To: Chen-Yu Tsai Cc: Michael Turquette , Stephen Boyd , Rob Herring , Mark Rutland , Yong Deng , Mauro Carvalho Chehab , Chen-Yu Tsai , linux-arm-kernel , linux-clk , Linux Media Mailing List , devicetree , linux-kernel , Paul Kocialkowski Subject: Re: [PATCH 4/6] ARM: dts: sun8i: a83t: Add device node for CSI (Camera Sensor Interface) Message-ID: <20190409145225.2ltluiyqa5xha4zd@flea> References: <20190408165744.11672-1-wens@kernel.org> <20190408165744.11672-5-wens@kernel.org> <20190409075804.4zrwjil7ie2gjigu@flea> <20190409082818.z33mq2qrxethldzf@flea> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha256; protocol="application/pgp-signature"; boundary="opeshs6swmdpxgen" Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20180716 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --opeshs6swmdpxgen Content-Type: text/plain; charset=us-ascii Content-Disposition: inline On Tue, Apr 09, 2019 at 04:40:40PM +0800, Chen-Yu Tsai wrote: > On Tue, Apr 9, 2019 at 4:28 PM Maxime Ripard wrote: > > > > On Tue, Apr 09, 2019 at 04:07:34PM +0800, Chen-Yu Tsai wrote: > > > On Tue, Apr 9, 2019 at 3:58 PM Maxime Ripard wrote: > > > > On Tue, Apr 09, 2019 at 12:57:42AM +0800, Chen-Yu Tsai wrote: > > > > > From: Chen-Yu Tsai > > > > > > > > > > The A83T SoC has a camera sensor interface (known as CSI in Allwinner > > > > > lingo), which is similar to the one found on the A64 and H3. The only > > > > > difference seems to be that support of MIPI CSI through a connected > > > > > MIPI CSI-2 bridge. > > > > > > > > > > Add a device node for it, and pinctrl nodes for the commonly used MCLK > > > > > and 8-bit parallel interface. The property /omit-if-no-ref/ is added to > > > > > the pinctrl nodes to keep the device tree blob size down if they are > > > > > unused. > > > > > > > > > > Signed-off-by: Chen-Yu Tsai > > > > > --- > > > > > arch/arm/boot/dts/sun8i-a83t.dtsi | 31 +++++++++++++++++++++++++++++++ > > > > > 1 file changed, 31 insertions(+) > > > > > > > > > > diff --git a/arch/arm/boot/dts/sun8i-a83t.dtsi b/arch/arm/boot/dts/sun8i-a83t.dtsi > > > > > index f739b88efb53..0c52f945fd5f 100644 > > > > > --- a/arch/arm/boot/dts/sun8i-a83t.dtsi > > > > > +++ b/arch/arm/boot/dts/sun8i-a83t.dtsi > > > > > @@ -682,6 +682,20 @@ > > > > > #interrupt-cells = <3>; > > > > > #gpio-cells = <3>; > > > > > > > > > > + /omit-if-no-ref/ > > > > > + csi_8bit_parallel_pins: csi-8bit-parallel-pins { > > > > > + pins = "PE0", "PE2", "PE3", "PE6", "PE7", > > > > > + "PE8", "PE9", "PE10", "PE11", > > > > > + "PE12", "PE13"; > > > > > + function = "csi"; > > > > > + }; > > > > > + > > > > > + /omit-if-no-ref/ > > > > > + csi_mclk_pin: csi-mclk-pin { > > > > > + pins = "PE1"; > > > > > + function = "csi"; > > > > > + }; > > > > > + > > > > > emac_rgmii_pins: emac-rgmii-pins { > > > > > pins = "PD2", "PD3", "PD4", "PD5", "PD6", "PD7", > > > > > "PD11", "PD12", "PD13", "PD14", "PD18", > > > > > @@ -994,6 +1008,23 @@ > > > > > interrupts = ; > > > > > }; > > > > > > > > > > + csi: camera@1cb0000 { > > > > > + compatible = "allwinner,sun8i-a83t-csi"; > > > > > + reg = <0x01cb0000 0x1000>; > > > > > + interrupts = ; > > > > > + clocks = <&ccu CLK_BUS_CSI>, > > > > > + <&ccu CLK_CSI_SCLK>, > > > > > + <&ccu CLK_DRAM_CSI>; > > > > > + clock-names = "bus", "mod", "ram"; > > > > > + resets = <&ccu RST_BUS_CSI>; > > > > > + status = "disabled"; > > > > > + > > > > > + csi_in: port { > > > > > + #address-cells = <1>; > > > > > + #size-cells = <0>; > > > > > > > > If we expect a single enpoint, then we don't need the address-cells > > > > and size-cells properties. > > > > > > I wouldn't bet on anything. The way the Q8 tablets did front/back cameras > > > is kind of genius if not very hacky. They have two "identical" sensors > > > on the same I2C bus and CSI bus, with shared reset line but separate > > > shutdown lines. Since they are identical, they also have the same I2C > > > address. I haven't figured out how to model this in the device tree. > > > > > > The point is, it's perfectly possible to have two or more sensors use > > > the same controller, provided only one be active at a time. > > > > Right, but I guess the common case would be to have a single sensor, > > where that wouldn't be needed. > > > > In odd cases, we can always specify it in the DTS, and if it becomes > > common enough, we can move it to the DTSI. > > Makes sense. Do you want me to re-spin? If there's no other comment, we'll fix it when applying. Maxime -- Maxime Ripard, Bootlin Embedded Linux and Kernel engineering https://bootlin.com --opeshs6swmdpxgen Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iHUEABYIAB0WIQRcEzekXsqa64kGDp7j7w1vZxhRxQUCXKyxqAAKCRDj7w1vZxhR xQqgAPoCwGE+02LeS5CqpwNkNGyMU+On6b/GFxOR2vtPx16ypwEA42TEbPqw9AfF r31IMk7MKBdc6HAcaoxwGTv23e1kfgU= =Fr2o -----END PGP SIGNATURE----- --opeshs6swmdpxgen--