From: AKASHI Takahiro <takahiro.akashi@linaro.org>
To: u-boot@lists.denx.de
Subject: [PATCH v3 04/17] common: update: add a generic interface for FIT image
Date: Thu, 16 Jul 2020 09:43:13 +0900 [thread overview]
Message-ID: <20200716004313.GA12429@laputa> (raw)
In-Reply-To: <132be7f0-77dc-5b53-76a9-d0d2dbc48fca@gmx.de>
Heinrich,
On Wed, Jul 15, 2020 at 09:07:26AM +0200, Heinrich Schuchardt wrote:
> On 15.07.20 06:28, AKASHI Takahiro wrote:
> > Heinrich,
> >
> > On Fri, Jul 10, 2020 at 06:24:45PM +0200, Heinrich Schuchardt wrote:
> >> On 10.07.20 03:25, AKASHI Takahiro wrote:
> >>> The main purpose of this patch is to separate a generic interface for
> >>> updating firmware using DFU drivers from "auto-update" via tftp.
> >>>
> >>> This function will also be used in implementing UEFI capsule update
> >>> in a later commit.
> >>>
> >>> Signed-off-by: AKASHI Takahiro <takahiro.akashi@linaro.org>
> >>> ---
> >>> common/Kconfig | 16 +++++++++++
> >>> common/Makefile | 2 +-
> >>> common/update.c | 75 +++++++++++++++++++++++++++++++++++++++++++++++--
> >>> include/image.h | 12 ++++++++
> >>> 4 files changed, 102 insertions(+), 3 deletions(-)
> >>>
> >>> diff --git a/common/Kconfig b/common/Kconfig
> >>> index 2d86dd7e63c6..a51d2a7b9d2a 100644
> >>> --- a/common/Kconfig
> >>> +++ b/common/Kconfig
> >>> @@ -985,9 +985,16 @@ endmenu
> >>>
> >>> menu "Update support"
> >>>
> >>> +config UPDATE_COMMON
> >>> + bool
> >>> + default n
> >>> + select DFU_ALT
> >>> +
> >>> config UPDATE_TFTP
> >>> bool "Auto-update using fitImage via TFTP"
> >>> depends on FIT
> >>> + depends on DFU
> >>> + select UPDATE_COMMON
> >>> help
> >>> This option allows performing update of NOR with data in fitImage
> >>> sent via TFTP boot.
> >>> @@ -1002,6 +1009,15 @@ config UPDATE_TFTP_MSEC_MAX
> >>> default 100
> >>> depends on UPDATE_TFTP
> >>>
> >>> +config UPDATE_FIT
> >>> + bool "Firmware update using fitImage"
> >>> + depends on FIT
> >>> + depends on DFU
> >>> + select UPDATE_COMMON
> >>> + help
> >>> + This option allows performing update of DFU-capable storage with
> >>> + data in fitImage.
> >>> +
> >>> config ANDROID_AB
> >>> bool "Android A/B updates"
> >>> default n
> >>> diff --git a/common/Makefile b/common/Makefile
> >>> index 2e7a090588d9..c238db8108e7 100644
> >>> --- a/common/Makefile
> >>> +++ b/common/Makefile
> >>> @@ -53,7 +53,7 @@ obj-$(CONFIG_LCD_ROTATION) += lcd_console_rotation.o
> >>> obj-$(CONFIG_LCD_DT_SIMPLEFB) += lcd_simplefb.o
> >>> obj-$(CONFIG_LYNXKDI) += lynxkdi.o
> >>> obj-$(CONFIG_MENU) += menu.o
> >>> -obj-$(CONFIG_UPDATE_TFTP) += update.o
> >>> +obj-$(CONFIG_UPDATE_COMMON) += update.o
> >>> obj-$(CONFIG_DFU_TFTP) += update.o
> >>> obj-$(CONFIG_USB_KEYBOARD) += usb_kbd.o
> >>> obj-$(CONFIG_CMDLINE) += cli_readline.o cli_simple.o
> >>> diff --git a/common/update.c b/common/update.c
> >>> index 3547dc68bf7c..a8151383fae7 100644
> >>> --- a/common/update.c
> >>> +++ b/common/update.c
> >>> @@ -24,6 +24,7 @@
> >>> #include <errno.h>
> >>> #include <mtd/cfi_flash.h>
> >>>
> >>> +#ifdef CONFIG_UPDATE_TFTP
> >>> /* env variable holding the location of the update file */
> >>> #define UPDATE_FILE_ENV "updatefile"
> >>>
> >>> @@ -211,6 +212,7 @@ static int update_flash(ulong addr_source, ulong addr_first, ulong size)
> >>> return 1;
> >>> #endif
> >>> }
> >>> +#endif /* CONFIG_UPDATE_TFTP */
> >>>
> >>> static int update_fit_getparams(const void *fit, int noffset, ulong *addr,
> >>> ulong *fladdr, ulong *size)
> >>> @@ -228,6 +230,7 @@ static int update_fit_getparams(const void *fit, int noffset, ulong *addr,
> >>> return 0;
> >>> }
> >>>
> >>> +#ifdef CONFIG_UPDATE_TFTP
> >>> int update_tftp(ulong addr, char *interface, char *devstring)
> >>> {
> >>> char *filename, *env_addr, *fit_image_name;
> >>> @@ -322,8 +325,9 @@ got_update_file:
> >>> }
> >>> } else if (fit_image_check_type(fit, noffset,
> >>> IH_TYPE_FIRMWARE)) {
> >>> - ret = dfu_tftp_write(fit_image_name, update_addr,
> >>> - update_size, interface, devstring);
> >>> + ret = dfu_write_by_name(fit_image_name, update_addr,
> >>> + update_size, interface,
> >>> + devstring);
> >>> if (ret)
> >>> return ret;
> >>> }
> >>> @@ -333,3 +337,70 @@ next_node:
> >>>
> >>> return ret;
> >>> }
> >>> +#endif
> >>> +
> >>> +#ifdef CONFIG_UPDATE_FIT
> >>> +/**
> >>> + * fit_update - update storage with FIT image
> >>> + * @fit: Pointer to FIT image
> >>> + *
> >>> + * Update firmware on storage using FIT image as input.
> >>> + * The storage area to be update will be identified by the name
> >>> + * in FIT and matching it to "dfu_alt_info" variable.
> >>> + *
> >>> + * Return: 0 - on success, non-zero - otherwise
> >>> + */
> >>> +int fit_update(const void *fit)
> >>
> >> With patch
> >>
> >> cmd: drop fitupd command
> >> https://patchwork.ozlabs.org/project/uboot/patch/20200617090903.9268-1-xypron.glpk at gmx.de/
> >>
> >> the fitupd command is removed.
> >>
> >> Lukasz has to put the patch into a pull request, yet
> >>
> >> Once that patch has been inserted only the automatic fit updates will
> >> use code in common/update.c. This code is not called by the 'dfu tftp'
> >> command.
> >
> > ?
> > In cmd/dfu.c,
> > ===8<===
> > #ifdef CONFIG_DFU_OVER_TFTP
> > if (!strcmp(argv[1], "tftp"))
> > return update_tftp(value, interface, devstring);
> > #endif
> > ===>8===
> >
> >> The function fit_update() that you create should be considered a part of
> >> the dfu framework and should be placed in drivers/dfu/dfu.c. Please,
> >> give it a name starting with dfu_.
> >
> > Please read my code carefully.
> > There are some helper functions common to update_tftp() and
> > fit_update(). There is a good reason why I put this code in this file.
>
> common/update.c should be completely dropped from U-Boot because it is
> not used by any board and the dfu command can be used instead.
As I said in my previous email, update_tftp() is used in cmd/dfu.c.
> The DFU API is described in include/dfu.h. This is sufficient to
> implement an update. I agree that it may make sense to provide functions
> at a higher abstraction level. These functions should be in drivers/dfu/.
Which part of my code do you think is 'functions at a higher abstraction
level'?
-Takahiro Akashi
> Best regards
>
> Heinrich
>
> >
> > -Takahiro Akashi
> >
> >> This way there is no need to change the Kconfig for common/update.c as
> >> update.c remains dedicated to automatic updates via tFTP.
> >>
> >> Best regards
> >>
> >> Heinrich
next prev parent reply other threads:[~2020-07-16 0:43 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-07-10 1:25 [PATCH v3 00/17] efi_loader: add capsule update support AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 01/17] common: update_tftp: remove unnecessary build check AKASHI Takahiro
2020-07-10 5:38 ` Heinrich Schuchardt
2020-07-10 1:25 ` [PATCH v3 02/17] dfu: add a hidden reverse-dependency on UPDATE_TFTP AKASHI Takahiro
2020-07-10 5:21 ` Heinrich Schuchardt
2020-07-15 5:14 ` AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 03/17] dfu: rename dfu_tftp_write() to dfu_write_by_name() AKASHI Takahiro
2020-07-10 5:45 ` Heinrich Schuchardt
2020-07-15 5:23 ` AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 04/17] common: update: add a generic interface for FIT image AKASHI Takahiro
2020-07-10 16:24 ` Heinrich Schuchardt
2020-07-15 4:28 ` AKASHI Takahiro
2020-07-15 7:07 ` Heinrich Schuchardt
2020-07-16 0:43 ` AKASHI Takahiro [this message]
2020-07-10 1:25 ` [PATCH v3 05/17] dfu: export dfu_list AKASHI Takahiro
2020-07-10 16:25 ` Heinrich Schuchardt
2020-07-15 4:33 ` AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 06/17] efi_loader: add option to initialise EFI subsystem early AKASHI Takahiro
2020-07-10 16:25 ` Heinrich Schuchardt
2020-07-15 4:41 ` AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 07/17] efi_loader: define UpdateCapsule api AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 08/17] efi_loader: capsule: add capsule_on_disk support AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 09/17] efi_loader: capsule: add memory range capsule definitions AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 10/17] efi_loader: capsule: support firmware update AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 11/17] efi_loader: add firmware management protocol for FIT image AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 12/17] dfu: add dfu_write_by_alt() AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 13/17] efi_loader: add firmware management protocol for raw image AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 14/17] cmd: add "efidebug capsule" command AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 15/17] tools: add mkeficapsule command for UEFI capsule update AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 16/17] test/py: add a test for uefi firmware update capsule of FIT image AKASHI Takahiro
2020-07-10 1:25 ` [PATCH v3 17/17] test/py: add a test for uefi firmware update capsule of raw image AKASHI Takahiro
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=20200716004313.GA12429@laputa \
--to=takahiro.akashi@linaro.org \
--cc=u-boot@lists.denx.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