[U-Boot] [PATCH]: Smart Autoboot
Wolfgang Denk
wd at denx.de
Thu Apr 28 15:41:45 CEST 2011
Dear "Johannes Thoma",
In message <20110428125810.123810 at gmx.net> you wrote:
>
> I wrote a small patch that checks on autoboot if the image is a kernel
> image and if not assumes that it is a standalone image. If the image
> is kernel do_bootm is used else (unconditionally) do_go is used.
> This is handy if you are working with test applications and kernels,
> since you only need to reconfigure your DHCP server and don't need
> to re-flash u-boot.
The same can be done with minimal scripting, without changing any
code. Your solution may work for you, but I don't think this is how
to solve such an issue in general.
> Since I am new to u-boot I'd like to ask if the following patch
> is formatted correctly (I have used git format-patch) and if
> there is the possiblity to add this feature to mainline UBoot.
Second part of the question first: I consider this a highly specific
feature which is not needed by many people, and if it was needed, if
can be implemented with mninimal scripting, so I don't think adding
this code to mainline is a good idea.
For the formal issues: most things look good, except:
> From c631d05e225fa3f87b0a5cad0bb033063e61018c Mon Sep 17 00:00:00 2001
> From: Johannes Thoma <johannes.thoma at gmx.at>
> Date: Thu, 28 Apr 2011 14:25:39 +0200
> Subject: [PATCH] Smart autoboot
>
> We check if the image is a kernel image and use bootm command
> to boot the OS, else we do a go.
>
> To use this feature, #define CONFIG_SMART_AUTOBOOT in your config
> and set the environment variable autostart to "yes". Then your
> DHCP driver can be used to either boot a kernel image or a
> u-boot application without changing anything on the target.
Signed-off-by: line missing.
> ---
> README | 5 +++++
> common/cmd_net.c | 25 +++++++++++++++++++++++--
> 2 files changed, 28 insertions(+), 2 deletions(-)
...
> +extern int do_bootm (cmd_tbl_t *, int, int, char * const []);
> +#ifdef CONFIG_SMART_AUTOBOOT
> +extern int do_go (cmd_tbl_t *, int, int, char * const []);
externs should be avoided; use prototype declarations in the
respective header files.
> +
> +
Don't add too much white space - a single blank line is enough.
> static int netboot_common (proto_t, cmd_tbl_t *, int , char * const []);
>
> int do_bootp (cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
> @@ -212,14 +218,29 @@ netboot_common (proto_t proto, cmd_tbl_t *cmdtp, int argc, char * const argv[])
>
> /* Loading ok, check if we should attempt an auto-start */
> if (((s = getenv("autostart")) != NULL) && (strcmp(s,"yes") == 0)) {
> - char *local_args[2];
> + char *local_args[3];
Indentation must be done by TABs, not spaces.
...
> +#ifdef CONFIG_SMART_AUTOBOOT
> + if (image_get_type((void*) load_addr) == IH_TYPE_KERNEL)
Don't add trailing white space.
It appears you did not run checkpatch, which would have caught most
of these issues.
Best regards,
Wolfgang Denk
--
DENX Software Engineering GmbH, MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd at denx.de
Abstainer: A weak person who yields to the temptation of denying him-
self a pleasure. A total abstainer is one who abstains from every-
thing but abstention, and especially from inactivity in the affairs
of others. - Ambrose Bierce
More information about the U-Boot
mailing list