ath11k: mhi: add error handling for suspend and resume
authorKalle Valo <quic_kvalo@quicinc.com>
Tue, 5 Apr 2022 08:26:39 +0000 (11:26 +0300)
committerKalle Valo <quic_kvalo@quicinc.com>
Wed, 6 Apr 2022 08:31:55 +0000 (11:31 +0300)
While reviewing the mhi.c I noticed we were just ignoring the errors coming
from MHI subsystem during suspend and resume. Add proper checks and warning
messages. Also pass the error value to callers.

Tested-on: WCN6855 hw2.0 PCI WLAN.HSP.1.1-03003-QCAHSPSWPL_V1_V2_SILICONZ_LITE-2

Signed-off-by: Kalle Valo <quic_kvalo@quicinc.com>
Link: https://lore.kernel.org/r/20220401173042.17467-3-kvalo@kernel.org
drivers/net/wireless/ath/ath11k/mhi.c
drivers/net/wireless/ath/ath11k/mhi.h
drivers/net/wireless/ath/ath11k/pci.c

index 6ad91c600d0e053992ad3f9f55f48cf0e37ca2f2..defdf641df0b177029245cb0201ddd3872f9c045 100644 (file)
@@ -489,16 +489,34 @@ void ath11k_mhi_stop(struct ath11k_pci *ab_pci)
        mhi_unprepare_after_power_down(ab_pci->mhi_ctrl);
 }
 
-void ath11k_mhi_suspend(struct ath11k_pci *ab_pci)
+int ath11k_mhi_suspend(struct ath11k_pci *ab_pci)
 {
-       mhi_pm_suspend(ab_pci->mhi_ctrl);
+       struct ath11k_base *ab = ab_pci->ab;
+       int ret;
+
+       ret = mhi_pm_suspend(ab_pci->mhi_ctrl);
+       if (ret) {
+               ath11k_warn(ab, "failed to suspend mhi: %d", ret);
+               return ret;
+       }
+
+       return 0;
 }
 
-void ath11k_mhi_resume(struct ath11k_pci *ab_pci)
+int ath11k_mhi_resume(struct ath11k_pci *ab_pci)
 {
+       struct ath11k_base *ab = ab_pci->ab;
+       int ret;
+
        /* Do force MHI resume as some devices like QCA6390, WCN6855
         * are not in M3 state but they are functional. So just ignore
         * the MHI state while resuming.
         */
-       mhi_pm_resume_force(ab_pci->mhi_ctrl);
+       ret = mhi_pm_resume_force(ab_pci->mhi_ctrl);
+       if (ret) {
+               ath11k_warn(ab, "failed to resume mhi: %d", ret);
+               return ret;
+       }
+
+       return 0;
 }
index 5dd024f879c416895eced10550a8fca8b2182d0e..8d9f852da69527e08c39f85951e70c81def2434e 100644 (file)
@@ -23,7 +23,7 @@ void ath11k_mhi_unregister(struct ath11k_pci *ar_pci);
 void ath11k_mhi_set_mhictrl_reset(struct ath11k_base *ab);
 void ath11k_mhi_clear_vector(struct ath11k_base *ab);
 
-void ath11k_mhi_suspend(struct ath11k_pci *ar_pci);
-void ath11k_mhi_resume(struct ath11k_pci *ar_pci);
+int ath11k_mhi_suspend(struct ath11k_pci *ar_pci);
+int ath11k_mhi_resume(struct ath11k_pci *ar_pci);
 
 #endif
index 3fd5b416a5644302bdd547df6bb66075007d3f82..024661a170085a90d2ee25ddc78f55665651bfd6 100644 (file)
@@ -619,18 +619,14 @@ static int ath11k_pci_hif_suspend(struct ath11k_base *ab)
 {
        struct ath11k_pci *ar_pci = ath11k_pci_priv(ab);
 
-       ath11k_mhi_suspend(ar_pci);
-
-       return 0;
+       return ath11k_mhi_suspend(ar_pci);
 }
 
 static int ath11k_pci_hif_resume(struct ath11k_base *ab)
 {
        struct ath11k_pci *ar_pci = ath11k_pci_priv(ab);
 
-       ath11k_mhi_resume(ar_pci);
-
-       return 0;
+       return ath11k_mhi_resume(ar_pci);
 }
 
 static void ath11k_pci_hif_ce_irq_enable(struct ath11k_base *ab)