From: Ilias Apalodimas <ilias.apalodimas@linaro.org>
To: Sughosh Ganu <sughosh.ganu@linaro.org>
Cc: u-boot@lists.denx.de, Heinrich Schuchardt <xypron.glpk@gmx.de>,
Takahiro Akashi <takahiro.akashi@linaro.org>,
Patrick Delaunay <patrick.delaunay@foss.st.com>,
Patrice Chotard <patrice.chotard@foss.st.com>,
Simon Glass <sjg@chromium.org>, Tom Rini <trini@konsulko.com>,
Etienne Carriere <etienne.carriere@linaro.org>,
Jassi Brar <jaswinder.singh@linaro.org>
Subject: Re: [PATCH v15 03/15] FWU: Add FWU metadata access driver for GPT partitioned block devices
Date: Fri, 21 Oct 2022 19:38:32 +0300 [thread overview]
Message-ID: <Y1LLCN3RjEoG6Gxd@hera> (raw)
In-Reply-To: <CADg8p97d2-AUrw9BH+YpeFBKCDibH=A+RYKitDt4jAM7jNshHA@mail.gmail.com>
On Fri, Oct 21, 2022 at 09:57:45PM +0530, Sughosh Ganu wrote:
> hi Ilias,
>
> On Fri, 21 Oct 2022 at 20:33, Ilias Apalodimas
> <ilias.apalodimas@linaro.org> wrote:
> >
> > Hi Sughosh
> >
> > > +{
> > > + int ret;
> > > + u32 len, blk_start, blkcnt;
> > > + struct disk_partition info;
> > > +
> > > + ALLOC_CACHE_ALIGN_BUFFER_PAD(struct fwu_mdata, mdata_aligned, 1,
> > > + desc->blksz);
> > > +
> > > + if (!mdata)
> > > + return -ENOMEM;
> >
> > ENOMEM is usually for allocation failures this is an -EINVAL
> >
> > > +
> > > + ret = gpt_get_mdata_disk_part(desc, &info, part_num);
> > > + if (ret < 0) {
> > > + printf("Unable to get the FWU metadata partition\n");
> > > + return -ENOENT;
> > > + }
> > > +
> > > + len = sizeof(*mdata);
> > > + blkcnt = BLOCK_CNT(len, desc);
> > > + if (blkcnt > info.size) {
> > > + log_debug("Block count exceeds FWU metadata partition size\n");
> > > + return -ERANGE;
> > > + }
> > > +
> > > + blk_start = info.start;
> > > + if (access == MDATA_READ) {
> > > + if (blk_dread(desc, blk_start, blkcnt, mdata_aligned) != blkcnt) {
> > > + log_debug("Error reading FWU metadata from the device\n");
> > > + return -EIO;
> > > + }
> > > + memcpy(mdata, mdata_aligned, sizeof(struct fwu_mdata));
> > > + } else {
> >
> > else if ?
> >
> > > + if (blk_dwrite(desc, blk_start, blkcnt, mdata) != blkcnt) {
> > > + log_debug("Error writing FWU metadata to the device\n");
> > > + return -EIO;
> > > + }
> > > + }
> > > +
> > > + return 0;
> > > +}
> > > +
> > > +static int fwu_gpt_update_mdata(struct udevice *dev, struct fwu_mdata *mdata)
> > > +{
> > > + int ret;
> > > + struct blk_desc *desc;
> > > + uint mdata_parts[2];
> > > + struct fwu_mdata_gpt_blk_priv *priv = dev_get_priv(dev);
> > > +
> > > + desc = dev_get_uclass_plat(priv->blk_dev);
> >
> > dev_get_uclass_plat might return NULL, gpt_read_write_mdata() doesn't check
> > against NULL and then it ends up calling gpt_get_mdata_disk_part() which
> > then calls part_get_info(). I don't think anyone checks for the desc ptr
> >
> > And I think this is a problem overall in all the callbacks belowe that
> > invoke dev_get_uclass_plat()
>
> dev_get_uclass_plat() returns NULL only when the dev parameter passed
> to the function is NULL. And that won't happen since that would mean
> that the mdata_dev is NULL, and in such a scenario the driver's probe
> function would fail. So these functions would not get called with desc
> being NULL.
>
> -sughosh
Ok makes sense.
Acked-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
Thanks
/Ilias
>
> >
[...]
next prev parent reply other threads:[~2022-10-21 16:38 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-10-21 12:45 [PATCH v15 00/15] FWU: Add FWU Multi Bank Update feature support Sughosh Ganu
2022-10-21 12:45 ` [PATCH v15 01/15] dt/bindings: Add bindings for GPT based FWU Metadata storage device Sughosh Ganu
2022-11-01 14:34 ` Tom Rini
2022-10-21 12:45 ` [PATCH v15 02/15] FWU: Add FWU metadata structure and driver for accessing metadata Sughosh Ganu
2022-10-21 12:45 ` [PATCH v15 03/15] FWU: Add FWU metadata access driver for GPT partitioned block devices Sughosh Ganu
2022-10-21 15:03 ` Ilias Apalodimas
2022-10-21 16:27 ` Sughosh Ganu
2022-10-21 16:38 ` Ilias Apalodimas [this message]
2022-10-21 12:45 ` [PATCH v15 04/15] stm32mp1: Add a node for the FWU metadata device Sughosh Ganu
2022-10-21 12:45 ` [PATCH v15 05/15] stm32mp1: Add image information for capsule updates Sughosh Ganu
2022-10-21 12:45 ` [PATCH v15 06/15] FWU: Add helper functions for accessing FWU metadata Sughosh Ganu
2022-10-21 12:46 ` [PATCH v15 07/15] FWU: STM32MP1: Add support to read boot index from backup register Sughosh Ganu
2022-10-21 12:46 ` [PATCH v15 08/15] event: Add an event for main_loop Sughosh Ganu
2022-10-21 12:46 ` [PATCH v15 09/15] FWU: Add boot time checks as highlighted by the FWU specification Sughosh Ganu
2022-10-21 15:08 ` Ilias Apalodimas
2022-10-21 16:30 ` Sughosh Ganu
2022-10-21 12:46 ` [PATCH v15 10/15] FWU: Add support for the FWU Multi Bank Update feature Sughosh Ganu
2022-10-31 17:59 ` Ilias Apalodimas
2022-11-01 13:31 ` Tom Rini
2022-11-01 19:36 ` Simon Glass
2022-10-21 12:46 ` [PATCH v15 11/15] FWU: cmd: Add a command to read FWU metadata Sughosh Ganu
2022-10-21 12:46 ` [PATCH v15 12/15] test: dm: Add test cases for FWU Metadata uclass Sughosh Ganu
2022-10-21 12:46 ` [PATCH v15 13/15] mkeficapsule: Add support for generating empty capsules Sughosh Ganu
2022-10-21 12:46 ` [PATCH v15 14/15] mkeficapsule: Add support for setting OEM flags in capsule header Sughosh Ganu
2022-10-25 13:56 ` Etienne Carriere
2022-10-21 12:46 ` [PATCH v15 15/15] FWU: doc: Add documentation for the FWU feature Sughosh Ganu
2022-10-21 13:33 ` Ilias Apalodimas
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=Y1LLCN3RjEoG6Gxd@hera \
--to=ilias.apalodimas@linaro.org \
--cc=etienne.carriere@linaro.org \
--cc=jaswinder.singh@linaro.org \
--cc=patrice.chotard@foss.st.com \
--cc=patrick.delaunay@foss.st.com \
--cc=sjg@chromium.org \
--cc=sughosh.ganu@linaro.org \
--cc=takahiro.akashi@linaro.org \
--cc=trini@konsulko.com \
--cc=u-boot@lists.denx.de \
--cc=xypron.glpk@gmx.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.