Re: using labels for stdout-path

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



On Thu, May 11, 2017 at 08:40:23PM +0200, Uwe Kleine-König wrote:
> Hello,
> 
> On Thu, May 11, 2017 at 10:49:15AM -0500, Rob Herring wrote:
> > +dtc list because labels are purely dts syntax.
> 
> Ah, I wasn't aware that there is a separate list for that. Thanks.
> 
> > On Thu, May 11, 2017 at 8:05 AM, Uwe Kleine-König
> > <u.kleine-koenig@xxxxxxxxxxxxxx> wrote:
> > > Hello,
> > >
> > > on an i.MX28 based machine I want to have the console on &duart with
> > > 115200 Bd, 8 Bit, no parity.
> > >
> > > The options for that are AFAICT:
> > >
> > >  - use an alias, like:
> > >
> > >         stdout-path = "serialX:115200n8";
> > >
> > >    the problem here is, that the duart doesn't have an alias. I guess I
> > >    shouldn't introduce a new one for my setup?
> > >
> > >  - use a label, like:
> > >
> > >         stdout-path = &duart, ":115200n8";
> > >
> > >    This would be the prettiest, but that doesn't work, because there is
> > >    a '\0' separating the path and the options.
> > 
> > You could make that work changing the kernel parsing, but that's
> > probably not a good option if we ever want to support more than 1 out
> > path.
> 
> Good point. That's a good reason to not use this syntax.

Yes, changing the actual property format is a bad idea.

> > >  - use the full path, like:
> > >
> > >         stdout-path = "/apb@80000000/apbx@80040000/serial@80074000:115200n8";
> > >
> > >    This is ugly.
> > >
> > > Do I miss something? Is that worth to introduce new syntax, maybe
> > >
> > >         stdout-path = &duart . ":115200n8";
> > >
> > > or similar?
> > 
> > Seems like we should make a comma be significant in splitting strings.
> > I'm not sure if there's anything relying on "foo" "bar" and "foo",
> > "bar" being the same. At least for numbers, a comma has no meaning, so
> > it would complicate the parsing I'd imagine. Not really an area I'm
> > familiar with.
> 
> "foo" "bar" is a syntax error now (and another obvious candidate for
> string concatination). So writing in the dts

Right.  "foo" "bar" would be my preferred syntax for string
concatenation (the main guiding principle for dts syntax is "be like C
where possible").

> 
> 	stdout-path = &duart ":115200n8";
> 
> and getting the same result as
> 
> 	stdout-path = "/apb@80000000/apbx@80040000/serial@80074000:115200n8";
> 
> looks nicely and consistent with
> 
> 	stdout-path = &duart;
> 
> being equivalent to
> 
> 	stdout-path = "/apb@80000000/apbx@80040000/serial@80074000";
> 
> After a quick look into the dtc sources I imagine that wouldn't be too
> hard to implement for someone being fluent in lex and yacc.

Unfortunately, there are two complications with this.  The more minor
one is that an "implicit" operation like this (no actual operator
symbol) can make things get a bit curly in the grammar - mostly by
allowing potential ambiguity in situations which are obviously
different to a human, but not to the parser.

The bigger problem is that during the parse which is when we're (for
example) evaluating integer expressions, we haven't yet resolved
labels.  So, we can't expand the reference, we just insert a "marker"
in the property bytestring which says to insert the node path later.
That means we can't just have simple code to do a string concatenation
here.  That marker gets expanded later on, once we've resolved all
references.

Note that this is the same reason you can do:
	prop = < (1+2+3) &foo >;
But you can't do
	prop = < (&foo + 1) >;

There are two ways we could deal with this:

   1) The quick and dirty way: special case string append with a
   reference, so that we insert a new type of marker which will be
   expaned to the node path without the final \0.

   2) The complicated but powerful way: rather than (mostly)
   constructing the property values as bytestrings at parse time, we
   just construct the property values as expression trees at parse
   time, then evaluate those expression trees later on, once we're
   able to resolve references.

Approach (2) has been suggested before.  As well as this case it would
be a necessary step for allowing defined "functions" (for integers or
otherwise) in dtc.  It has some nice properties, but it's a rather a
lot of work.

> And probably
> it would be cheap to add the other obvious extensions like:
> 
> 	property = < 0x12 0x43 > "a string" &label /incbin/(filename);

Um.. what?  That's not an obvious extension at all.  The proposed
change is to have (a b) be a string concatenation, but several of the
things above aren't strings, so it's not clear what it should do.  If
you want _bytestring_ concatenation, we already have syntax for that -
that's exactly what ',' does in dtc.

-- 
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

Attachment: signature.asc
Description: PGP signature


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

  Powered by Linux