[PATCH 1/2] dt-bindings: display: Turn lvds.yaml into a generic schema

Maxime Ripard maxime at cerno.tech
Mon Nov 22 14:53:44 UTC 2021


Hi,

On Sat, Nov 20, 2021 at 12:46:33AM +0200, Laurent Pinchart wrote:
> On Tue, Nov 16, 2021 at 03:35:02PM +0100, Maxime Ripard wrote:
> > The lvds.yaml file so far was both defining the generic LVDS properties
> > (such as data-mapping) that could be used for any LVDS sink, but also
> > the panel-lvds binding.
> > 
> > That last binding was to describe LVDS panels simple enough, and had a
> > number of other bindings using it as a base to specialise it further.
> > 
> > However, this situation makes it fairly hard to extend and reuse both
> > the generic parts, and the panel-lvds itself.
> > 
> > Let's remove the panel-lvds parts and leave only the generic LVDS
> > properties.
> > 
> > Signed-off-by: Maxime Ripard <maxime at cerno.tech>
> > ---
> >  .../display/panel/advantech,idk-1110wr.yaml   | 17 ++++++++++-
> >  .../display/panel/innolux,ee101ia-01d.yaml    | 21 +++++++++++++-
> >  .../bindings/display/panel/lvds.yaml          | 29 +------------------
> >  .../display/panel/mitsubishi,aa104xd12.yaml   | 17 ++++++++++-
> >  .../display/panel/mitsubishi,aa121td01.yaml   | 17 ++++++++++-
> >  .../display/panel/sgd,gktw70sdae4se.yaml      | 17 ++++++++++-
> >  6 files changed, 85 insertions(+), 33 deletions(-)
> > 
> > diff --git a/Documentation/devicetree/bindings/display/panel/advantech,idk-1110wr.yaml b/Documentation/devicetree/bindings/display/panel/advantech,idk-1110wr.yaml
> > index 93878c2cd370..f27cd2038636 100644
> > --- a/Documentation/devicetree/bindings/display/panel/advantech,idk-1110wr.yaml
> > +++ b/Documentation/devicetree/bindings/display/panel/advantech,idk-1110wr.yaml
> > @@ -11,13 +11,23 @@ maintainers:
> >    - Thierry Reding <thierry.reding at gmail.com>
> >  
> >  allOf:
> > +  - $ref: panel-common.yaml#
> >    - $ref: lvds.yaml#
> >  
> > +select:
> > +  properties:
> > +    compatible:
> > +      contains:
> > +        const: advantech,idk-1110wr
> > +
> > +  required:
> > +    - compatible
> 
> I've never encountered this before, what does it do ?

select dictates if the schema is applied to a node or not.

It takes a schema, and if this schema is valid, the rest of the schema
will be applied to the current node.

It's mostly unused in the kernel because the dt-validate tool will add a
select clause from the compatible list in most case that would expand in
this case to:

select:
  properties:
    contains:
      enum:
        - advantech,idk-1110wr
	- panel-lvds

  required:
    - compatible

ie, it tries to validate with this schema any node that has either the
panel compatible or the generic compatible.

That means we would have that schema applied to all the nodes that have
panel-lvds, including the ones with a different compatible than the
advantech one.

With this clause, we make sure that we ignore the other panels, while
ensuring that the compatible list for the advantech compatible is
correct.

> > +
> >  properties:
> >    compatible:
> >      items:
> >        - const: advantech,idk-1110wr
> > -      - {} # panel-lvds, but not listed here to avoid false select
> > +      - const: panel-lvds
> >  
> >    data-mapping:
> >      const: jeida-24
> > @@ -35,6 +45,11 @@ additionalProperties: false
> >  
> >  required:
> >    - compatible
> > +  - data-mapping
> > +  - width-mm
> > +  - height-mm
> > +  - panel-timing
> > +  - port
> >  
> >  examples:
> >    - |+
> > diff --git a/Documentation/devicetree/bindings/display/panel/innolux,ee101ia-01d.yaml b/Documentation/devicetree/bindings/display/panel/innolux,ee101ia-01d.yaml
> > index a69681e724cb..6e06eecac14e 100644
> > --- a/Documentation/devicetree/bindings/display/panel/innolux,ee101ia-01d.yaml
> > +++ b/Documentation/devicetree/bindings/display/panel/innolux,ee101ia-01d.yaml
> > @@ -11,15 +11,26 @@ maintainers:
> >    - Thierry Reding <thierry.reding at gmail.com>
> >  
> >  allOf:
> > +  - $ref: panel-common.yaml#
> >    - $ref: lvds.yaml#
> >  
> > +select:
> > +  properties:
> > +    compatible:
> > +      contains:
> > +        const: innolux,ee101ia-01d
> > +
> > +  required:
> > +    - compatible
> > +
> >  properties:
> >    compatible:
> >      items:
> >        - const: innolux,ee101ia-01d
> > -      - {} # panel-lvds, but not listed here to avoid false select
> > +      - const: panel-lvds
> >  
> >    backlight: true
> > +  data-mapping: true
> >    enable-gpios: true
> >    power-supply: true
> >    width-mm: true
> > @@ -27,5 +38,13 @@ properties:
> >    panel-timing: true
> >    port: true
> >  
> > +required:
> > +  - compatible
> > +  - data-mapping
> > +  - width-mm
> > +  - height-mm
> > +  - panel-timing
> > +  - port
> > +
> >  additionalProperties: false
> >  ...
> > diff --git a/Documentation/devicetree/bindings/display/panel/lvds.yaml b/Documentation/devicetree/bindings/display/panel/lvds.yaml
> > index 49460c9dceea..5281a75c8bb5 100644
> > --- a/Documentation/devicetree/bindings/display/panel/lvds.yaml
> > +++ b/Documentation/devicetree/bindings/display/panel/lvds.yaml
> > @@ -4,7 +4,7 @@
> >  $id: http://devicetree.org/schemas/display/panel/lvds.yaml#
> >  $schema: http://devicetree.org/meta-schemas/core.yaml#
> >  
> > -title: LVDS Display Panel
> > +title: LVDS Display Common Properties
> 
> Maybe
> 
> title: LVDS Display Panel Common Properties
> 
> or do you foresee this being useful for non-panel LBDS sinks too ? In
> that case the title is fine, but the file could be moved in the parent
> directory.
> 
> I'm also wondering what we should do with the data-mapping and
> data-mirror properties. For an LVDS panel they're fine at the device
> level, but for an LVDS sink, they may be better placed at the port or
> endpoint level.

That was my intent, but it might not be relevant indeed. Honestly at
this point I just want to have the tbs,a711-panel compatible documented
somewhere :)

Maxime


More information about the dri-devel mailing list