[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20231016095610.1095084-1-korneld@chromium.org>
Date: Mon, 16 Oct 2023 09:56:10 +0000
From: Kornel Dulęba <korneld@...omium.org>
To: linux-mmc@...r.kernel.org, linux-kernel@...r.kernel.org
Cc: Adrian Hunter <adrian.hunter@...el.com>,
Ritesh Harjani <riteshh@...eaurora.org>,
Asutosh Das <quic_asutoshd@...cinc.com>,
Ulf Hansson <ulf.hansson@...aro.org>,
Radoslaw Biernacki <biernacki@...gle.com>,
Guenter Roeck <groeck@...omium.org>,
Gwendal Grignou <gwendal@...omium.org>, upstream@...ihalf.com,
Kornel Dulęba <korneld@...omium.org>
Subject: [PATCH] mmc: cqhci: Be more verbose in error irq handler
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@...omium.org>
---
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
Powered by blists - more mailing lists