[U-Boot] [PATCH] fdt: Enhance dts/Makefile to be all things to all men
Simon Glass
sjg at chromium.org
Thu May 30 07:33:29 CEST 2013
Hi Stephen,
On Wed, May 29, 2013 at 10:11 PM, Stephen Warren <swarren at wwwdotorg.org>wrote:
> On 05/29/2013 10:46 PM, Simon Glass wrote:
> > Hi,
> >
> > On Wed, May 29, 2013 at 4:07 PM, Stephen Warren <swarren at wwwdotorg.org
> > <mailto:swarren at wwwdotorg.org>> wrote:
> >
> > On 05/29/2013 04:36 PM, Wolfgang Denk wrote:
> > > Dear Stephen Warren,
> > >
> > > In message <51A67EC1.2000208 at wwwdotorg.org
> > <mailto:51A67EC1.2000208 at wwwdotorg.org>> you wrote:
> > >>
> > >> To keep this process in check a bit, we could always pick a
> > specific git
> > >> commit or release version of dtc that each U-Boot version
> > (release) will
> > >> be allowed to assume. That will limit the number of times people
> > need to
> > >> update their locally-built dtc to at most once per U-Boot release.
> > >> Hopefully much less often.
> > >
> > > I think this is broken by design, in several aspects. First,
> U-Boot
> > > is usually not the only user of DTC. Second, assume you run a "git
> > > bisect" over a U-Boot tree - would you really want to switch DTC
> in-
> > > flight?
> > >
> > > Sorry, instead we should strive to be compatible to a reasonably
> old,
> > > stable version of DTC, like we do for all other tools as well. As
> > > mentioned before - just because RHEL 5 ships an ancient version of
> -
> > > say - "make" we will NOT start building this from the sources
> ourself.
> > > This cannot be the way to go.
> >
> > So the result of that is that we can never ever use new features in
> any
> > tool, at least in any meaningful time-frame.
> >
> > I think we need to differentiate between tools that are already
> stable
> > and/or core to all aspects of the U-Boot build process (such as
> make),
> > and tools that enable new features that are under development.
> >
> > Clearly the U-Boot makefiles have to be fairly cautious in their use
> of
> > any new make features, so that everyone with any reasonable version
> of
> > make can build U-Boot.
> >
> > However, when enabling a new feature, such as using device trees to
> > configure U-Boot[1], for which tool support is new and evolving along
> > with the feature itself, and which is only used on a very very few
> > boards and even fewer SoCs right now within U-Boot, it seems entirely
> > reasonable to demand that the people working on/with that new feature
> > are aware that it's evolving, and that they may need to take a few
> extra
> > steps to go out and get tools that support that new feature. No doubt
> > once this feature has settled down a bit, and distros have pulled in
> > newer versions of dtc, everthing will "just work" just like any other
> > stable feature.
> >
> > If you don't accept this, then we simply have to ban any include use
> in
> > U-Boot; dtc -i isn't in distro-packaged versions of dtc, so we'd
> need to
> > stop using that. We'd need to move *.dts into a single directory
> within
> > U-Boot to work around that, or perhaps hard-coding relative include
> > paths in *.dts might work. Similarly for the patches to support
> dtc+cpp
> > usage, so we wouldn't be able to use named constants in DT files for
> > many years, which would prevent sharing DT files with the kernel
> and/or
> > any other standard repository of DT files, which are bound to use
> this
> > feature.
> >
> > [1] Which is very specifically a different feature than simply having
> > U-Boot pass a DT to the Linux kernel during boot, and perhaps modify
> it
> > a little, which clearly is not a new feature.
> >
> >
> > My patch:
> >
> > - doesn't require -i but uses it if available (ARCH_CPU_DTS works around
> > this)
>
I had to remove all sharp objects from the room half-way through reading
your email :-) Gosh, things aren't that bad!
>
> If we ever need to support a dtc that doesn't implement -i, then we
> always need to support that. So, there's no point using -i when it's
> available; we should simply have a single way of writing the *.dts files
> that doesn't ever assume dtc -i is available. Otherwise, there will be
> rampant inconsistency between different *.dts files; how they're
> written, the flow by which they're compiled, etc.
>
> In other words, we /always/ have to use "ARCH_CPU_DTS" in *.dts
> throughout the entire U-Boot source tree if we're to support not using
> dtc -i.
>
Well realistically at some point there will be a new dtc release, and
perhaps a year or so after that we can maybe start deprecating this and
requiring -i.
>
> > - honours #define, #include, etc.
> > - works with old and new versions of dtc
>
> If we are forced to rely only upon features in old versions of dtc, we
> specifically shouldn't allow use of features that will only work with
> newer dtc. If we don't actively enforce this rule, we haven't achieved
> the goal of not relying upon new versions of dtc.
>
As you know I'm uncomfortable with the idea of using CPP to do things that
I feel dtc should do for itself, but yes if dtc does not grow these
features, we have little choice. But as an example, both #include and
symbols can be syntactically very similar whether CPP is used or not.
>
> ...
> > However, let's say Tegra needs a newer dtc than 1.3. I wonder whether we
>
> This shouldn't be about whether a specific Soc's DT requires some
> feature or not. All the U-Boot *.dts should work the same way.
>
> > should just add a setting to tell U-Boot to not build the device tree at
> > all? The same U-Boot binary can run on many different board times, just
> > needing a different device tree.
>
> Unfortunately, that's not remotely true yet for any Tegra system at
> least; there's still a bunch of C code specific to each board. The
> amount is reducing as things get migrated to DT, but we certainly aren't
> there yet.
>
OK, but that wasn't quite my point....
>
> > Rather than pick one, we could just
> > pick none. Then if you want to use new features in dtc, just define
> > CONFIG_OF_NO_BUILD, or similar, and you can deal with the device tree
> > details yourself. MAKEALL/buildman will be happy with this.
>
> So you're saying: move the *.dts files out of U-Boot into some separate
> project. It'd be nice to do that; hopefully that separate project could
> be the one where the kernel's *.dts files move to. The big issue here is
> that the DT bindings U-Boot uses are often different to the standard
> bindings, so U-Boot currently contains U-Boot-specific *.dts so there
> wouldn't be much point moving them out of U-Boot into some common DT
> repository. Again, hopefully that's changing over time, but we're still
> not there yet.
>
a. I didn't say move them out of U-Boot
b. If there are differences between the U-Boot and kernel bindings, we
should fix that
c. My point was that 'building nothing' fudges the 'failed build' problem
and might be an acceptable compromise. Then Tegra can use the whiz-bang new
features without breaking the build.
>
> > Otherwise for now I think my patch is a reasonable compromise in terms
> > of features.
>
> It seems to be aimed specifically at enabling use of new dtc features
> when present. That seems to be specifically against Wolfgang's goal of
> not requiring new dtc features. There's no point allowing use of new dtc
> features if we can't require them, since there's no fallback when they
> aren't there to use.
>
My patch is specifically designed to provide a fallback when the are not
there to use. I'm not sure how feasible this is long term, but it works for
now.
I have no problem with including dtc in with U-Boot if that is the chosen
approach. It solves some problems. In fact my Kbuild patch set could make
that quite easy. However I do understand Wolfgang's POV that it is
philosophically a dangerous path.
You know my strong support for some sort of symbolic support in dtc, and I
share your frustration that it hasn't happened yet.
Is my patch better than what is there, or is it just making things worse?
Regards,
Simon
More information about the U-Boot
mailing list