On Thu, Sep 08, 2011 at 12:14:44PM +0200, Linus Walleij wrote: > From: Linus Walleij <[email protected]> > > This adds a Kconfig string where you can specify a > file to be appended to the zImage on build, then > auto-appends it. The idea is to mimic how we supply > an initramfs image by a similar parameter. > > This makes it easy to script the kernel build with > different device trees, and it also vastly simplifies > building uImages since "make uImage" will now pick > up the devcie tree and include it in the final image > as part of the build process.
The other option is to encode the .dtb filename into the zImage target name (something like zImage.%). The advantage being that the build can emit multiple .dtb bound images without changing the kernel config. This is what PowerPC currently does. Also, the way this is implemented means that it is no longer possible to emit a zImage without a dtb if the DTB config is set. Personally, I'd use a different target name regardless instead of adjusting the semantics of zImage. g. > > Cc: Nicolas Pitre <[email protected]> > Cc: David Brown <[email protected]> > Cc: Niklas Hernaeus <[email protected]> > Cc: Grant Likely <[email protected]> > Signed-off-by: Linus Walleij <[email protected]> > --- > This builds on top of Nicos pending appended device tree > patches. Nico, if this gains some liking, please include > it in your series. > --- > arch/arm/Kconfig | 10 ++++++++++ > arch/arm/boot/Makefile | 8 +++++++- > 2 files changed, 17 insertions(+), 1 deletions(-) > > diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig > index 4ea9974..cb8ee68 100644 > --- a/arch/arm/Kconfig > +++ b/arch/arm/Kconfig > @@ -1789,6 +1789,16 @@ config ARM_APPENDED_DTB > (dtb) appended to zImage > (e.g. cat zImage <filename>.dtb > zImage_w_dtb). > > +config ARM_APPENDED_DTB_FILE > + string "DTB file" > + depends on ARM_APPENDED_DTB > + default "" > + help > + This gives the name of file from the build directory to append > + to the zImage after it has been built. > + > + If you are not sure, leave it blank. > + > config ARM_ATAG_DTB_COMPAT > bool "Supplement the appended DTB with traditional ATAG information" > depends on ARM_APPENDED_DTB > diff --git a/arch/arm/boot/Makefile b/arch/arm/boot/Makefile > index a1edfd5..5ab6abf 100644 > --- a/arch/arm/boot/Makefile > +++ b/arch/arm/boot/Makefile > @@ -53,8 +53,14 @@ $(obj)/Image: vmlinux FORCE > $(obj)/compressed/vmlinux: $(obj)/Image FORCE > $(Q)$(MAKE) $(build)=$(obj)/compressed $@ > > -$(obj)/zImage: $(obj)/compressed/vmlinux FORCE > +# Rule to optionally append a DTB > +dtbfile := $(shell echo $(CONFIG_ARM_APPENDED_DTB_FILE)) > +quiet_cmd_append = CAT $@ > + cmd_append = (cat /dev/null $(dtbfile) >> $@) > + > +$(obj)/zImage: $(obj)/compressed/vmlinux $(dtbfile) FORCE > $(call if_changed,objcopy) > + $(call if_changed,append) > @echo ' Kernel: $@ is ready' > > endif > -- > 1.7.3.2 > _______________________________________________ devicetree-discuss mailing list [email protected] https://lists.ozlabs.org/listinfo/devicetree-discuss
