From: Lukasz Majewski <lukma@denx.de>
To: u-boot@lists.denx.de
Subject: [U-Boot] [RFC PATCH 03/14] dfu: prepare the support of multiple interface
Date: Mon, 22 Jul 2019 09:57:18 +0200 [thread overview]
Message-ID: <20190722095718.18fae749@jawa> (raw)
In-Reply-To: <1563541046-6432-4-git-send-email-patrick.delaunay@st.com>
Hi Patrick,
> Split the function dfu_config_entities with 2 new functions
> - dfu_alt_init
> - dfu_alt_add
Ok.
>
> Signed-off-by: Patrick Delaunay <patrick.delaunay@st.com>
> ---
>
> drivers/dfu/dfu.c | 51
> +++++++++++++++++++++++++++++++++++++++------------ include/dfu.h
> | 2 ++ 2 files changed, 41 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/dfu/dfu.c b/drivers/dfu/dfu.c
> index eb3a3c6..79a652e 100644
> --- a/drivers/dfu/dfu.c
> +++ b/drivers/dfu/dfu.c
> @@ -438,13 +438,12 @@ void dfu_free_entities(void)
> alt_num_cnt = 0;
> }
>
> -int dfu_config_entities(char *env, char *interface, char *devstr)
> +int dfu_alt_init(int num, struct dfu_entity **dfu)
> {
> - struct dfu_entity *dfu;
> - int i, ret;
> char *s;
> + int ret;
>
> - dfu_alt_num = dfu_find_alt_num(env);
> + dfu_alt_num = num;
> debug("%s: dfu_alt_num=%d\n", __func__, dfu_alt_num);
>
> dfu_hash_algo = NULL;
> @@ -455,21 +454,49 @@ int dfu_config_entities(char *env, char
> *interface, char *devstr) pr_err("Hash algorithm %s not supported\n",
> s); }
>
> - dfu = calloc(sizeof(*dfu), dfu_alt_num);
> - if (!dfu)
> + *dfu = calloc(sizeof(struct dfu_entity), dfu_alt_num);
> + if (!*dfu)
> + return -1;
I'm aware that the dfu.c file in some places uses -1 or -<errno> as
return value.
I would prefer that with new code we shall add -<errno>. In this
particular case it would be -ENOMEM
> +
> + return 0;
> +}
> +
> +int dfu_alt_add(struct dfu_entity *dfu, char *interface, char
> *devstr, char *s) +{
> + struct dfu_entity *p_dfu;
> + int ret;
> +
> + if (alt_num_cnt >= dfu_alt_num)
> + return -1;
> +
> + p_dfu = &dfu[alt_num_cnt];
> + ret = dfu_fill_entity(p_dfu, s, alt_num_cnt, interface,
> devstr);
> + if (ret)
> return -1;
> - for (i = 0; i < dfu_alt_num; i++) {
>
> + list_add_tail(&p_dfu->list, &dfu_list);
> + alt_num_cnt++;
> +
> + return 0;
> +}
> +
> +int dfu_config_entities(char *env, char *interface, char *devstr)
> +{
> + struct dfu_entity *dfu;
> + int i, ret;
> + char *s;
> +
> + ret = dfu_alt_init(dfu_find_alt_num(env), &dfu);
> + if (ret)
> + return -1;
> +
> + for (i = 0; i < dfu_alt_num; i++) {
> s = strsep(&env, ";");
> - ret = dfu_fill_entity(&dfu[i], s, alt_num_cnt,
> interface,
> - devstr);
> + ret = dfu_alt_add(dfu, interface, devstr, s);
> if (ret) {
> /* We will free "dfu" in dfu_free_entities()
> */ return -1;
> }
> -
> - list_add_tail(&dfu[i].list, &dfu_list);
> - alt_num_cnt++;
> }
>
> return 0;
> diff --git a/include/dfu.h b/include/dfu.h
> index bf51ab7..7d60ffc 100644
> --- a/include/dfu.h
> +++ b/include/dfu.h
> @@ -143,6 +143,8 @@ struct dfu_entity {
> #ifdef CONFIG_SET_DFU_ALT_INFO
> void set_dfu_alt_info(char *interface, char *devstr);
> #endif
> +int dfu_alt_init(int num, struct dfu_entity **dfu);
> +int dfu_alt_add(struct dfu_entity *dfu, char *interface, char
> *devstr, char *s); int dfu_config_entities(char *s, char *interface,
> char *devstr); void dfu_free_entities(void);
> void dfu_show_entities(void);
Best regards,
Lukasz Majewski
--
DENX Software Engineering GmbH, Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-59 Fax: (+49)-8142-66989-80 Email: lukma at denx.de
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 488 bytes
Desc: OpenPGP digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20190722/ac6e6bfd/attachment.sig>
next prev parent reply other threads:[~2019-07-22 7:57 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-07-19 12:57 [U-Boot] [RFC PATCH 00/14] dfu: update dfu stack and use them for stm32mp1 Patrick Delaunay
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 01/14] dfu: cosmetic: cleanup sf to avoid checkpatch error Patrick Delaunay
2019-07-22 7:51 ` Lukasz Majewski
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 02/14] dfu: sf: add partition support for nor backend Patrick Delaunay
2019-07-22 7:54 ` Lukasz Majewski
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 03/14] dfu: prepare the support of multiple interface Patrick Delaunay
2019-07-22 7:57 ` Lukasz Majewski [this message]
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 04/14] dfu: allow to manage DFU on several devices Patrick Delaunay
2019-07-22 8:04 ` Lukasz Majewski
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 05/14] dfu: allow read with 0 data for EOF indication Patrick Delaunay
2019-07-22 8:05 ` Lukasz Majewski
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 06/14] dfu: add backend for MTD device Patrick Delaunay
2019-07-22 8:11 ` Lukasz Majewski
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 07/14] dfu: add partition support for MTD backend Patrick Delaunay
2019-07-22 8:16 ` Lukasz Majewski
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 08/14] dfu: add DFU virtual backend Patrick Delaunay
2019-07-22 8:20 ` Lukasz Majewski
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 09/14] dfu: add callback for flush and initiated operation Patrick Delaunay
2019-07-22 8:22 ` Lukasz Majewski
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 10/14] stm32mp1: activate DFU support and command MTD Patrick Delaunay
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 11/14] stm32mp1: activate SET_DFU_ALT_INFO Patrick Delaunay
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 12/14] stp32mp1: configs: activate CONFIG_MTD_SPI_NAND Patrick Delaunay
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 13/14] stm32mp1: board: add spi nand support Patrick Delaunay
2019-07-19 12:57 ` [U-Boot] [RFC PATCH 14/14] stm32mp1: add support for virtual partition read Patrick Delaunay
2019-07-22 8:27 ` [U-Boot] [RFC PATCH 00/14] dfu: update dfu stack and use them for stm32mp1 Lukasz Majewski
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=20190722095718.18fae749@jawa \
--to=lukma@denx.de \
--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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.