wifi: rtw88: add flag check before enter or leave IPS
authorChih-Kang Chang <gary.chang@realtek.com>
Tue, 9 Aug 2022 08:41:06 +0000 (16:41 +0800)
committerKalle Valo <kvalo@kernel.org>
Wed, 10 Aug 2022 05:48:46 +0000 (08:48 +0300)
Enter or leave IPS controlled by mac80211 before driver support HW
scan. After support HW scan, driver need to control IPS before start
HW scan and scan complete, but mac80211 also ask driver enter or leave
IPS. Therefore, we add flag check in IPS to prevent entering or
leaving IPS twice.

Signed-off-by: Chih-Kang Chang <gary.chang@realtek.com>
Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20220809084107.38137-7-pkshih@realtek.com
drivers/net/wireless/realtek/rtw88/ps.c

index bfa64c038f5f0a35d6721eba7f4976ce414588aa..c93da743681fc51954f635f4c1455f70a6e77196 100644 (file)
@@ -19,14 +19,14 @@ static int rtw_ips_pwr_up(struct rtw_dev *rtwdev)
                rtw_err(rtwdev, "leave idle state failed\n");
 
        rtw_set_channel(rtwdev);
-       clear_bit(RTW_FLAG_INACTIVE_PS, rtwdev->flags);
 
        return ret;
 }
 
 int rtw_enter_ips(struct rtw_dev *rtwdev)
 {
-       set_bit(RTW_FLAG_INACTIVE_PS, rtwdev->flags);
+       if (test_and_set_bit(RTW_FLAG_INACTIVE_PS, rtwdev->flags))
+               return 0;
 
        rtw_coex_ips_notify(rtwdev, COEX_IPS_ENTER);
 
@@ -50,6 +50,9 @@ int rtw_leave_ips(struct rtw_dev *rtwdev)
 {
        int ret;
 
+       if (!test_and_clear_bit(RTW_FLAG_INACTIVE_PS, rtwdev->flags))
+               return 0;
+
        rtw_hci_link_ps(rtwdev, false);
 
        ret = rtw_ips_pwr_up(rtwdev);