[PATCH 8/9 V3] Add documentation for the new DTS language.
David Gibson
david at gibson.dropbear.id.au
Wed Oct 1 13:46:56 EST 2008
On Tue, Sep 30, 2008 at 08:55:37AM -0600, Grant Likely wrote:
> On Fri, Sep 26, 2008 at 03:25:47PM -0500, Jon Loeliger wrote:
> > From: Jon Loeliger <jdl at freescale.com>
> >
> > Signed-off-by: Jon Loeliger <jdl at freescale.com>
> > ---
> > Documentation/manual.txt | 500 ++++++++++++++++++++++++++++++++++++++++++----
> > 1 files changed, 463 insertions(+), 37 deletions(-)
>
> Hey Jon,
>
> I don't yet have fully formed thoughts about this stuff so I've held off
> on making comments. But FWIW, here are my initial thoughts.
>
> I'm not convinced about the approach of interleaving the executable and
> data syntaxes. The whole design of the existing syntax is to represent
> the data structure. Adding additional syntax to define executable
> elements doesn't feel right to me. I think many people will find the
> resulting file structure to be confusing.
>
> I'm also not convinced that it is a good idea to implement a new
> interpreted language. Any new language is a new thing that needs to be
> maintained and a new thing for users to learn. I'd prefer to make use
> of an existing language with a library of support routines for
> maintaining an internal representation of the data and building up a
> device tree programmatically with the ability to import and manipulate
> 'stock' nodes for existing parts. However, I haven't spent enough brain
> cell cycles on this to make any recommendations on a specific language
> or to figure out if that will just result in even more complexity for
> users.
>
> As I said, these are just initial thoughts. My opinion could be
> swayed.
Ah, thank you Grant, you've helped clarify by own objections to the
current proposal.
The current device tree description is purely declarative, but this
proposal would make it a rather odd hybrid of declarative and
imperative components. I do think this could be confusing,
particularly to device tree newcomers who may not realise which
components are compile time evaluated and which go into the output
tree. I had in mind a rather more functional-programming style for
macros/computed properties to ameliorate this.
The several new components of not-C-feel syntax worry me greatly. If
you recall the one time I stepped away from C-inspired syntax in the
original language (bare hex constants), turned out to be a big mistake
requiring an incompatible source format change to fix. I really want
to avoid doing that again, if we possibly can.
I'm also concerned about adding language-level functions to the
language. This requires us to have runtime notions of type and
symbols and carry them around for evaluation. I still favour a
macro-expansion style preprocessing stage instead of semantic-level
functions for several reasons:
- it provides high flexibility for low conceptual complexity
- we don't have to carry around run-time evaluation structures
- it's a form familiar to C programmers from the preprocessor
This could either be done by actually invoking cpp, using some
pre-and-post mangling to deal with the #-in-property-names problem.
Or we could build our own preprocessor that uses something other than
# as a magic character, but otherwise works like cpp.
--
David Gibson | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_
| _way_ _around_!
http://www.ozlabs.org/~dgibson
More information about the devicetree-discuss
mailing list