From: Sakari Ailus <sakari.ailus@iki.fi>
To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Cc: Krzysztof Kozlowski <krzysztof.kozlowski@canonical.com>,
Jacopo Mondi <jacopo@jmondi.org>,
Chiranjeevi Rapolu <chiranjeevi.rapolu@intel.com>,
jeanmichel.hautbois@ideasonboard.com,
paul.kocialkowski@bootlin.com, paul.elder@ideasonboard.com,
Mauro Carvalho Chehab <mchehab@kernel.org>,
"open list:OMNIVISION OV5670 SENSOR DRIVER"
<linux-media@vger.kernel.org>,
robh@kernel.org, devicetree@vger.kernel.org
Subject: Re: [PATCH v2 1/8] media: dt-bindings: i2c: Document ov5670
Date: Tue, 15 Mar 2022 22:30:51 +0200 [thread overview]
Message-ID: <YjD3e14U0Hcqtob3@valkosipuli.retiisi.eu> (raw)
In-Reply-To: <YjCOL2H33oc2pOWN@pendragon.ideasonboard.com>
Hi Laurent,
On Tue, Mar 15, 2022 at 03:01:35PM +0200, Laurent Pinchart wrote:
> Hi Sakari,
>
> On Tue, Mar 15, 2022 at 02:47:43PM +0200, Sakari Ailus wrote:
> > On Tue, Mar 15, 2022 at 09:03:41AM +0100, Krzysztof Kozlowski wrote:
> > > On 15/03/2022 08:59, Sakari Ailus wrote:
> > > > On Tue, Mar 15, 2022 at 08:32:58AM +0100, Krzysztof Kozlowski wrote:
> > > >> On 14/03/2022 17:27, Jacopo Mondi wrote:
> > > >>> Provide the bindings documentation for Omnivision OV5670 image sensor.
> > > >>>
> > > >>> Signed-off-by: Jacopo Mondi <jacopo@jmondi.org>
> > > >>>
> > > >>> ---
> > > >>> v1->v2 (comments from Krzysztof)
> > > >>>
> > > >>> - Rename to include manufacturer name
> > > >>> - Add entry to MAINTAINERS
> > > >>> - Add maxItems: to -gpios properties
> > > >>> - Use common clock properties
> > > >>> - Use enum: [1, 2] for data lanes
> > > >>> - Fix whitespace issue in example
> > > >>> ---
> > > >>>
> > > >>> .../bindings/media/i2c/ovti,ov5670.yaml | 99 +++++++++++++++++++
> > > >>> MAINTAINERS | 1 +
> > > >>> 2 files changed, 100 insertions(+)
> > > >>> create mode 100644 Documentation/devicetree/bindings/media/i2c/ovti,ov5670.yaml
> > > >>>
> > > >>> diff --git a/Documentation/devicetree/bindings/media/i2c/ovti,ov5670.yaml b/Documentation/devicetree/bindings/media/i2c/ovti,ov5670.yaml
> > > >>> new file mode 100644
> > > >>> index 000000000000..73cf72203f17
> > > >>> --- /dev/null
> > > >>> +++ b/Documentation/devicetree/bindings/media/i2c/ovti,ov5670.yaml
> > > >>> @@ -0,0 +1,99 @@
> > > >>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
> > > >>> +%YAML 1.2
> > > >>> +---
> > > >>> +$id: http://devicetree.org/schemas/media/i2c/ovti,ov5670.yaml#
> > > >>> +$schema: http://devicetree.org/meta-schemas/core.yaml#
> > > >>> +
> > > >>> +title: Omnivision OV5670 5 Megapixels raw image sensor
> > > >>> +
> > > >>> +maintainers:
> > > >>> + - Jacopo Mondi <jacopo@jmondi.org>
> > > >>> +
> > > >>> +description: |-
> > > >>> + The OV5670 is a 5 Megapixels raw image sensor which provides images in 10-bits
> > > >>> + RAW BGGR Bayer format on a 2 data lanes MIPI CSI-2 serial interface and is
> > > >>> + controlled through an I2C compatible control bus.
> > > >>> +
> > > >>> +properties:
> > > >>> + compatible:
> > > >>> + const: ovti,ov5670
> > > >>> +
> > > >>> + reg:
> > > >>> + maxItems: 1
> > > >>> +
> > > >>> + assigned-clocks: true
> > > >>> + assigned-clock-parents: true
> > > >>> + assigned-clock-rates: true
> > > >>
> > > >> You should not need these. These are coming with schema. You can add
> > > >> these to example schema below and double-check.
> > > >
> > > > They should probably be required actually.
> > >
> > > Why required? The hardware can work with different clocks, get their
> > > rate and configure internal PLLs/clocks to new value. Having it required
> > > might have sense for current implementation of driver but this is
> > > independent of bindings. Bindings do not describe driver, but hardware.
> >
> > We've had this discussion before and the result of that was this (see
> > "Handling clocks"):
> >
> > Documentation/driver-api/media/camera-sensor.rst
>
> I don't think those properties should be required in the sensor
> bindings. There are platforms where the clock provided to the sensor
> comes from a fixed-frequency oscillator, assigning a rate or parent
> makes no sense for those (assigning a parent would actually be
> impossible).
>
> Assigning a parent or rate is fine when applicable, but as it can't be
> required, there's also no point in listing the properties here.
The cases where the clock is fixed are quite rare but admittedly they
exist.
It's just easy to get this wrong.
--
Sakari Ailus
next prev parent reply other threads:[~2022-03-15 20:30 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20220314162714.153970-1-jacopo@jmondi.org>
2022-03-14 16:27 ` [PATCH v2 1/8] media: dt-bindings: i2c: Document ov5670 Jacopo Mondi
2022-03-15 7:32 ` Krzysztof Kozlowski
2022-03-15 7:59 ` Sakari Ailus
2022-03-15 8:03 ` Krzysztof Kozlowski
2022-03-15 12:47 ` Sakari Ailus
2022-03-15 12:57 ` Krzysztof Kozlowski
2022-03-15 13:01 ` Laurent Pinchart
2022-03-15 20:30 ` Sakari Ailus [this message]
2022-03-15 8:09 ` Laurent Pinchart
2022-03-15 8:41 ` Jacopo Mondi
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=YjD3e14U0Hcqtob3@valkosipuli.retiisi.eu \
--to=sakari.ailus@iki.fi \
--cc=chiranjeevi.rapolu@intel.com \
--cc=devicetree@vger.kernel.org \
--cc=jacopo@jmondi.org \
--cc=jeanmichel.hautbois@ideasonboard.com \
--cc=krzysztof.kozlowski@canonical.com \
--cc=laurent.pinchart@ideasonboard.com \
--cc=linux-media@vger.kernel.org \
--cc=mchehab@kernel.org \
--cc=paul.elder@ideasonboard.com \
--cc=paul.kocialkowski@bootlin.com \
--cc=robh@kernel.org \
/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
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox