mail archive of the barebox mailing list
 help / color / mirror / Atom feed
From: Ahmad Fatoum <a.fatoum@pengutronix.de>
To: barebox@lists.infradead.org
Cc: Ahmad Fatoum <a.fatoum@pengutronix.de>
Subject: [PATCH v2] mtd: don't try to detect UBI in too small flash partitions
Date: Thu, 29 Feb 2024 17:23:23 +0100	[thread overview]
Message-ID: <20240229162322.1480141-1-a.fatoum@pengutronix.de> (raw)

The detect callback will try to detect an UBI volume inside a partition.

This can misbehave for partitions without UBI:

  - For partitions smaller than 512 bytes, detect fails with -EINVAL,
    because it wasn't possible to read as much

  - For partitions smaller than 64 PEBs, detect will erroneously do
    64 lookups and attempt reading beyond the partition

  - For partition bigger than 64 PEBs, but without UBI, detect will
    read 512 bytes off each PEB without ever finding the UBI.

Fix this by not attempting to read more PEBs than they are and ensure
that there at least 5 PEBs, because anything lower wouldn't account for
UBI overhead[1].

[1]: http://www.linux-mtd.infradead.org/doc/ubi.html#L_overhead

Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
---
v1 -> v2:
  - change minimum PEB count to 5 instead of 1 (Sascha)
  - change erroneous max() to min() (Sascha)
  - reword commit message to avoid confusion around 512 byte read
    (Sascha)

---
 drivers/mtd/core.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/drivers/mtd/core.c b/drivers/mtd/core.c
index 97a7996cf68e..ec2c3ff7bb41 100644
--- a/drivers/mtd/core.c
+++ b/drivers/mtd/core.c
@@ -599,7 +599,10 @@ static int mtd_detect(struct device *dev)
 	enum filetype filetype;
 	int npebs = mtd_div_by_eb(mtd->size, mtd);
 
-	npebs = max(npebs, 64);
+	/* No point in looking for UBI on a partition that's too small */
+	npebs = min(npebs, 64);
+	if (npebs < 5)
+		return 0;
 
 	/*
 	 * Do not try to attach an UBI device if this device has partitions
-- 
2.39.2




             reply	other threads:[~2024-02-29 16:24 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-02-29 16:23 Ahmad Fatoum [this message]
2024-03-04  9:19 ` Sascha Hauer

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=20240229162322.1480141-1-a.fatoum@pengutronix.de \
    --to=a.fatoum@pengutronix.de \
    --cc=barebox@lists.infradead.org \
    /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