]> www.infradead.org Git - nvme.git/commitdiff
Revert "wifi: ath11k: support hibernation"
authorBaochen Qiang <quic_bqiang@quicinc.com>
Fri, 30 Aug 2024 07:34:20 +0000 (15:34 +0800)
committerKalle Valo <quic_kvalo@quicinc.com>
Mon, 2 Sep 2024 16:33:00 +0000 (19:33 +0300)
This reverts commit 166a490f59ac10340ee5330e51c15188ce2a7f8f.

There are several reports that this commit breaks system suspend on some specific
Lenovo platforms. Since there is no fix available, for now revert this commit
to make suspend work again on those platforms.

Closes: https://bugzilla.kernel.org/show_bug.cgi?id=219196
Closes: https://bugzilla.redhat.com/show_bug.cgi?id=2301921
Cc: <stable@vger.kernel.org> # 6.10.x: d3e154d7776b: Revert "wifi: ath11k: restore country code during resume"
Cc: <stable@vger.kernel.org> # 6.10.x
Signed-off-by: Baochen Qiang <quic_bqiang@quicinc.com>
Acked-by: Jeff Johnson <quic_jjohnson@quicinc.com>
Signed-off-by: Kalle Valo <quic_kvalo@quicinc.com>
Link: https://patch.msgid.link/20240830073420.5790-3-quic_bqiang@quicinc.com
drivers/net/wireless/ath/ath11k/ahb.c
drivers/net/wireless/ath/ath11k/core.c
drivers/net/wireless/ath/ath11k/core.h
drivers/net/wireless/ath/ath11k/hif.h
drivers/net/wireless/ath/ath11k/mhi.c
drivers/net/wireless/ath/ath11k/mhi.h
drivers/net/wireless/ath/ath11k/pci.c
drivers/net/wireless/ath/ath11k/qmi.c

index 634d385fd9ad71c8531d9994b44a8261c0aaa40a..97b12f51ef28c04603dfbb1449c5ccd77c0ac2e8 100644 (file)
@@ -413,7 +413,7 @@ static int ath11k_ahb_power_up(struct ath11k_base *ab)
        return ret;
 }
 
-static void ath11k_ahb_power_down(struct ath11k_base *ab, bool is_suspend)
+static void ath11k_ahb_power_down(struct ath11k_base *ab)
 {
        struct ath11k_ahb *ab_ahb = ath11k_ahb_priv(ab);
 
@@ -1280,7 +1280,7 @@ static void ath11k_ahb_remove(struct platform_device *pdev)
        struct ath11k_base *ab = platform_get_drvdata(pdev);
 
        if (test_bit(ATH11K_FLAG_QMI_FAIL, &ab->dev_flags)) {
-               ath11k_ahb_power_down(ab, false);
+               ath11k_ahb_power_down(ab);
                ath11k_debugfs_soc_destroy(ab);
                ath11k_qmi_deinit_service(ab);
                goto qmi_fail;
index 325b930aaf0652ff781074e532941075057f587f..ccf4ad35fdc33523edd1343e2e44017790961931 100644 (file)
@@ -906,6 +906,12 @@ int ath11k_core_suspend(struct ath11k_base *ab)
                return ret;
        }
 
+       ret = ath11k_wow_enable(ab);
+       if (ret) {
+               ath11k_warn(ab, "failed to enable wow during suspend: %d\n", ret);
+               return ret;
+       }
+
        ret = ath11k_dp_rx_pktlog_stop(ab, false);
        if (ret) {
                ath11k_warn(ab, "failed to stop dp rx pktlog during suspend: %d\n",
@@ -916,85 +922,29 @@ int ath11k_core_suspend(struct ath11k_base *ab)
        ath11k_ce_stop_shadow_timers(ab);
        ath11k_dp_stop_shadow_timers(ab);
 
-       /* PM framework skips suspend_late/resume_early callbacks
-        * if other devices report errors in their suspend callbacks.
-        * However ath11k_core_resume() would still be called because
-        * here we return success thus kernel put us on dpm_suspended_list.
-        * Since we won't go through a power down/up cycle, there is
-        * no chance to call complete(&ab->restart_completed) in
-        * ath11k_core_restart(), making ath11k_core_resume() timeout.
-        * So call it here to avoid this issue. This also works in case
-        * no error happens thus suspend_late/resume_early get called,
-        * because it will be reinitialized in ath11k_core_resume_early().
-        */
-       complete(&ab->restart_completed);
-
-       return 0;
-}
-EXPORT_SYMBOL(ath11k_core_suspend);
-
-int ath11k_core_suspend_late(struct ath11k_base *ab)
-{
-       struct ath11k_pdev *pdev;
-       struct ath11k *ar;
-
-       if (!ab->hw_params.supports_suspend)
-               return -EOPNOTSUPP;
-
-       /* so far single_pdev_only chips have supports_suspend as true
-        * and only the first pdev is valid.
-        */
-       pdev = ath11k_core_get_single_pdev(ab);
-       ar = pdev->ar;
-       if (!ar || ar->state != ATH11K_STATE_OFF)
-               return 0;
-
        ath11k_hif_irq_disable(ab);
        ath11k_hif_ce_irq_disable(ab);
 
-       ath11k_hif_power_down(ab, true);
+       ret = ath11k_hif_suspend(ab);
+       if (ret) {
+               ath11k_warn(ab, "failed to suspend hif: %d\n", ret);
+               return ret;
+       }
 
        return 0;
 }
-EXPORT_SYMBOL(ath11k_core_suspend_late);
-
-int ath11k_core_resume_early(struct ath11k_base *ab)
-{
-       int ret;
-       struct ath11k_pdev *pdev;
-       struct ath11k *ar;
-
-       if (!ab->hw_params.supports_suspend)
-               return -EOPNOTSUPP;
-
-       /* so far single_pdev_only chips have supports_suspend as true
-        * and only the first pdev is valid.
-        */
-       pdev = ath11k_core_get_single_pdev(ab);
-       ar = pdev->ar;
-       if (!ar || ar->state != ATH11K_STATE_OFF)
-               return 0;
-
-       reinit_completion(&ab->restart_completed);
-       ret = ath11k_hif_power_up(ab);
-       if (ret)
-               ath11k_warn(ab, "failed to power up hif during resume: %d\n", ret);
-
-       return ret;
-}
-EXPORT_SYMBOL(ath11k_core_resume_early);
+EXPORT_SYMBOL(ath11k_core_suspend);
 
 int ath11k_core_resume(struct ath11k_base *ab)
 {
        int ret;
        struct ath11k_pdev *pdev;
        struct ath11k *ar;
-       long time_left;
 
        if (!ab->hw_params.supports_suspend)
                return -EOPNOTSUPP;
 
-       /* so far single_pdev_only chips have supports_suspend as true
+       /* so far signle_pdev_only chips have supports_suspend as true
         * and only the first pdev is valid.
         */
        pdev = ath11k_core_get_single_pdev(ab);
@@ -1002,19 +952,29 @@ int ath11k_core_resume(struct ath11k_base *ab)
        if (!ar || ar->state != ATH11K_STATE_OFF)
                return 0;
 
-       time_left = wait_for_completion_timeout(&ab->restart_completed,
-                                               ATH11K_RESET_TIMEOUT_HZ);
-       if (time_left == 0) {
-               ath11k_warn(ab, "timeout while waiting for restart complete");
-               return -ETIMEDOUT;
+       ret = ath11k_hif_resume(ab);
+       if (ret) {
+               ath11k_warn(ab, "failed to resume hif during resume: %d\n", ret);
+               return ret;
        }
 
+       ath11k_hif_ce_irq_enable(ab);
+       ath11k_hif_irq_enable(ab);
+
        ret = ath11k_dp_rx_pktlog_start(ab);
-       if (ret)
+       if (ret) {
                ath11k_warn(ab, "failed to start rx pktlog during resume: %d\n",
                            ret);
+               return ret;
+       }
 
-       return ret;
+       ret = ath11k_wow_wakeup(ab);
+       if (ret) {
+               ath11k_warn(ab, "failed to wakeup wow during resume: %d\n", ret);
+               return ret;
+       }
+
+       return 0;
 }
 EXPORT_SYMBOL(ath11k_core_resume);
 
@@ -2109,8 +2069,6 @@ static void ath11k_core_restart(struct work_struct *work)
 
        if (!ab->is_reset)
                ath11k_core_post_reconfigure_recovery(ab);
-
-       complete(&ab->restart_completed);
 }
 
 static void ath11k_core_reset(struct work_struct *work)
@@ -2180,7 +2138,7 @@ static void ath11k_core_reset(struct work_struct *work)
        ath11k_hif_irq_disable(ab);
        ath11k_hif_ce_irq_disable(ab);
 
-       ath11k_hif_power_down(ab, false);
+       ath11k_hif_power_down(ab);
        ath11k_hif_power_up(ab);
 
        ath11k_dbg(ab, ATH11K_DBG_BOOT, "reset started\n");
@@ -2253,7 +2211,7 @@ void ath11k_core_deinit(struct ath11k_base *ab)
 
        mutex_unlock(&ab->core_lock);
 
-       ath11k_hif_power_down(ab, false);
+       ath11k_hif_power_down(ab);
        ath11k_mac_destroy(ab);
        ath11k_core_soc_destroy(ab);
        ath11k_fw_destroy(ab);
@@ -2306,7 +2264,6 @@ struct ath11k_base *ath11k_core_alloc(struct device *dev, size_t priv_size,
        timer_setup(&ab->rx_replenish_retry, ath11k_ce_rx_replenish_retry, 0);
        init_completion(&ab->htc_suspend);
        init_completion(&ab->wow.wakeup_completed);
-       init_completion(&ab->restart_completed);
 
        ab->dev = dev;
        ab->hif.bus = bus;
index df24f0e409afb1b17345c14a29f5b7c24edd45c8..b655967a465bbaf0e9e26fe40090006de234ad42 100644 (file)
@@ -1036,8 +1036,6 @@ struct ath11k_base {
                DECLARE_BITMAP(fw_features, ATH11K_FW_FEATURE_COUNT);
        } fw;
 
-       struct completion restart_completed;
-
 #ifdef CONFIG_NL80211_TESTMODE
        struct {
                u32 data_pos;
@@ -1237,10 +1235,8 @@ void ath11k_core_free_bdf(struct ath11k_base *ab, struct ath11k_board_data *bd);
 int ath11k_core_check_dt(struct ath11k_base *ath11k);
 int ath11k_core_check_smbios(struct ath11k_base *ab);
 void ath11k_core_halt(struct ath11k *ar);
-int ath11k_core_resume_early(struct ath11k_base *ab);
 int ath11k_core_resume(struct ath11k_base *ab);
 int ath11k_core_suspend(struct ath11k_base *ab);
-int ath11k_core_suspend_late(struct ath11k_base *ab);
 void ath11k_core_pre_reconfigure_recovery(struct ath11k_base *ab);
 bool ath11k_core_coldboot_cal_support(struct ath11k_base *ab);
 
index c4c6cc09c7c1610bc25958470b964b490f53e2b5..674ff772b181b99395da13b49ad322c1ea5ec339 100644 (file)
@@ -18,7 +18,7 @@ struct ath11k_hif_ops {
        int (*start)(struct ath11k_base *ab);
        void (*stop)(struct ath11k_base *ab);
        int (*power_up)(struct ath11k_base *ab);
-       void (*power_down)(struct ath11k_base *ab, bool is_suspend);
+       void (*power_down)(struct ath11k_base *ab);
        int (*suspend)(struct ath11k_base *ab);
        int (*resume)(struct ath11k_base *ab);
        int (*map_service_to_pipe)(struct ath11k_base *ab, u16 service_id,
@@ -67,18 +67,12 @@ static inline void ath11k_hif_irq_disable(struct ath11k_base *ab)
 
 static inline int ath11k_hif_power_up(struct ath11k_base *ab)
 {
-       if (!ab->hif.ops->power_up)
-               return -EOPNOTSUPP;
-
        return ab->hif.ops->power_up(ab);
 }
 
-static inline void ath11k_hif_power_down(struct ath11k_base *ab, bool is_suspend)
+static inline void ath11k_hif_power_down(struct ath11k_base *ab)
 {
-       if (!ab->hif.ops->power_down)
-               return;
-
-       ab->hif.ops->power_down(ab, is_suspend);
+       ab->hif.ops->power_down(ab);
 }
 
 static inline int ath11k_hif_suspend(struct ath11k_base *ab)
index ab182690aed32909fc79a15812c64c17ee18c193..6974a551883fcb4cddf9b97ac692eaea43499c7f 100644 (file)
@@ -453,17 +453,9 @@ int ath11k_mhi_start(struct ath11k_pci *ab_pci)
        return 0;
 }
 
-void ath11k_mhi_stop(struct ath11k_pci *ab_pci, bool is_suspend)
+void ath11k_mhi_stop(struct ath11k_pci *ab_pci)
 {
-       /* During suspend we need to use mhi_power_down_keep_dev()
-        * workaround, otherwise ath11k_core_resume() will timeout
-        * during resume.
-        */
-       if (is_suspend)
-               mhi_power_down_keep_dev(ab_pci->mhi_ctrl, true);
-       else
-               mhi_power_down(ab_pci->mhi_ctrl, true);
-
+       mhi_power_down(ab_pci->mhi_ctrl, true);
        mhi_unprepare_after_power_down(ab_pci->mhi_ctrl);
 }
 
index 2d567705e73233df53ade2e9b2d0f44efa0bf1e7..a682aad52fc515f15cabca4c396e85afebee1027 100644 (file)
@@ -18,7 +18,7 @@
 #define MHICTRL_RESET_MASK                     0x2
 
 int ath11k_mhi_start(struct ath11k_pci *ar_pci);
-void ath11k_mhi_stop(struct ath11k_pci *ar_pci, bool is_suspend);
+void ath11k_mhi_stop(struct ath11k_pci *ar_pci);
 int ath11k_mhi_register(struct ath11k_pci *ar_pci);
 void ath11k_mhi_unregister(struct ath11k_pci *ar_pci);
 void ath11k_mhi_set_mhictrl_reset(struct ath11k_base *ab);
@@ -26,4 +26,5 @@ void ath11k_mhi_clear_vector(struct ath11k_base *ab);
 
 int ath11k_mhi_suspend(struct ath11k_pci *ar_pci);
 int ath11k_mhi_resume(struct ath11k_pci *ar_pci);
+
 #endif
index 8d63b84d12614c7bc9a1a402cfbbb1d513197662..be9d2c69cc4137c519244ce02e4eaa3bdf2ec546 100644 (file)
@@ -638,7 +638,7 @@ static int ath11k_pci_power_up(struct ath11k_base *ab)
        return 0;
 }
 
-static void ath11k_pci_power_down(struct ath11k_base *ab, bool is_suspend)
+static void ath11k_pci_power_down(struct ath11k_base *ab)
 {
        struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 
@@ -649,7 +649,7 @@ static void ath11k_pci_power_down(struct ath11k_base *ab, bool is_suspend)
 
        ath11k_pci_msi_disable(ab_pci);
 
-       ath11k_mhi_stop(ab_pci, is_suspend);
+       ath11k_mhi_stop(ab_pci);
        clear_bit(ATH11K_FLAG_DEVICE_INIT_DONE, &ab->dev_flags);
        ath11k_pci_sw_reset(ab_pci->ab, false);
 }
@@ -970,7 +970,7 @@ static void ath11k_pci_remove(struct pci_dev *pdev)
        ath11k_pci_set_irq_affinity_hint(ab_pci, NULL);
 
        if (test_bit(ATH11K_FLAG_QMI_FAIL, &ab->dev_flags)) {
-               ath11k_pci_power_down(ab, false);
+               ath11k_pci_power_down(ab);
                ath11k_debugfs_soc_destroy(ab);
                ath11k_qmi_deinit_service(ab);
                goto qmi_fail;
@@ -998,7 +998,7 @@ static void ath11k_pci_shutdown(struct pci_dev *pdev)
        struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 
        ath11k_pci_set_irq_affinity_hint(ab_pci, NULL);
-       ath11k_pci_power_down(ab, false);
+       ath11k_pci_power_down(ab);
 }
 
 static __maybe_unused int ath11k_pci_pm_suspend(struct device *dev)
@@ -1035,39 +1035,9 @@ static __maybe_unused int ath11k_pci_pm_resume(struct device *dev)
        return ret;
 }
 
-static __maybe_unused int ath11k_pci_pm_suspend_late(struct device *dev)
-{
-       struct ath11k_base *ab = dev_get_drvdata(dev);
-       int ret;
-
-       ret = ath11k_core_suspend_late(ab);
-       if (ret)
-               ath11k_warn(ab, "failed to late suspend core: %d\n", ret);
-
-       /* Similar to ath11k_pci_pm_suspend(), we return success here
-        * even error happens, to allow system suspend/hibernation survive.
-        */
-       return 0;
-}
-
-static __maybe_unused int ath11k_pci_pm_resume_early(struct device *dev)
-{
-       struct ath11k_base *ab = dev_get_drvdata(dev);
-       int ret;
-
-       ret = ath11k_core_resume_early(ab);
-       if (ret)
-               ath11k_warn(ab, "failed to early resume core: %d\n", ret);
-
-       return ret;
-}
-
-static const struct dev_pm_ops __maybe_unused ath11k_pci_pm_ops = {
-       SET_SYSTEM_SLEEP_PM_OPS(ath11k_pci_pm_suspend,
-                               ath11k_pci_pm_resume)
-       SET_LATE_SYSTEM_SLEEP_PM_OPS(ath11k_pci_pm_suspend_late,
-                                    ath11k_pci_pm_resume_early)
-};
+static SIMPLE_DEV_PM_OPS(ath11k_pci_pm_ops,
+                        ath11k_pci_pm_suspend,
+                        ath11k_pci_pm_resume);
 
 static struct pci_driver ath11k_pci_driver = {
        .name = "ath11k_pci",
index 1bc648920ab6668643f4b17fa99fb26558c9f94f..f477afd325deafe7e6e8072e95addd68b8f645a2 100644 (file)
@@ -2877,7 +2877,7 @@ int ath11k_qmi_fwreset_from_cold_boot(struct ath11k_base *ab)
        }
 
        /* reset the firmware */
-       ath11k_hif_power_down(ab, false);
+       ath11k_hif_power_down(ab);
        ath11k_hif_power_up(ab);
        ath11k_dbg(ab, ATH11K_DBG_QMI, "exit wait for cold boot done\n");
        return 0;