[PATCH] mmc: cqhci: Be more verbose in error irq handler

From: Kornel Dulęba
Date: Mon Oct 16 2023 - 05:56:20 EST


There are several reasons for controller to generate an error interrupt.
They include controller<->card timeout, and CRC mismatch error.
Right now we only get one line in the logs stating that CQE recovery was
triggered, but with no information about what caused it.
To figure out what happened be more verbose and dump the registers from
irq error handler logic.
This matches the behaviour of the software timeout logic, see
cqhci_timeout.

Signed-off-by: Kornel Dulęba <korneld@xxxxxxxxxxxx>
---
drivers/mmc/host/cqhci-core.c | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/drivers/mmc/host/cqhci-core.c b/drivers/mmc/host/cqhci-core.c
index b3d7d6d8d654..33abb4bd53b5 100644
--- a/drivers/mmc/host/cqhci-core.c
+++ b/drivers/mmc/host/cqhci-core.c
@@ -700,8 +700,9 @@ static void cqhci_error_irq(struct mmc_host *mmc, u32 status, int cmd_error,

terri = cqhci_readl(cq_host, CQHCI_TERRI);

- pr_debug("%s: cqhci: error IRQ status: 0x%08x cmd error %d data error %d TERRI: 0x%08x\n",
- mmc_hostname(mmc), status, cmd_error, data_error, terri);
+ pr_warn("%s: cqhci: error IRQ status: 0x%08x cmd error %d data error %d\n",
+ mmc_hostname(mmc), status, cmd_error, data_error);
+ cqhci_dumpregs(cq_host);

/* Forget about errors when recovery has already been triggered */
if (cq_host->recovery_halt)
--
2.42.0.655.g421f12c284-goog