On Fri, Jul 28, 2017 at 11:11 AM, Pantelis Antoniou <pantelis.antoniou@xxxxxxxxxxxx> wrote: > Hi Rob, > > On Fri, 2017-07-28 at 10:07 -0500, Rob Herring wrote: >> On Fri, Jul 28, 2017 at 7:23 AM, Pantelis Antoniou >> <pantelis.antoniou@xxxxxxxxxxxx> wrote: >> > Hi Rob, >> > >> > On Thu, 2017-07-27 at 21:12 -0500, Rob Herring wrote: >> >> On Thu, Jul 27, 2017 at 7:51 PM, Tom Rini <trini@xxxxxxxxxxxx> wrote: >> >> > On Thu, Jul 27, 2017 at 06:00:00PM -0500, Rob Herring wrote: >> >> >> On Thu, Jul 27, 2017 at 4:46 PM, Pantelis Antoniou >> >> >> <pantelis.antoniou@xxxxxxxxxxxx> wrote: >> >> >> > Hi Frank, >> >> >> > >> >> >> > On Thu, 2017-07-27 at 13:22 -0700, Frank Rowand wrote: >> >> >> >> Hi Pantelis, >> >> >> >> >> >> >> >> Keep in mind one of the reasons Linus says he is very direct is to >> >> >> >> avoid leading a developer on, so that they don't waste a lot of time >> >> >> >> trying to resolve the maintainer's issues instead of realizing that >> >> >> >> the maintainer is saying "no". Please read my current answer as being >> >> >> >> "no, not likely to ever be accepted", not "no, not in the current form". >> >> >> >> >> >> >> >> My first reaction is: no, this is not a good idea for the Linux kernel. >> >> >> >> >> >> >> > >> >> >> > This has nothing to do with the kernel. It spits out valid DTBs that the >> >> >> > kernel (or anything else) may use. >> >> >> >> >> >> Let me rephrase Frank's statement: this is not a good idea for the >> >> >> main repository of dts files. >> >> >> >> >> >> But sure, DTS is already not the only source of DTBs. It comes from >> >> >> firmware on Power systems. >> >> > >> >> > Yes, but unless they're generated from something other than a (at the >> >> > time) normal DTS, that's not a good example, IMHO. >> >> >> >> They aren't. I'm talking about IBM systems. The firmware has its own >> >> representation and flattens that to a DTB is how I understand it. >> >> >> >> >> If you want to create and maintain your own >> >> >> source format, then that is perfectly fine. But based on the current >> >> >> understanding, I'm not seeing a reason we'd convert DTS files to YAML. >> >> > >> >> > Can I propose one? To borrow a phrase, Validation, Validation, >> >> > Validation. Let me point to fe496e23b748 in the kernel for a moment. I >> >> > found that as part of helping a new engineer come up to speed on doing >> >> > device tree work. What I found was a case where: >> >> > - The binding doc gives one value for compatible as the required value. >> >> > - The code accepts only a single, different value. >> >> > - A few in-kernel dts files have different still values. >> >> > >> >> > If the common dts source file was in yaml, binding docs would be written >> >> > so that we could use them as validation and hey, the above wouldn't ever >> >> > have happened. And I'm sure this is not the only example that's in-tree >> >> > right now. These kind of problems create an artificially high barrier >> >> > to entry in a rather important area of the kernel (you can't trust the >> >> > docs, you have to check around the code too, and of course the code >> >> > might have moved since the docs were written). >> >> >> >> I'm all for validation, but the binding doc or schema and files that >> >> describe platforms (aka DTS files) are not the same thing. The schema >> >> is what are the constraints for a binding. Maybe some bindings are >> >> fixed where there's only one valid binding implementation, but that's >> >> the easy case (we could use DTS for that). I'll take YAML for binding >> >> docs yesterday. Believe me, I'm tired of reviewing free form binding >> >> docs. If that's where you want to go, reply to my reply that went >> >> unanswered on Matt Porter's YAML proposal from 2 years ago (or maybe 3 >> >> now). I had the whole binding doc tree converted over to an initial >> >> YAML schema. We just need to agree on the schema. Or we can keep >> >> waiting for Grant to publish what he started on... >> >> >> > >> > The way I see it there's a validation hierarchy. >> > >> > There are the bindings that describe the schema of the resulting source >> > files. The bindings must be validated against a binding schema. >> > >> > For the source files, at first they must be valid against the core >> > language (i.e. DTS or DT YAML variant) schema. >> > >> > Next for each node that a binding exists in a valid format, it must be >> > validated against it. I.e. if an interrupt property exist it must point >> > to valid interrupt node etc. >> > >> > Up next a number of per-platform/configuration validation passes. >> > I.e. for a complete source file which is using a specific SoC family >> > i.e. "ti,am33xx" the pass may verify that for the given peripherals >> > their configuration is correct, i.e. that the interrupt numbers for a >> > given peripheral are the correct ones for the target board etc. >> > This may be possible by having a golden master configuration when those >> > number can be retrieved and compared against. >> > >> > Finally you could have a per-application/vendor/end-user final rule >> > check, i.e. the regulators may be configured in a manner that the power >> > consumption is under some specified threshold, etc. This is something >> > that is completely out of the kernel scope, but may have have to >> > vendors. >> > >> > Why don't you share what you've been working on and see what we can do >> > using it as a base? >> >> I did. 2 years ago: >> >> https://git.kernel.org/pub/scm/linux/kernel/git/robh/linux.git/log/?h=dt-yaml-v2 >> >> It's very rough, but I was at the point of wanting feedback on the >> schema format. Only the crickets gave me any. >> >> It doesn't validate anything, but is purely binding docs mass >> converted to YAML using DTS files as input. >> > > Sorry, missed that; wasn't CCed on it. Sorry, going back thru the thread with Matt's proposal[1], looks like I must have only given Matt the link. Anyway, there's still open issues about the doc format to discuss in the thread. > I can certainly use it. You haven't looked at my hacky bash and 1st attempt at Python. ;) >> >> >> Maybe you're not proposing that now, but if that is not the end goal I >> >> >> don't see the point of a new format. If YAML solves a bunch of >> >> >> problems, then of course we'd want to convert DTS files at some point. >> >> > >> >> > To borrow that same phrase again, Tooling, Tooling, Tooling. The >> >> > current dts format is a niche format. That's great, our community >> >> > is basically responsible for all tooling, we can do what we want. >> >> > That's also awful, we're the only people that care about tooling and we >> >> > all have lots of other itches to scratch. There are so so so many >> >> > editors that just know YAML and will work it into the rest of the >> >> > development environment someone is using. None of that exists for our >> >> > dts format. Who cares about that? Engineers that aren't primarily >> >> > writing dts files. I'm pretty sure every engineer that's written / >> >> > extended a dts file has made an "invisible" mistake that would have been >> >> > caught with a different source format that had validation already. >> >> >> >> The same can be said about DTB format as well. >> >> >> >> > And we've been talking about validation for ages now. We'll probably >> >> > still be talking about it for ages more (as it's hard >> >> > thanked-at-conferences-and-such work!), until it reaches the point where >> >> > anyone can pick up a current binding and re-format it into yaml for >> >> > validation. >> >> >> >> I did state earlier that I think this tool has uses, but on it's own >> >> and only to change from dts to yaml source files, I don't see it. >> >> Let's start with validation and define the schema for that and tools >> >> for that. If that involves dts to yaml in the flow, I don't really >> >> care. >> >> >> >> Or if it is type checking that Pantelis keeps mentioning, then let's >> >> discuss that. Those are different problems. >> >> >> > >> > Let's discuss it then. >> > I've laid out my plans to add type-checking in the compiler pass using >> > YAML. What is the plan for DTC? >> >> But you haven't. You've said YAML can do type checking, but no >> concrete example. Say I have: >> >> int-prop = <1234>; >> string-prop = "some string"; >> >> How do I go from that whether in DTS or YAML to type information as >> input to the compiler and/or in the dtb? >> > > DTC throws that away as I know. yamldt carries everything until the emit > phase and can tell you a) what sequence of values comprise the property, > and what the textual representation of it is. It also tracks whether > the property had an explicit tag or not. > > So let's take this example you've posted. > > 'int-prop = <1234>;' > > would be written as > > 'int-prop: 1234'. > > This is without an explicit tag and is marked as a scalar. yamldt will > attempt to evaluate '1234' as an integer expression and it will succeed, > tagging it as an !int internally. > > 'int-prop: !int 1234' > > The type checker would search for the node's property compatible string, > locate the appropriate binding doc/schema. It will be loaded and if a > matching property entry is found it will be validated. > > For instance if an entry such as the following exists: > > --- > properties: > - name: int-prop > category: required > description: An example int property > accepts-type: [ "!int", "!int8", "!int16", "!int32", "!int64" ] > type: "!int64" Okay, but this isn't a YAML version of DTS. It's a schema. This is what we should be discussing. Any tools that work with this are secondary at this point IMO. > --- > > The property would be promoted to "!int64" and a 64 bit value would be > generated in the DTB file. > > Attempting to use that value as another type it would throw an error. > > The 'string-prop = "some string"' line would be explicitly set to "!str" > since that's what the double quotes explicitly denote. > > A more complicated example would be something to match gpio references. > > For example to check the types of a > > 'gpios = <&gpio1 10 1>, <&gpio2 4 2>;' > > type of property it would be converted to YAML > > gpios: [ [ *gpio1 10 1], [ *gpio2 4 2 ] ] > > > --- > properties: > - name: gpio > category: required > description: An example of a gpio property that contains gpios > accepts-type: > - [ "*!*!gpio-controller", "!int", "#int!*gpio!#gpio-cells"-1 ] > - "*" This is a good example of one of my concerns. I really don't want to repeat this somewhat complicated accepts-type value for every single *-gpios property description. We need to have some inheritance. We're also going to need a checker for the schema. I'd suggest you start with picking up Matt's proposal and going from there. There's a number of open issues such as how to do logical expressions. It's the schema format that I'm interested in first. The tools and validation of dts files can come somewhat later. IMO, the sooner we can define that, the better. Even if we have to evolve the format a bit. Once it is machine parseable we can more easily tweak the format. The Zephyr guys are also using YAML for their DT docs. I'm guessing you or Matt are somewhat plugged into that already? We need to align with them. Rob [1] http://www.mail-archive.com/devicetree-spec@xxxxxxxxxxxxxxx/msg00181.html -- To unsubscribe from this list: send the line "unsubscribe devicetree-compiler" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html