spi: spi-qpic-snand: document the limited bit error reporting capability
authorGabor Juhos <j4g8y7@gmail.com>
Tue, 27 May 2025 11:08:16 +0000 (13:08 +0200)
committerMark Brown <broonie@kernel.org>
Mon, 2 Jun 2025 11:27:51 +0000 (12:27 +0100)
The QPIC hardware is not capable of reporting the exact number of the
corrected bit errors, it only reports the number of the corrected bytes.

Document this behaviour in the code, and also issue a warning message
to inform the user about it.

No functional changes.

Signed-off-by: Gabor Juhos <j4g8y7@gmail.com>
Link: https://patch.msgid.link/20250527-qpic-snand-limited-biterr-caps-v1-1-61f7cf87be1e@gmail.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-qpic-snand.c

index fd129650434f0129e24d3bdac7e7c4d5542627e6..c2f5ef899f6a60ad98b9d754b7cac1832d0500eb 100644 (file)
@@ -639,6 +639,20 @@ static int qcom_spi_check_error(struct qcom_nand_controller *snandc)
                        unsigned int stat;
 
                        stat = buffer & BS_CORRECTABLE_ERR_MSK;
+
+                       /*
+                        * The exact number of the corrected bits is
+                        * unknown because the hardware only reports the
+                        * number of the corrected bytes.
+                        *
+                        * Since we have no better solution at the moment,
+                        * report that value as the number of bit errors
+                        * despite that it is inaccurate in most cases.
+                        */
+                       if (stat && stat != ecc_cfg->strength)
+                               dev_warn_once(snandc->dev,
+                                             "Warning: due to hw limitation, the reported number of the corrected bits may be inaccurate\n");
+
                        snandc->qspi->ecc_stats.corrected += stat;
                        max_bitflips = max(max_bitflips, stat);
                }