From: Lukasz Majewski <lukma@denx.de>
To: u-boot@lists.denx.de
Subject: [U-Boot] [RFC PATCH 07/14] dfu: add partition support for MTD backend
Date: Mon, 22 Jul 2019 10:16:05 +0200 [thread overview]
Message-ID: <20190722101605.29a43a73@jawa> (raw)
In-Reply-To: <1563541046-6432-8-git-send-email-patrick.delaunay@st.com>
Hi Patrick,
> Add the support of MTD partition for the MTD backend.
>
> The expected dfu_alt_info for one alternate on the mtd device :
> <name> part <part_id>
> <name> partubi <part_id>
>
> "partubi" also erase up to the end of the partition after write
> operation.
>
> For example: dfu_alt_info = "spl part 1;u-boot part 2; UBI partubi 3"
As in the previous comments - please add this info to dedicated doc
entry.
>
> U-Boot> dfu 0 mtd nand0
>
> Signed-off-by: Patrick Delaunay <patrick.delaunay@st.com>
> ---
>
> drivers/dfu/dfu_mtd.c | 78
> ++++++++++++++++++++++++++++++++++++++++++++++++++-
> include/dfu.h | 2 ++ 2 files changed, 79 insertions(+), 1
> deletion(-)
>
> diff --git a/drivers/dfu/dfu_mtd.c b/drivers/dfu/dfu_mtd.c
> index 1168a6e..223b0fe 100644
> --- a/drivers/dfu/dfu_mtd.c
> +++ b/drivers/dfu/dfu_mtd.c
> @@ -10,6 +10,7 @@
> #include <common.h>
> #include <dfu.h>
> #include <mtd.h>
> +#include <jffs2/load_kernel.h>
>
> static bool mtd_is_aligned_with_block_size(struct mtd_info *mtd, u64
> size) {
> @@ -181,11 +182,49 @@ static int dfu_write_medium_mtd(struct
> dfu_entity *dfu,
> static int dfu_flush_medium_mtd(struct dfu_entity *dfu)
> {
> + struct mtd_info *mtd = dfu->data.mtd.info;
> + int ret;
> +
> + /* in case of ubi partition, erase rest of the partition */
> + if (dfu->data.nand.ubi) {
> + struct erase_info erase_op = {};
> +
> + erase_op.mtd = dfu->data.mtd.info;
> + erase_op.addr = round_up(dfu->data.mtd.start +
> dfu->offset +
> + dfu->bad_skip,
> mtd->erasesize);
> + erase_op.len = dfu->data.mtd.start +
> dfu->data.mtd.size -
> + erase_op.addr;
> + erase_op.scrub = 0;
> +
> + while (erase_op.len) {
> + ret = mtd_erase(mtd, &erase_op);
> + /* Abort if its not a bad block error */
> + if (ret != -EIO)
> + break;
> +
> + printf("Skipping bad block at 0x%08llx\n",
> + erase_op.fail_addr);
> +
> + /* Skip bad block and continue behind it */
> + erase_op.addr = erase_op.fail_addr +
> mtd->erasesize;
> + erase_op.len = dfu->data.mtd.start +
> + dfu->data.mtd.size -
> + erase_op.addr;
> + }
> + }
> return 0;
> }
>
> static unsigned int dfu_polltimeout_mtd(struct dfu_entity *dfu)
> {
> + /*
> + * Currently, Poll Timeout != 0 is only needed on nand
> + * ubi partition, as sectors which are not used need
> + * to be erased
> + */
> + if (dfu->data.nand.ubi)
> + return DFU_MANIFEST_POLL_TIMEOUT;
> +
> return DFU_DEFAULT_POLL_TIMEOUT;
> }
>
> @@ -194,6 +233,7 @@ int dfu_fill_entity_mtd(struct dfu_entity *dfu,
> char *devstr, char *s) char *st;
> struct mtd_info *mtd;
> bool has_pages;
> + int ret, part;
>
> mtd = get_mtd_device_nm(devstr);
> if (IS_ERR_OR_NULL(mtd))
> @@ -212,11 +252,47 @@ int dfu_fill_entity_mtd(struct dfu_entity *dfu,
> char *devstr, char *s) dfu->data.mtd.start = simple_strtoul(s, &s,
> 16); s++;
> dfu->data.mtd.size = simple_strtoul(s, &s, 16);
> + } else if ((!strcmp(st, "part")) || (!strcmp(st,
> "partubi"))) {
> + char mtd_id[32];
> + struct mtd_device *mtd_dev;
> + u8 part_num;
> + struct part_info *pi;
> +
> + dfu->layout = DFU_RAW_ADDR;
> +
> + part = simple_strtoul(s, &s, 10);
> +
> + sprintf(mtd_id, "%s,%d", devstr, part - 1);
> + printf("using id '%s'\n", mtd_id);
> +
> + mtdparts_init();
> +
> + ret = find_dev_and_part(mtd_id, &mtd_dev, &part_num,
> &pi);
> + if (ret != 0) {
> + printf("Could not locate '%s'\n", mtd_id);
> + return -1;
-ENODEV maybe would be more appropriate ?
> + }
> +
> + dfu->data.mtd.start = pi->offset;
> + dfu->data.mtd.size = pi->size;
> + if (!strcmp(st, "partubi"))
> + dfu->data.mtd.ubi = 1;
> } else {
> - printf("%s: (%s) not supported!\n", __func__, st);
> + printf("%s: Memory layout (%s) not supported!\n",
> __func__, st); return -1;
> }
>
> + if (!mtd_is_aligned_with_block_size(mtd,
> dfu->data.mtd.start)) {
> + printf("Offset not aligned with a block (0x%x)\n",
> + mtd->erasesize);
> + return -EINVAL;
> + }
> + if (!mtd_is_aligned_with_block_size(mtd,
> dfu->data.mtd.size)) {
> + printf("Size not aligned with a block (0x%x)\n",
> + mtd->erasesize);
> + return -EINVAL;
> + }
> +
> dfu->get_medium_size = dfu_get_medium_size_mtd;
> dfu->read_medium = dfu_read_medium_mtd;
> dfu->write_medium = dfu_write_medium_mtd;
> diff --git a/include/dfu.h b/include/dfu.h
> index 924952f..a90732c 100644
> --- a/include/dfu.h
> +++ b/include/dfu.h
> @@ -62,6 +62,8 @@ struct mtd_internal_data {
> /* RAW programming */
> u64 start;
> u64 size;
> + /* for ubi partition */
> + unsigned int ubi;
> };
>
> struct nand_internal_data {
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/c113d98e/attachment.sig>
next prev parent reply other threads:[~2019-07-22 8:16 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
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 [this message]
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=20190722101605.29a43a73@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.