On Wed, Feb 5, 2020 at 3:09 PM <yhchuang@xxxxxxxxxxx> wrote: > > From: Ping-Ke Shih <pkshih@xxxxxxxxxxx> > > When driver is coming up, mac80211 will set changed as ~0 (0xffffffff), > and driver could enter IDLE state (power off) before switching channel or > other config event. So move rtw_enter_ips() to the last, to make sure the > driver completed the config events before going to IDLE state. > > So, moves leave/enter IPS config to be first/last one according to flag > IEEE80211_CONF_IDLE. If there're more configureations we want to add in > the future, they must locate between leave/enter IPS. > > Signed-off-by: Ping-Ke Shih <pkshih@xxxxxxxxxxx> > Signed-off-by: Yan-Hsuan Chuang <yhchuang@xxxxxxxxxxx> > --- Reviewed-by: Chris Chiu <chiu@xxxxxxxxxxxx> > drivers/net/wireless/realtek/rtw88/mac80211.c | 19 ++++++++++--------- > 1 file changed, 10 insertions(+), 9 deletions(-) > > diff --git a/drivers/net/wireless/realtek/rtw88/mac80211.c b/drivers/net/wireless/realtek/rtw88/mac80211.c > index 6fc33e11d08c..8742b3f2b5c1 100644 > --- a/drivers/net/wireless/realtek/rtw88/mac80211.c > +++ b/drivers/net/wireless/realtek/rtw88/mac80211.c > @@ -75,15 +75,12 @@ static int rtw_ops_config(struct ieee80211_hw *hw, u32 changed) > > rtw_leave_lps_deep(rtwdev); > > - if (changed & IEEE80211_CONF_CHANGE_IDLE) { > - if (hw->conf.flags & IEEE80211_CONF_IDLE) { > - rtw_enter_ips(rtwdev); > - } else { > - ret = rtw_leave_ips(rtwdev); > - if (ret) { > - rtw_err(rtwdev, "failed to leave idle state\n"); > - goto out; > - } > + if ((changed & IEEE80211_CONF_CHANGE_IDLE) && > + !(hw->conf.flags & IEEE80211_CONF_IDLE)) { > + ret = rtw_leave_ips(rtwdev); > + if (ret) { > + rtw_err(rtwdev, "failed to leave idle state\n"); > + goto out; > } > } > > @@ -99,6 +96,10 @@ static int rtw_ops_config(struct ieee80211_hw *hw, u32 changed) > if (changed & IEEE80211_CONF_CHANGE_CHANNEL) > rtw_set_channel(rtwdev); > > + if ((changed & IEEE80211_CONF_CHANGE_IDLE) && > + (hw->conf.flags & IEEE80211_CONF_IDLE)) > + rtw_enter_ips(rtwdev); > + > out: > mutex_unlock(&rtwdev->mutex); > return ret; > -- > 2.17.1 >