From: Boris Brezillon <boris.brezillon@bootlin.com>
To: "Rafał Miłecki" <zajec5@gmail.com>
Cc: "Brian Norris" <computersforpeace@gmail.com>,
"David Woodhouse" <dwmw2@infradead.org>,
"Boris Brezillon" <boris.brezillon@free-electrons.com>,
"Marek Vasut" <marek.vasut@gmail.com>,
"Richard Weinberger" <richard@nod.at>,
"Cyrille Pitchen" <cyrille.pitchen@wedev4u.fr>,
"Rafał Miłecki" <rafal@milecki.pl>,
linux-mtd@lists.infradead.org,
"Jonas Gorski" <jonas.gorski@gmail.com>
Subject: Re: [PATCH] mtd: move code adding (registering) partitions to the parse_mtd_partitions()
Date: Wed, 9 May 2018 17:53:36 +0200 [thread overview]
Message-ID: <20180509175336.46e4d1bd@bbrezillon> (raw)
In-Reply-To: <20180327203541.1118-1-zajec5@gmail.com>
On Tue, 27 Mar 2018 22:35:41 +0200
Rafał Miłecki <zajec5@gmail.com> wrote:
> From: Rafał Miłecki <rafal@milecki.pl>
>
> This commit slightly simplifies the code. Every parse_mtd_partitions()
> caller (out of two existing ones) had to add partitions & cleanup parser
> on its own. This moves that responsibility into the function.
>
> That change also allows dropping struct mtd_partitions argument.
>
> There is one minor behavior change caused by this cleanup. If
> parse_mtd_partitions() fails to add partitions (add_mtd_partitions()
> return an error) then mtd_device_parse_register() will still try to
> add (register) fallback partitions. It's a real corner case affecting
> one of uncommon error paths and shouldn't cause any harm.
>
> Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
Applied.
Thanks,
Boris
> ---
> drivers/mtd/mtdcore.c | 14 ++++----------
> drivers/mtd/mtdcore.h | 1 -
> drivers/mtd/mtdpart.c | 44 ++++++++++++++++----------------------------
> 3 files changed, 20 insertions(+), 39 deletions(-)
>
> diff --git a/drivers/mtd/mtdcore.c b/drivers/mtd/mtdcore.c
> index 20d5262c5b5c..7ad9f3a16866 100644
> --- a/drivers/mtd/mtdcore.c
> +++ b/drivers/mtd/mtdcore.c
> @@ -690,7 +690,6 @@ int mtd_device_parse_register(struct mtd_info *mtd, const char * const *types,
> const struct mtd_partition *parts,
> int nr_parts)
> {
> - struct mtd_partitions parsed = { };
> int ret;
>
> mtd_set_dev_defaults(mtd);
> @@ -702,13 +701,10 @@ int mtd_device_parse_register(struct mtd_info *mtd, const char * const *types,
> }
>
> /* Prefer parsed partitions over driver-provided fallback */
> - ret = parse_mtd_partitions(mtd, types, &parsed, parser_data);
> - if (!ret && parsed.nr_parts) {
> - parts = parsed.parts;
> - nr_parts = parsed.nr_parts;
> - }
> -
> - if (nr_parts)
> + ret = parse_mtd_partitions(mtd, types, parser_data);
> + if (ret > 0)
> + ret = 0;
> + else if (nr_parts)
> ret = add_mtd_partitions(mtd, parts, nr_parts);
> else if (!device_is_registered(&mtd->dev))
> ret = add_mtd_device(mtd);
> @@ -734,8 +730,6 @@ int mtd_device_parse_register(struct mtd_info *mtd, const char * const *types,
> }
>
> out:
> - /* Cleanup any parsed partitions */
> - mtd_part_parser_cleanup(&parsed);
> if (ret && device_is_registered(&mtd->dev))
> del_mtd_device(mtd);
>
> diff --git a/drivers/mtd/mtdcore.h b/drivers/mtd/mtdcore.h
> index 37accfd0400e..9887bda317cd 100644
> --- a/drivers/mtd/mtdcore.h
> +++ b/drivers/mtd/mtdcore.h
> @@ -15,7 +15,6 @@ int del_mtd_partitions(struct mtd_info *);
> struct mtd_partitions;
>
> int parse_mtd_partitions(struct mtd_info *master, const char * const *types,
> - struct mtd_partitions *pparts,
> struct mtd_part_parser_data *data);
>
> void mtd_part_parser_cleanup(struct mtd_partitions *parts);
> diff --git a/drivers/mtd/mtdpart.c b/drivers/mtd/mtdpart.c
> index 023516a63276..f8d3a015cdad 100644
> --- a/drivers/mtd/mtdpart.c
> +++ b/drivers/mtd/mtdpart.c
> @@ -335,20 +335,7 @@ static inline void free_partition(struct mtd_part *p)
> */
> static int mtd_parse_part(struct mtd_part *slave, const char *const *types)
> {
> - struct mtd_partitions parsed;
> - int err;
> -
> - err = parse_mtd_partitions(&slave->mtd, types, &parsed, NULL);
> - if (err)
> - return err;
> - else if (!parsed.nr_parts)
> - return -ENOENT;
> -
> - err = add_mtd_partitions(&slave->mtd, parsed.parts, parsed.nr_parts);
> -
> - mtd_part_parser_cleanup(&parsed);
> -
> - return err;
> + return parse_mtd_partitions(&slave->mtd, types, NULL);
> }
>
> static struct mtd_part *allocate_partition(struct mtd_info *parent,
> @@ -933,30 +920,27 @@ static int mtd_part_of_parse(struct mtd_info *master,
> }
>
> /**
> - * parse_mtd_partitions - parse MTD partitions
> + * parse_mtd_partitions - parse and register MTD partitions
> + *
> * @master: the master partition (describes whole MTD device)
> * @types: names of partition parsers to try or %NULL
> - * @pparts: info about partitions found is returned here
> * @data: MTD partition parser-specific data
> *
> - * This function tries to find partition on MTD device @master. It uses MTD
> - * partition parsers, specified in @types. However, if @types is %NULL, then
> - * the default list of parsers is used. The default list contains only the
> + * This function tries to find & register partitions on MTD device @master. It
> + * uses MTD partition parsers, specified in @types. However, if @types is %NULL,
> + * then the default list of parsers is used. The default list contains only the
> * "cmdlinepart" and "ofpart" parsers ATM.
> * Note: If there are more then one parser in @types, the kernel only takes the
> * partitions parsed out by the first parser.
> *
> * This function may return:
> * o a negative error code in case of failure
> - * o zero otherwise, and @pparts will describe the partitions, number of
> - * partitions, and the parser which parsed them. Caller must release
> - * resources with mtd_part_parser_cleanup() when finished with the returned
> - * data.
> + * o number of found partitions otherwise
> */
> int parse_mtd_partitions(struct mtd_info *master, const char *const *types,
> - struct mtd_partitions *pparts,
> struct mtd_part_parser_data *data)
> {
> + struct mtd_partitions pparts = { };
> struct mtd_part_parser *parser;
> int ret, err = 0;
>
> @@ -970,7 +954,7 @@ int parse_mtd_partitions(struct mtd_info *master, const char *const *types,
> * handled in a separated function.
> */
> if (!strcmp(*types, "ofpart")) {
> - ret = mtd_part_of_parse(master, pparts);
> + ret = mtd_part_of_parse(master, &pparts);
> } else {
> pr_debug("%s: parsing partitions %s\n", master->name,
> *types);
> @@ -981,13 +965,17 @@ int parse_mtd_partitions(struct mtd_info *master, const char *const *types,
> parser ? parser->name : NULL);
> if (!parser)
> continue;
> - ret = mtd_part_do_parse(parser, master, pparts, data);
> + ret = mtd_part_do_parse(parser, master, &pparts, data);
> if (ret <= 0)
> mtd_part_parser_put(parser);
> }
> /* Found partitions! */
> - if (ret > 0)
> - return 0;
> + if (ret > 0) {
> + err = add_mtd_partitions(master, pparts.parts,
> + pparts.nr_parts);
> + mtd_part_parser_cleanup(&pparts);
> + return err ? err : pparts.nr_parts;
> + }
> /*
> * Stash the first error we see; only report it if no parser
> * succeeds
prev parent reply other threads:[~2018-05-09 15:54 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-03-27 20:35 [PATCH] mtd: move code adding (registering) partitions to the parse_mtd_partitions() Rafał Miłecki
2018-05-07 8:06 ` Boris Brezillon
2018-05-09 15:53 ` Boris Brezillon [this message]
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=20180509175336.46e4d1bd@bbrezillon \
--to=boris.brezillon@bootlin.com \
--cc=boris.brezillon@free-electrons.com \
--cc=computersforpeace@gmail.com \
--cc=cyrille.pitchen@wedev4u.fr \
--cc=dwmw2@infradead.org \
--cc=jonas.gorski@gmail.com \
--cc=linux-mtd@lists.infradead.org \
--cc=marek.vasut@gmail.com \
--cc=rafal@milecki.pl \
--cc=richard@nod.at \
--cc=zajec5@gmail.com \
/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;
as well as URLs for NNTP newsgroup(s).