The rsi_resume() does access the bus to enable interrupts on the RSI
SDIO WiFi card, however when calling sdio_claim_host() in the resume
path, it is possible the bus is already claimed and sdio_claim_host()
spins indefinitelly. Enable the SDIO card interrupts in resume_noirq
instead to prevent anything else from claiming the SDIO bus first.

Fixes: 20db07332736 ("rsi: sdio suspend and resume support")
Signed-off-by: Marek Vasut <ma...@denx.de>
Cc: Amitkumar Karwar <amit.kar...@redpinesignals.com>
Cc: Angus Ainslie <an...@akkea.ca>
Cc: David S. Miller <da...@davemloft.net>
Cc: Jakub Kicinski <k...@kernel.org>
Cc: Kalle Valo <kv...@codeaurora.org>
Cc: Karun Eagalapati <karun...@gmail.com>
Cc: Martin Kepplinger <mart...@posteo.de>
Cc: Sebastian Krzyszkowiak <sebastian.krzyszkow...@puri.sm>
Cc: Siva Rebbagondla <siva8...@gmail.com>
Cc: netdev@vger.kernel.org
Cc: sta...@vger.kernel.org
---
 drivers/net/wireless/rsi/rsi_91x_sdio.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/net/wireless/rsi/rsi_91x_sdio.c 
b/drivers/net/wireless/rsi/rsi_91x_sdio.c
index 122174fca672..8465a4ee9b61 100644
--- a/drivers/net/wireless/rsi/rsi_91x_sdio.c
+++ b/drivers/net/wireless/rsi/rsi_91x_sdio.c
@@ -1513,7 +1513,7 @@ static int rsi_restore(struct device *dev)
 }
 static const struct dev_pm_ops rsi_pm_ops = {
        .suspend = rsi_suspend,
-       .resume = rsi_resume,
+       .resume_noirq = rsi_resume,
        .freeze = rsi_freeze,
        .thaw = rsi_thaw,
        .restore = rsi_restore,
-- 
2.30.2

Reply via email to