From: Michael Olbrich <m.olbrich@pengutronix.de>
To: ptxdist@pengutronix.de
Cc: Denis OSTERLAND <denis.osterland@diehl.com>,
Ahmad Fatoum <a.fatoum@pengutronix.de>
Subject: Re: [ptxdist] [PATCH 2/2] u-boot: Allow generation of boot script
Date: Fri, 12 Apr 2019 09:49:18 +0200 [thread overview]
Message-ID: <20190412074918.3us5zohml6sqdz2y@pengutronix.de> (raw)
In-Reply-To: <20190411110937.27761-3-ada@thorsis.com>
On Thu, Apr 11, 2019 at 01:09:37PM +0200, Alexander Dahl wrote:
> From: Ahmad Fatoum <a.fatoum@pengutronix.de>
>
> U-Boot can be configured via the environment to look for a boot script
> in the rootfs. The boot script can then be used to customize the booting
> process further.
>
> Cc: Denis OSTERLAND <denis.osterland@diehl.com>
> Co-authored-by: Alexander Dahl <ada@thorsis.com>
> Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
> Signed-off-by: Alexander Dahl <ada@thorsis.com>
> ---
>
> Notes:
> Changes from the original patch by Ahmad:
>
> * Added compile stage from patch adding precompiled U-Boot env, but
> changed compile command to '@$(call world/compile, <PKG>)' as
> suggested by Denis OSTERLAND. (That patch was not merged upstream.)
> * Changed default script filename to 'boot.scr.uimg', because this is
> one of the defaults in 'config_distro_bootcmd.h' in U-Boot. (Took me
> only half a day to find why the script was not found here.)
>
> platforms/u-boot.in | 18 ++++++++++++++++++
> rules/u-boot.make | 32 ++++++++++++++++++++++++++++++++
> 2 files changed, 50 insertions(+)
>
> diff --git a/platforms/u-boot.in b/platforms/u-boot.in
> index 5d04a3cbd..8af0c8271 100644
> --- a/platforms/u-boot.in
> +++ b/platforms/u-boot.in
> @@ -71,6 +71,24 @@ config U_BOOT_CONFIG
>
> endif
>
> +config U_BOOT_BOOT_SCRIPT
> + prompt "Compile U-Boot boot script"
> + bool
> + help
> + Use U-Boot's mkimage to compile a U-Boot boot script and install it
> + into the rootfs
> +
> +if U_BOOT_BOOT_SCRIPT
> +
> +config U_BOOT_BOOT_SCRIPT_ROOTFS_PATH
> + string
> + default "/boot/boot.scr.uimg"
> + prompt "Installation path"
> + help
> + Target rootfs path where the U-Boot script should be located
> +
> +endif
> +
> comment "target install"
>
> config U_BOOT_INSTALL_SREC
> diff --git a/rules/u-boot.make b/rules/u-boot.make
> index 55d18b97d..277216af9 100644
> --- a/rules/u-boot.make
> +++ b/rules/u-boot.make
> @@ -2,6 +2,7 @@
> #
> # Copyright (C) 2007 by Sascha Hauer
> # 2009, 2010 by Marc Kleine-Budde <mkl@pengutronix.de>
> +# 2018 by Ahmad Fatoum <a.fatoum@pengutronix.de>
> #
> # See CREDITS for details about who has contributed to this project.
> #
> @@ -34,6 +35,10 @@ endif
> # Prepare
> # ----------------------------------------------------------------------------
>
ifdef PTXCONF_U_BOOT_BOOT_SCRIPT
> +U_BOOT_BOOT_SCRIPT_TXT := $(call ptx/in-platformconfigdir, uboot.scr)
> +U_BOOT_BOOT_SCRIPT_BIN := $(call remove_quotes, \
> + $(PTXCONF_U_BOOT_BOOT_SCRIPT_ROOTFS_PATH))
$(STATEDIR)/u-boot.compile: $(U_BOOT_BOOT_SCRIPT_TXT)
endif
While ptx/in-platformconfigdir is not as slow as ptx/get-alternative, it
should still be avoided when not needed.
Add the dependency to ensure changes are propagated.
> U_BOOT_WRAPPER_BLACKLIST := \
> TARGET_HARDEN_STACKCLASH \
> TARGET_HARDEN_RELRO \
> @@ -82,6 +87,20 @@ $(STATEDIR)/u-boot.prepare:
> endif
>
> # ----------------------------------------------------------------------------
> +# Compile
> +# ----------------------------------------------------------------------------
> +
> +$(STATEDIR)/u-boot.compile:
> + @$(call targetinfo)
> + @$(call world/compile, U_BOOT)
> +ifdef PTXCONF_U_BOOT_BOOT_SCRIPT
> + @$(U_BOOT_DIR)/tools/mkimage -T script -C none \
> + -d $(U_BOOT_BOOT_SCRIPT_TXT) \
> + $(U_BOOT_DIR)/uboot.scr
I don't mind the name, but you could use
'$(notdir $(U_BOOT_BOOT_SCRIPT_TXT))' here and below.
Michael
> +endif
> + @$(call touch)
> +
> +# ----------------------------------------------------------------------------
> # Install
> # ----------------------------------------------------------------------------
>
> @@ -122,6 +141,19 @@ ifdef PTXCONF_U_BOOT_INSTALL_U_BOOT_WITH_SPL_PBL
> @install -v -D -m644 $(U_BOOT_DIR)/u-boot-with-spl-pbl.bin \
> $(IMAGEDIR)/u-boot-with-spl-pbl.bin
> endif
> +
> +ifdef PTXCONF_U_BOOT_BOOT_SCRIPT
> + @$(call install_init, u-boot)
> + @$(call install_fixup, u-boot, PRIORITY, optional)
> + @$(call install_fixup, u-boot, SECTION, base)
> + @$(call install_fixup, u-boot, AUTHOR, "Ahmad Fatoum <afa@pengutronix.de>")
> + @$(call install_fixup, u-boot, DESCRIPTION, "U-Boot boot script")
> +
> + @$(call install_copy, u-boot, 0, 0, 0644, \
> + $(U_BOOT_DIR)/uboot.scr, $(U_BOOT_BOOT_SCRIPT_BIN))
> +
> + @$(call install_finish, u-boot)
> +endif
> @$(call touch)
>
> # ----------------------------------------------------------------------------
> --
> 2.11.0
>
>
> _______________________________________________
> ptxdist mailing list
> ptxdist@pengutronix.de
--
Pengutronix e.K. | |
Industrial Linux Solutions | http://www.pengutronix.de/ |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 |
Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |
_______________________________________________
ptxdist mailing list
ptxdist@pengutronix.de
next prev parent reply other threads:[~2019-04-12 7:49 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-04-11 11:09 [ptxdist] [PATCH 0/2] u-boot: boot script and series option Alexander Dahl
2019-04-11 11:09 ` [ptxdist] [PATCH 1/2] Revert "readd _SERIES option for u-boot and add it for at91bootstrap (partially reverts dac31c4)" Alexander Dahl
2019-04-11 11:09 ` [ptxdist] [PATCH 2/2] u-boot: Allow generation of boot script Alexander Dahl
2019-04-11 13:05 ` Denis OSTERLAND
2019-04-12 7:49 ` Michael Olbrich [this message]
2019-04-12 13:17 ` Alexander Dahl
2019-04-12 14:09 ` Michael Olbrich
2019-04-12 14:17 ` Alexander Dahl
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20190412074918.3us5zohml6sqdz2y@pengutronix.de \
--to=m.olbrich@pengutronix.de \
--cc=a.fatoum@pengutronix.de \
--cc=denis.osterland@diehl.com \
--cc=ptxdist@pengutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox