From: Sakari Ailus <sakari.ailus@iki.fi> To: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Cc: Jacopo Mondi <jacopo+renesas@jmondi.org>, robh+dt@kernel.org, devicetree@vger.kernel.org, slongerbeam@gmail.com, linux-media@vger.kernel.org, linux-renesas-soc@vger.kernel.org, Maxime Coquelin <mcoquelin.stm32@gmail.com>, Alexandre Torgue <alexandre.torgue@st.com>, "moderated list:ARM/STM32 ARCHITECTURE" <linux-stm32@st-md-mailman.stormreply.com> Subject: Re: [PATCH 08/13] dt-bindings: media: ov5640: Remove data-shift Date: Thu, 30 Jul 2020 19:43:59 +0300 Message-ID: <20200730164359.GB5201@valkosipuli.retiisi.org.uk> (raw) In-Reply-To: <20200730163211.GB6107@pendragon.ideasonboard.com> Hi Laurent, On Thu, Jul 30, 2020 at 07:32:11PM +0300, Laurent Pinchart wrote: > Hi Sakari, > > On Thu, Jul 30, 2020 at 07:22:19PM +0300, Sakari Ailus wrote: > > On Wed, Jul 29, 2020 at 05:46:08PM +0300, Laurent Pinchart wrote: > > > On Wed, Jul 29, 2020 at 05:29:36PM +0300, Sakari Ailus wrote: > > > > On Sun, Jul 26, 2020 at 12:31:25AM +0300, Laurent Pinchart wrote: > > > > > On Sun, Jul 26, 2020 at 12:18:33AM +0300, Sakari Ailus wrote: > > > > > > On Fri, Jul 24, 2020 at 02:15:49AM +0300, Laurent Pinchart wrote: > > > > > > > On Fri, Jul 24, 2020 at 01:22:59AM +0300, Sakari Ailus wrote: > > > > > > > > On Fri, Jul 17, 2020 at 11:57:22PM +0300, Laurent Pinchart wrote: > > > > > > > > > Hi Jacopo, > > > > > > > > > > > > > > > > > > (CC'ing Sakari) > > > > > > > > > > > > > > > > > > Thank you for the patch. > > > > > > > > > > > > > > > > > > On Fri, Jul 17, 2020 at 03:28:54PM +0200, Jacopo Mondi wrote: > > > > > > > > > > The value of the data-shift property solely depend on the selected > > > > > > > > > > bus width and it's not freely configurable. > > > > > > > > > > > > > > > > > > > > Remove it from the bindings document and update its users accordingly. > > > > > > > > > > > > > > > > > > Hmmmm that's an interesting one. Sakari, what do you think ? > > > > > > > > > > > > > > > > > > > Signed-off-by: Jacopo Mondi <jacopo+renesas@jmondi.org> > > > > > > > > > > --- > > > > > > > > > > Documentation/devicetree/bindings/media/i2c/ov5640.yaml | 9 --------- > > > > > > > > > > arch/arm/boot/dts/stm32mp157c-ev1.dts | 1 - > > > > > > > > > > 2 files changed, 10 deletions(-) > > > > > > > > > > > > > > > > > > > > diff --git a/Documentation/devicetree/bindings/media/i2c/ov5640.yaml b/Documentation/devicetree/bindings/media/i2c/ov5640.yaml > > > > > > > > > > index 5e1662e848bd..ab700a1830aa 100644 > > > > > > > > > > --- a/Documentation/devicetree/bindings/media/i2c/ov5640.yaml > > > > > > > > > > +++ b/Documentation/devicetree/bindings/media/i2c/ov5640.yaml > > > > > > > > > > @@ -92,12 +92,6 @@ properties: > > > > > > > > > > parallel bus. > > > > > > > > > > enum: [8, 10] > > > > > > > > > > > > > > > > > > > > - data-shift: > > > > > > > > > > - description: | > > > > > > > > > > - Shall be set to <2> for 8 bits parallel bus (lines 9:2 are used) or > > > > > > > > > > - <0> for 10 bits parallel bus. > > > > > > > > > > - enum: [0, 2] > > > > > > > > > > > > > > > > > > Should you document in the description of bus-width that data-shift is > > > > > > > > > implied ? > > > > > > > > > > > > > > > > The purpose of the datas-shift property is to convey how the parallel bus > > > > > > > > lines are connected for a given bus width for devices where it is > > > > > > > > configurable. As this device does not not support that, then indeed this > > > > > > > > property is not relevant for the device IMO. > > > > > > > > > > > > > > Could you elaborate on this ? I believe the case that Jacopo is > > > > > > > describing connects D[9:2] from the sensor to D[7:0] of the receiver > > > > > > > (Jacopo, could you confirm ?). Isn't that what data-shift is for ? > > > > > > > > > > > > Yes, it is. But in this case what data-shift configures is not configurable > > > > > > as such but defined by another configuration, making the data-shift > > > > > > property redundant. We generally haven't documented redundant things in DT > > > > > > bindings --- for instance data-lanes is documented in bindings only if it > > > > > > is configurable. > > > > > > > > > > Then I think we share the same understanding. I believe the > > > > > documentation in video-interfaces.txt needs to be expanded, as it's > > > > > quite terse and not very clear. > > > > > > > > The DT spec states that: > > > > > > > > A DTSpec-compliant devicetree describes device information in a > > > > system that cannot necessarily be dynamically detected by a client > > > > program. For example, the architecture of PCI enables a client to > > > > probe and detect attached devices, and thus devicetree nodes > > > > describing PCI devices might not be required. However, a device > > > > node is required to describe a PCI host bridge device in the system > > > > if it cannot be detected by probing. > > > > > > > > I'd read that as there's no need to specify properties that do not provide > > > > additional information to software. > > > > > > That's a bit of a stretch interpretation :-) > > > > > > > As some properties are dependent on > > > > others and and this depends on hardware features, I don't think we can in > > > > general case take this account in generic binding documentation, but device > > > > specific ones. > > > > > > > > Of course we could add this to data-shift documentation, but then I wonder > > > > how many other similar cases there are where in hardware the configuration > > > > defined by one property determines the value of another? > > > > > > I was mostly thinking about documenting *how* data-shift interacts with > > > bus-width. I think that specifying the default data-shift value based on > > > the bus-width value, for the case where data-shift is not specified, > > > would also make sense. > > > > Do you mean in device binding documentation or in generic documentation? > > Device bindings should have this information, yes. > > I mean in video-interfaces.txt (which should become > video-interfaces.yaml :-)) for the general rules, and in specific > bindings for any device-specific rule. Please send a patch. :-) > > We will likely need a runtime API too, it's entirely conceivable that a > 10-bit parallel sensor, which D[9:0] signals, could use either D[9:2] or > D[7:0] when configured to transmit 10-bit data. This isn't something > that can be encoded in DT. It's a separate topic though. You can set defaults in the current API but those defaults are basically a C struct. I don't think we should be looking into making those defaults depend on property values, unless there's a clear reason to do so --- and in this case there isn't one. -- Kind regards, Sakari Ailus
next prev parent reply index Thread overview: 46+ messages / expand[flat|nested] mbox.gz Atom feed top 2020-07-17 13:28 [PATCH 00/13] dt-bindings: media: ov5640: Convert to json-schema Jacopo Mondi 2020-07-17 13:28 ` [PATCH 01/13] " Jacopo Mondi 2020-07-17 19:28 ` Laurent Pinchart 2020-07-20 16:32 ` Rob Herring 2020-07-17 13:28 ` [PATCH 02/13] arm64: dts: qcom: apq8016-sbc: Fix CSI-2 lanes routing Jacopo Mondi 2020-07-17 19:35 ` Laurent Pinchart 2020-07-22 8:14 ` Loic Poulain 2020-07-22 8:34 ` Jacopo Mondi 2020-07-17 13:28 ` [PATCH 03/13] dt-bindings: media: ov5640: Do not limit rotation Jacopo Mondi 2020-07-17 19:38 ` Laurent Pinchart 2020-07-20 19:36 ` Rob Herring 2020-07-17 13:28 ` [PATCH 04/13] dt-bindings: media: ti,cal: Remove sensor from example Jacopo Mondi 2020-07-17 19:39 ` Laurent Pinchart 2020-07-23 20:57 ` Rob Herring 2020-07-17 13:28 ` [PATCH 05/13] dt-bindings: media: ov5640: Make bus-type mandatory Jacopo Mondi 2020-07-17 15:48 ` Fabio Estevam 2020-07-17 19:48 ` Laurent Pinchart 2020-07-20 19:45 ` Rob Herring 2020-07-17 13:28 ` [PATCH 06/13] dt-bindings: media: ov5640: Require ep properties Jacopo Mondi 2020-07-17 19:50 ` Laurent Pinchart 2020-07-17 13:28 ` [PATCH 07/13] dt-bindings: media: ov5640: Remove clock-lanes Jacopo Mondi 2020-07-17 20:48 ` Laurent Pinchart 2020-07-20 19:47 ` Rob Herring 2020-07-17 13:28 ` [PATCH 08/13] dt-bindings: media: ov5640: Remove data-shift Jacopo Mondi 2020-07-17 20:57 ` Laurent Pinchart 2020-07-23 22:22 ` Sakari Ailus 2020-07-23 23:15 ` Laurent Pinchart 2020-07-25 21:18 ` Sakari Ailus 2020-07-25 21:31 ` Laurent Pinchart 2020-07-29 14:29 ` Sakari Ailus 2020-07-29 14:46 ` Laurent Pinchart 2020-07-30 16:22 ` Sakari Ailus 2020-07-30 16:32 ` Laurent Pinchart 2020-07-30 16:43 ` Sakari Ailus [this message] 2020-07-17 13:28 ` [PATCH 09/13] dt-bindings: media: ov5640: Add default for synch signals Jacopo Mondi 2020-07-17 20:59 ` Laurent Pinchart 2020-07-20 19:50 ` Rob Herring 2020-07-17 13:28 ` [PATCH 10/13] dt-bindings: media: ov5640: Demote DVP required properties Jacopo Mondi 2020-07-17 21:00 ` Laurent Pinchart 2020-07-17 13:28 ` [PATCH 11/13] media: i2c: ov5640: Initialize DVP polarities as default Jacopo Mondi 2020-07-17 21:02 ` Laurent Pinchart 2020-07-17 13:28 ` [PATCH 12/13] MAINTAINERS: ov5640: Add bindings file Jacopo Mondi 2020-07-17 21:03 ` Laurent Pinchart 2020-07-17 13:28 ` [PATCH 13/13] dt-bindings: media: ov5640: Add myself as co-maintainer Jacopo Mondi 2020-07-17 21:03 ` Laurent Pinchart 2020-07-17 19:31 ` [PATCH 00/13] dt-bindings: media: ov5640: Convert to json-schema Laurent Pinchart
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=20200730164359.GB5201@valkosipuli.retiisi.org.uk \ --to=sakari.ailus@iki.fi \ --cc=alexandre.torgue@st.com \ --cc=devicetree@vger.kernel.org \ --cc=jacopo+renesas@jmondi.org \ --cc=laurent.pinchart@ideasonboard.com \ --cc=linux-media@vger.kernel.org \ --cc=linux-renesas-soc@vger.kernel.org \ --cc=linux-stm32@st-md-mailman.stormreply.com \ --cc=mcoquelin.stm32@gmail.com \ --cc=robh+dt@kernel.org \ --cc=slongerbeam@gmail.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
Linux-Devicetree Archive on lore.kernel.org Archives are clonable: git clone --mirror https://lore.kernel.org/linux-devicetree/0 linux-devicetree/git/0.git git clone --mirror https://lore.kernel.org/linux-devicetree/1 linux-devicetree/git/1.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 linux-devicetree linux-devicetree/ https://lore.kernel.org/linux-devicetree \ devicetree@vger.kernel.org public-inbox-index linux-devicetree Example config snippet for mirrors Newsgroup available over NNTP: nntp://nntp.lore.kernel.org/org.kernel.vger.linux-devicetree AGPL code for this site: git clone https://public-inbox.org/public-inbox.git