Re: [RFC] Introducing yamldt, a yaml to dtb compiler

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On Thu, 2017-07-27 at 13:09 -0500, Rob Herring wrote:
> On Thu, Jul 27, 2017 at 11:49 AM, Pantelis Antoniou
> <pantelis.antoniou@xxxxxxxxxxxx> wrote:
> > Hi all,
> >
> > This is a project I've been working on lately and it's finally in a
> > usuable form.
> >
> > I'm introducing yamldt.
> >
> > A YAML to DT blob generator/compiler, utilizing a YAML schema that is
> > functionaly equivalent to DTS and supports all DTS features.
> 
> What problem are you trying to solve?
> 

I am demonstrating that the DTS source format is not the only way to
describe hardware and generate a DTB that is functionally equivalent.

I feel that the reliance on DTS has been holding progress back in
expressing modern hardware and having a tool that generates DTB as well
will allow me to experiment in ways that things like overlays and
portable overlays can be defined.

> > yamldl parses a device tree description (source) file in YAML format and
> > outputs a (bit-exact if the -C option is used) device tree blob.
> >
> > A DT aware YAML schema is a good fit as a DTS syntax alternative.
> >
> > YAML is a human-readable data serialization language, and is expressive
> > enough to cover all DTS source features.
> >
> > Simple YAML files are just key value pairs that are very easy to parse,
> > even without using a formal YAML parser. For instance YAML in restricted
> > environments may simple be appending a few lines of text in a given YAML
> > file.
> >
> > The parsers of YAML are very mature, as it has been released in 2001. It
> > is in wide-spread use and schema validation tools are available. YAML
> > support is available for every major programming language.
> >
> > Data in YAML can easily be converted to/form other format that a
> > particular tool that we may use in the future understands.
> >
> > More importantly YAML offers (an optional) type information for each
> > data, which is IMHO crucial for thorough validation and checking against
> > device tree bindings (when they will be converted to a machine readable
> > format, preferably YAML).
> 
> We have type information in dts. We can distinguish numbers, strings,
> phandles, etc. The problem is we loose that information in the DTB and
> this does nothing to help that problem.
> 

This is not enough information IMO. We not only need those scalar types
but type information about references (what phandles really are) and
use them to enforce type checking and promotion.

And of course DTS throws away all type information away and has no
way to be extended. In YAML this is a solved problem. 

> >
> > For more take a look here.
> >
> > https://github.com/pantoniou/yamldt
> 
> Looking at the example, I find the syntax harder to follow. Parsing
> what are node names vs labels is one. Relying on indentation for tree
> hierarchy is another.
> 

This is really debatable. You can use curly braces if you don't like the
indentation.

I.e.

foo:
  bar: true

Can be written as
foo: { bar: true }

YAML is a JSON superset which uses the curly braces as a map separator.

And frankly there are about x1000 more people aware of YAML syntax than
DTS syntax.

> Does C preprocessing of the YAML files work? I'm surprised if it does.
> 

I think you should check the code out and see for yourself.

The complete set of C preprocessing of DTS is available, and works
perfectly AFAIKT.

> >
> > I am eagerly awaiting for your comments.
> 
> I could see some uses here to extract data from dts files more easily.
> For example, to extract all compatible strings for some set of dts
> files. I did this by hacking dtc to dump them. Or as a starting point
> to create YAML based DT binding schema. I wonder how Grant is coming
> along with that.
> 
> Rob


--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]


  Powered by Linux