All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] mtd: aspeed-smc: improve probe resilience
@ 2021-12-29 14:33 ` Patrick Williams
  0 siblings, 0 replies; 42+ messages in thread
From: Patrick Williams @ 2021-12-29 14:33 UTC (permalink / raw)
  To: Tudor Ambarus, Michael Walle, Pratyush Yadav, Miquel Raynal,
	Richard Weinberger, Vignesh Raghavendra, Joel Stanley,
	Andrew Jeffery
  Cc: Potin Lai, Patrick Williams, linux-mtd, linux-arm-kernel,
	linux-aspeed, linux-kernel

The aspeed-smc can have multiple SPI devices attached to it in the
device tree.  If one of the devices is missing or failing the entire
probe will fail and all MTD devices under the controller will be
removed.  On OpenBMC this results in a kernel panic due to missing
rootfs:

[    0.538774] aspeed-smc 1e620000.spi: Using 50 MHz SPI frequency
[    0.540471] aspeed-smc 1e620000.spi: w25q01jv-iq (131072 Kbytes)
[    0.540750] aspeed-smc 1e620000.spi: CE0 window [ 0x20000000 - 0x28000000 ] 128MB
[    0.540943] aspeed-smc 1e620000.spi: CE1 window [ 0x28000000 - 0x2c000000 ] 64MB
[    0.541143] aspeed-smc 1e620000.spi: read control register: 203b0041
[    0.581442] 5 fixed-partitions partitions found on MTD device bmc
[    0.581625] Creating 5 MTD partitions on "bmc":
[    0.581854] 0x000000000000-0x0000000e0000 : "u-boot"
[    0.584472] 0x0000000e0000-0x000000100000 : "u-boot-env"
[    0.586468] 0x000000100000-0x000000a00000 : "kernel"
[    0.588465] 0x000000a00000-0x000006000000 : "rofs"
[    0.590552] 0x000006000000-0x000008000000 : "rwfs"
[    0.592605] aspeed-smc 1e620000.spi: Using 50 MHz SPI frequency
[    0.592801] aspeed-smc 1e620000.spi: unrecognized JEDEC id bytes: 00 00 00 00 00 00
[    0.593039] Deleting MTD partitions on "bmc":
[    0.593175] Deleting u-boot MTD partition
[    0.637929] Deleting u-boot-env MTD partition
[    0.829527] Deleting kernel MTD partition
[    0.856902] Freeing initrd memory: 1032K
[    0.866428] Deleting rofs MTD partition
[    0.906264] Deleting rwfs MTD partition
[    0.986628] aspeed-smc 1e620000.spi: Aspeed SMC probe failed -2
[    0.986929] aspeed-smc: probe of 1e620000.spi failed with error -2
...
[    2.936719] /dev/mtdblock: Can't open blockdev
mount: mounting /dev/mtdblock on run/initramfs/ro failed: No such file or directory
[    2.963030] MTD: Couldn't look up '/dev/mtdblock': -2
mount: mounting /dev/mtdblock on run/initramfs/rw failed: No such file or directory

Mounting read-write /dev/mtdblock filesystem failed.  Please fix and run
	mount /dev/mtdblock run/initramfs/rw -t jffs2 -o rw
or perform a factory reset with the clean-rwfs-filesystem option.
Fatal error, triggering kernel panic!
[    3.013047] Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000100

Many BMC designs have two flash chips so that they can handle a hardware
failure of one of them.  If one chip failed, it doesn't do any good to
have redundancy if they all get removed anyhow.

Improve the resilience of the probe function to handle one of the
children being missing or failed.  Only in the case where all children
fail to probe should the controller be failed out.

Signed-off-by: Patrick Williams <patrick@stwcx.xyz>
---
 drivers/mtd/spi-nor/controllers/aspeed-smc.c | 15 +++++++++++++--
 1 file changed, 13 insertions(+), 2 deletions(-)

diff --git a/drivers/mtd/spi-nor/controllers/aspeed-smc.c b/drivers/mtd/spi-nor/controllers/aspeed-smc.c
index 7225870e8b18..acfe010f9dd7 100644
--- a/drivers/mtd/spi-nor/controllers/aspeed-smc.c
+++ b/drivers/mtd/spi-nor/controllers/aspeed-smc.c
@@ -769,6 +769,7 @@ static int aspeed_smc_setup_flash(struct aspeed_smc_controller *controller,
 	struct device_node *child;
 	unsigned int cs;
 	int ret = -ENODEV;
+	bool found_one = false;
 
 	for_each_available_child_of_node(np, child) {
 		struct aspeed_smc_chip *chip;
@@ -827,8 +828,17 @@ static int aspeed_smc_setup_flash(struct aspeed_smc_controller *controller,
 		 * by of property.
 		 */
 		ret = spi_nor_scan(nor, NULL, &hwcaps);
-		if (ret)
-			break;
+		/*
+		 * If we fail to scan the device it might not be present or
+		 * broken.  Don't fail the whole controller if others work.
+		 */
+		if (ret) {
+			if (found_one)
+				ret = 0;
+
+			devm_kfree(controller->dev, chip);
+			continue;
+		}
 
 		ret = aspeed_smc_chip_setup_finish(chip);
 		if (ret)
@@ -839,6 +849,7 @@ static int aspeed_smc_setup_flash(struct aspeed_smc_controller *controller,
 			break;
 
 		controller->chips[cs] = chip;
+		found_one = true;
 	}
 
 	if (ret) {
-- 
2.32.0


^ permalink raw reply related	[flat|nested] 42+ messages in thread

end of thread, other threads:[~2022-02-08 19:30 UTC | newest]

Thread overview: 42+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-12-29 14:33 [PATCH] mtd: aspeed-smc: improve probe resilience Patrick Williams
2021-12-29 14:33 ` Patrick Williams
2021-12-29 14:33 ` Patrick Williams
2021-12-29 17:34 ` Pratyush Yadav
2021-12-29 17:34   ` Pratyush Yadav
2021-12-29 17:34   ` Pratyush Yadav
2021-12-30 15:29   ` Patrick Williams
2021-12-30 15:29     ` Patrick Williams
2021-12-30 15:29     ` Patrick Williams
2021-12-31 10:26     ` Pratyush Yadav
2021-12-31 10:26       ` Pratyush Yadav
2021-12-31 10:26       ` Pratyush Yadav
2022-01-03 16:17       ` Miquel Raynal
2022-01-03 16:17         ` Miquel Raynal
2022-01-03 16:17         ` Miquel Raynal
2022-01-04 18:20         ` Patrick Williams
2022-01-04 18:20           ` Patrick Williams
2022-01-04 18:20           ` Patrick Williams
2022-01-05  6:32           ` Pratyush Yadav
2022-01-05  6:32             ` Pratyush Yadav
2022-01-05  6:32             ` Pratyush Yadav
2022-01-23 22:44             ` Cédric Le Goater
2022-01-23 22:44               ` Cédric Le Goater
2022-01-23 22:44               ` Cédric Le Goater
2022-01-24 15:36               ` Pratyush Yadav
2022-01-24 15:36                 ` Pratyush Yadav
2022-01-24 15:36                 ` Pratyush Yadav
2022-01-24 18:34                 ` Cédric Le Goater
2022-01-24 18:34                   ` Cédric Le Goater
2022-01-24 18:34                   ` Cédric Le Goater
2022-01-24 20:37                   ` Pratyush Yadav
2022-01-24 20:37                     ` Pratyush Yadav
2022-01-24 20:37                     ` Pratyush Yadav
2022-02-07 17:13                     ` Cédric Le Goater
2022-02-07 17:13                       ` Cédric Le Goater
2022-02-07 17:13                       ` Cédric Le Goater
2022-02-08 19:06                       ` Pratyush Yadav
2022-02-08 19:06                         ` Pratyush Yadav
2022-02-08 19:06                         ` Pratyush Yadav
2022-01-23 15:39 ` Miquel Raynal
2022-01-23 15:39   ` Miquel Raynal
2022-01-23 15:39   ` Miquel Raynal

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.