Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp574024imm; Fri, 28 Sep 2018 03:24:17 -0700 (PDT) X-Google-Smtp-Source: ACcGV60pa6BBmY8XMICag99gXv4x+pql33xqLgNb2B2nc9ootIN6bPlUOzEe1yvYT3R7T69cjZm2 X-Received: by 2002:a62:6003:: with SMTP id u3-v6mr16257043pfb.114.1538130257896; Fri, 28 Sep 2018 03:24:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538130257; cv=none; d=google.com; s=arc-20160816; b=HNp7+R/saY8+KaIDu8hqJFWqjMWXwy+wtA+wmA69tRSBydU+H3yG4ArpJmpJjHz8Zg RnnwuENgz2Q9M1D4X4FX2RgAwjmonvA/2blhQbtRFU9fN153OVImoAThGhOzcAxw3/h6 IS00HztidTccCtb8Ux+WQpYfDbCUBXD2VzBCDun4jz4q8eSjF1Vh3/3knydVT4+X3kvc IvernWIVReovxmXuYsFBodSdJV4AsTkYQ+91gQfPowXz1mdSwWoYbWx+ENqX1VFLPEzq nw1Aeu8/Rg6ySzkNz88/B6X8Uo7TIIx9wTlseqUybAkLJAA1Ao2VhrJmIzcXfmGm3m85 fIhg== 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=Z6/QqJk9mbWT7YXAg4dgsQIH1w4BfKaGvwY+1cGIno4=; b=EbnOzZuz9LXWJ6F2gMy6neC3XYryXJ6yh2g55fyGx5XEuFrq9Y4+UCGYU05p8eEbHO K3hU37JB3JP3qY2cvFwvohVrTgSEKa6euZO/fsMGJ1Dqcem3pIUz75HItKsuQ3ESfFIE Rs+Whj8qbYEWGpx9tizFdqBqXCi9QWemfYPsGrdO9RMvQs6HjAzgs+/Ktahu44Uc/EYJ p9WO30hscZhM7yf4sreq0fNmrNrHJ2bU6BtYKQT1QcO/iD++bkTAfMY3qGobraTgRPkq 5lRnIGVwm7rUGDuAjj604gOmTzILDaL//m8/SwnWoS9Ck5hyTimNvYJ2pbvv9Hu7q+9z Yvyg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y2-v6si4570278pli.330.2018.09.28.03.24.01; Fri, 28 Sep 2018 03:24:17 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729371AbeI1Qq4 (ORCPT + 99 others); Fri, 28 Sep 2018 12:46:56 -0400 Received: from mga12.intel.com ([192.55.52.136]:2104 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729181AbeI1Qq4 (ORCPT ); Fri, 28 Sep 2018 12:46:56 -0400 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by fmsmga106.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Sep 2018 03:23:51 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.54,314,1534834800"; d="scan'208";a="94263455" Received: from paasikivi.fi.intel.com ([10.237.72.42]) by fmsmga001.fm.intel.com with ESMTP; 28 Sep 2018 03:23:46 -0700 Received: by paasikivi.fi.intel.com (Postfix, from userid 1000) id 98335209CB; Fri, 28 Sep 2018 13:23:45 +0300 (EEST) Date: Fri, 28 Sep 2018 13:23:45 +0300 From: Sakari Ailus To: Laurent Pinchart Cc: Yong Deng , Maxime Ripard , Mauro Carvalho Chehab , Rob Herring , Mark Rutland , Chen-Yu Tsai , "\"David S. Miller" , Greg Kroah-Hartman , Andrew Morton , Arnd Bergmann , Hans Verkuil , Geert Uytterhoeven , Jacob Chen , Neil Armstrong , Thierry Reding , Philipp Zabel , Todor Tomov , linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-sunxi@googlegroups.com Subject: Re: [PATCH v11 1/2] dt-bindings: media: Add Allwinner V3s Camera Sensor Interface (CSI) Message-ID: <20180928102345.r2g342tg5mgcwfw6@paasikivi.fi.intel.com> References: <1537951204-24672-1-git-send-email-yong.deng@magewell.com> <20180928093833.gwmskm2jvby6x4s6@paasikivi.fi.intel.com> <14114604.4rraf0qJLU@avalon> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <14114604.4rraf0qJLU@avalon> User-Agent: NeoMutt/20170113 (1.7.2) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Laurent, On Fri, Sep 28, 2018 at 12:45:12PM +0300, Laurent Pinchart wrote: > Hi Sakari, > > On Friday, 28 September 2018 12:38:33 EEST Sakari Ailus wrote: > > On Wed, Sep 26, 2018 at 04:40:04PM +0800, Yong Deng wrote: > > > Add binding documentation for Allwinner V3s CSI. > > > > > > Acked-by: Maxime Ripard > > > Acked-by: Sakari Ailus > > > > I know... but I have a few more comments. > > > > > Reviewed-by: Rob Herring > > > Signed-off-by: Yong Deng > > > --- > > > > > > .../devicetree/bindings/media/sun6i-csi.txt | 59 +++++++++++++++++ > > > 1 file changed, 59 insertions(+) > > > create mode 100644 Documentation/devicetree/bindings/media/sun6i-csi.txt > > > > > > diff --git a/Documentation/devicetree/bindings/media/sun6i-csi.txt > > > b/Documentation/devicetree/bindings/media/sun6i-csi.txt new file mode > > > 100644 > > > index 000000000000..2ff47a9507a6 > > > --- /dev/null > > > +++ b/Documentation/devicetree/bindings/media/sun6i-csi.txt > > > @@ -0,0 +1,59 @@ > > > +Allwinner V3s Camera Sensor Interface > > > +------------------------------------- > > > + > > > +Allwinner V3s SoC features two CSI module. CSI0 is used for MIPI CSI-2 > > > +interface and CSI1 is used for parallel interface. > > > + > > > +Required properties: > > > + - compatible: value must be "allwinner,sun8i-v3s-csi" > > > + - reg: base address and size of the memory-mapped region. > > > + - interrupts: interrupt associated to this IP > > > + - clocks: phandles to the clocks feeding the CSI > > > + * bus: the CSI interface clock > > > + * mod: the CSI module clock > > > + * ram: the CSI DRAM clock > > > + - clock-names: the clock names mentioned above > > > + - resets: phandles to the reset line driving the CSI > > > + > > > +Each CSI node should contain one 'port' child node with one child > > > 'endpoint' +node, according to the bindings defined in > > > +Documentation/devicetree/bindings/media/video-interfaces.txt. As > > > mentioned > > > +above, the endpoint's bus type should be MIPI CSI-2 for CSI0 and parallel > > > or +Bt656 for CSI1. > > > > Which port represents CSI0 and which one is CSI1? That needs to be > > documented. > > There are two CSI devices, named CSI0 and CSI1, with one port each. The CSI0 > device supports CSI-2 only, and the CSI1 device parallel (BT.601 or BT.656) > only. > > > > + > > > +Endpoint node properties for CSI1 > > > > How about CSI0? I'd expect at least data-lanes, and clock-lanes as well if > > the hardware supports lane mapping. > > I enquired about that too. As far as I understand, CSI0 isn't supported yet in > the driver due to lack of documentation and lack of open-source vendor- > provided source code. While DT bindings are not tied to driver > implementations, it's not the best idea to design DT bindings without at least > one working implementation to test them. I thus proposed just listing CSI0 as > being unsupported for now. Ack. We should still define which receiver corresponds to a given port. Probably 1 for CSI1 would make sense, in order to avoid changing the order the hardware already uses. 0 doesn't need to be documented no IMO. What do you think? > > > > +--------------------------------- > > > + > > > +- remote-endpoint : (required) a phandle to the bus receiver's endpoint > > > + node > > > +- bus-width: : (required) must be 8, 10, 12 or 16 > > > +- pclk-sample : (optional) (default: sample on falling edge) > > > > Could you add that video-interfaces.txt contains documentation of these > > properties as well? There's a reference above but only discusses port and > > endpoint nodes. > > > > > +- hsync-active : (only required for parallel) > > > +- vsync-active : (only required for parallel) > > > > As you support both Bt656 and parallel (with sync signals), you can detect > > the interface type from the presence of these properties. I think you > > should also say that these properties are not allowed on Bt656. So I'd > > change this to e.g. > > > > (required; parallel-only) > > > > > + > > > +Example: > > > + > > > +csi1: csi@1cb4000 { > > > + compatible = "allwinner,sun8i-v3s-csi"; > > > + reg = <0x01cb4000 0x1000>; > > > + interrupts = ; > > > + clocks = <&ccu CLK_BUS_CSI>, > > > + <&ccu CLK_CSI1_SCLK>, > > > + <&ccu CLK_DRAM_CSI>; > > > + clock-names = "bus", "mod", "ram"; > > > + resets = <&ccu RST_BUS_CSI>; > > > + > > > + port { > > > + /* Parallel bus endpoint */ > > > + csi1_ep: endpoint { > > > + remote-endpoint = <&adv7611_ep>; > > > + bus-width = <16>; > > > + > > > + /* If hsync-active/vsync-active are missing, > > > + embedded BT.656 sync is used */ > > > + hsync-active = <0>; /* Active low */ > > > + vsync-active = <0>; /* Active low */ > > > + pclk-sample = <1>; /* Rising */ > > > + }; > > > + }; > > > +}; -- Terveisin, Sakari Ailus sakari.ailus@linux.intel.com