LKML Archive on lore.kernel.org
help / color / mirror / Atom feed
From: Bjorn Andersson <bjorn.andersson@linaro.org>
To: Rob Herring <robh@kernel.org>
Cc: devicetree@vger.kernel.org, devicetree-spec@vger.kernel.org,
linux-kernel@vger.kernel.org, grant.likely@arm.com,
frowand.list@gmail.com, mark.rutland@arm.com,
Geert Uytterhoeven <geert+renesas@glider.be>,
Linus Walleij <linus.walleij@linaro.org>,
Thierry Reding <thierry.reding@gmail.com>,
Mark Brown <broonie@kernel.org>,
shawnguo@kernel.org, Arnd Bergmann <arnd@arndb.de>,
Stephen Boyd <sboyd@kernel.org>,
Jonathan Cameron <jic23@kernel.org>
Subject: Re: [RFC PATCH] dt-bindings: add a jsonschema binding example
Date: Fri, 20 Apr 2018 14:47:22 -0700 [thread overview]
Message-ID: <20180420214722.GA18510@minitux> (raw)
In-Reply-To: <20180418222905.10414-1-robh@kernel.org>
On Wed 18 Apr 15:29 PDT 2018, Rob Herring wrote:
> The current DT binding documentation format of freeform text is painful
> to write, review, validate and maintain.
>
> This is just an example of what a binding in the schema format looks
> like. It's using jsonschema vocabulary in a YAML encoded document. Using
> jsonschema gives us access to existing tooling. A YAML encoding gives us
> something easy to edit.
>
> This example is just the tip of the iceberg, but it the part most
> developers writing bindings will interact with. Backing all this up
> are meta-schema (to validate the binding schemas), some DT core schema,
> YAML encoded DT output with dtc, and a small number of python scripts to
> run validation. The gory details including how to run end-to-end
> validation can be found here:
>
> https://www.spinics.net/lists/devicetree-spec/msg00649.html
>
> Signed-off-by: Rob Herring <robh@kernel.org>
> ---
> Cc list,
> You all review and/or write lots of binding documents. I'd like some feedback
> on the format.
>
I really like the idea of formalizing the binding document format and
the ability of validating a dtb is really nice.
> Thanks,
> Rob
>
> .../devicetree/bindings/example-schema.yaml | 149 +++++++++++++++++++++
> 1 file changed, 149 insertions(+)
> create mode 100644 Documentation/devicetree/bindings/example-schema.yaml
>
> diff --git a/Documentation/devicetree/bindings/example-schema.yaml b/Documentation/devicetree/bindings/example-schema.yaml
[..]
> + reg:
> + # The description of each element defines the order and implicitly defines
> + # the number of reg entries
> + items:
> + - description: core registers
> + - description: aux registers
> + # minItems/maxItems equal to 2 is implied
I assume that a reg with variable number of entries would have
"description" for all of them and then a minItems that matches the
required ones and maxItems matching all of them?
> +
> + reg-names:
> + # The core schema enforces this is a string array
> + items:
> + - const: core
> + - const: aux
I presume validation based on this should check that there's equal
number of entries in reg-names as there where in reg. Should this
relationship be described in the schema?
[..]
> + interrupts:
> + # Either 1 or 2 interrupts can be present
> + minItems: 1
> + maxItems: 2
> + items:
> + - description: tx or combined interrupt
> + - description: rx interrupt
> +
> + description: |
> + A variable number of interrupts warrants a description of what conditions
> + affect the number of interrupts. Otherwise, descriptions on standard
> + properties are not necessary.
For validation purposes this could be interrupts with interrupt-parents
or a interrupts-extend, a fact that we probably don't want to duplicate
in every definition?
Perhaps we should just do like you did here and define the "interrupts"
and then in the validation tool - where we need to encode the logic
behind this anyways - we support the different variants.
> +
> + interrupt-names:
> + # minItems must be specified here because the default would be 2
> + minItems: 1
As with reg-names, it would be good to have the validator warn if this
is not the same number of items as entries in "interrupts".
> + items:
> + - const: "tx irq"
> + - const: "rx irq"
> +
> + # Property names starting with '#' must be quoted
> + '#interrupt-cells':
> + # A simple case where the value must always be '2'.
> + # The core schema handles that this must be a single integer.
> + const: 2
If this is specified then interrupt-controller should also be given, or
vise versa. How would we describe that?
> +
> + interrupt-controller: {}
> + # The core checks this is a boolean, so just have to list it here to be
> + # valid for this binding.
> +
Regards,
Bjorn
next prev parent reply other threads:[~2018-04-20 21:47 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-04-18 22:29 Rob Herring
2018-04-20 16:47 ` Stephen Boyd
2018-04-20 18:15 ` Rob Herring
2018-04-20 19:53 ` Frank Rowand
2018-04-20 23:41 ` Stephen Boyd
2018-04-21 1:34 ` Rob Herring
2018-04-23 14:01 ` Grant Likely
2018-04-23 14:38 ` Rob Herring
2018-04-23 14:49 ` Grant Likely
2018-04-20 16:59 ` Mark Brown
2018-04-20 18:47 ` Rob Herring
2018-04-20 21:00 ` Frank Rowand
2018-04-21 1:28 ` Rob Herring
2018-04-23 7:25 ` Geert Uytterhoeven
2018-04-23 14:47 ` Grant Likely
2018-04-23 16:49 ` Geert Uytterhoeven
2018-04-25 10:15 ` Grant Likely
2018-04-25 0:33 ` Frank Rowand
2018-11-14 19:39 ` jonsmirl
2018-11-15 23:42 ` Rob Herring
2018-11-16 1:34 ` jonsmirl
2018-04-20 21:47 ` Bjorn Andersson [this message]
2018-04-23 16:51 ` Rob Herring
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=20180420214722.GA18510@minitux \
--to=bjorn.andersson@linaro.org \
--cc=arnd@arndb.de \
--cc=broonie@kernel.org \
--cc=devicetree-spec@vger.kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=frowand.list@gmail.com \
--cc=geert+renesas@glider.be \
--cc=grant.likely@arm.com \
--cc=jic23@kernel.org \
--cc=linus.walleij@linaro.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mark.rutland@arm.com \
--cc=robh@kernel.org \
--cc=sboyd@kernel.org \
--cc=shawnguo@kernel.org \
--cc=thierry.reding@gmail.com \
--subject='Re: [RFC PATCH] dt-bindings: add a jsonschema binding example' \
/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
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).