On Thu, 22 Nov 2007 17:10:07 +1100
David Gibson <[EMAIL PROTECTED]> wrote:

> The recent change to the lexer to only recognize property and node
> names in the appropriate context removed a number of lexical warts in
> our language that would have gotten ugly as we add expression support
> and so forth.
> 
> But there's one nasty one remaining: references can contain a full
> path, including the various problematic node name characters (',', '+'
> and '-', for example).  This would cause trouble with expressions, and
> it also causes trouble with the patch I'm working on to allow
> expanding references to paths rather than phandles.  This patch
> therefore reworks the lexer to mitigate these problems.
> 
>       - References to labels cause no problems.  These are now
> recognized separately from references to full paths.  No syntax change
> here.
> 
>       - References to full paths, including problematic characters
> are allowed by "quoting" the path with braces
> e.g. &{/[EMAIL PROTECTED]/[EMAIL PROTECTED],8000}.  The braces protect any 
> internal
> problematic characters from being confused with operators or whatever.
> 
>       - For compatibility with existing dts files, in v0 dts files
> we allow bare references to paths as before &/foo/bar/whatever - but
> *only* if the path contains no troublesome characters.  Specifically
> only [a-zA-Z0-9_@/] are allowed.
> 
> This is an incompatible change to the dts-v1 format, but since AFAIK
> no-one has yet switched to dts-v1 files, I think we can get away with
> it.  Better to make the transition when people to convert to v1, and
> get rid of the problematic old syntax.
> 
> Strictly speaking, it's also an incompatible change to the v0 format,
> since some path references that were allowed before are no longer
> allowed.  I suspect no-one has been using the no-longer-supported
> forms (certainly none of the kernel dts files will cause trouble).  We
> might need to think about this harder, though.
> 
> Signed-off-by: David Gibson <[EMAIL PROTECTED]>

So this breaks some of the in-kernel DTS files.  Example, bamboo.dts on
line 19 produces:

bamboo.dts: 19 syntax error
FATAL ERROR: Couldn't read input tree

I tried quoting the path with {} but that didn't seem to work.

josh
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to