cfg80211: call disconnect_wk when AP stops
[ Upstream commit e005bd7ddea06784c1eb91ac5bb6b171a94f3b05 ] Since we now prevent regulatory restore during STA disconnect if concurrent AP interfaces are active, we need to reschedule this check when the AP state changes. This fixes never doing a restore when an AP is the last interface to stop. Or to put it another way: we need to re-check after anything we check here changes. Cc: stable@vger.kernel.org Fixes: 113f3aaa81bd ("cfg80211: Prevent regulatory restore during STA disconnect in concurrent interfaces") Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
2b3541ffdd
commit
16a300fb1d
3 changed files with 5 additions and 1 deletions
|
@ -41,6 +41,8 @@ int __cfg80211_stop_ap(struct cfg80211_registered_device *rdev,
|
|||
cfg80211_sched_dfs_chan_update(rdev);
|
||||
}
|
||||
|
||||
schedule_work(&cfg80211_disconnect_work);
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
|
|
|
@ -430,6 +430,8 @@ void cfg80211_process_wdev_events(struct wireless_dev *wdev);
|
|||
bool cfg80211_does_bw_fit_range(const struct ieee80211_freq_range *freq_range,
|
||||
u32 center_freq_khz, u32 bw_khz);
|
||||
|
||||
extern struct work_struct cfg80211_disconnect_work;
|
||||
|
||||
/**
|
||||
* cfg80211_chandef_dfs_usable - checks if chandef is DFS usable
|
||||
* @wiphy: the wiphy to validate against
|
||||
|
|
|
@ -667,7 +667,7 @@ static void disconnect_work(struct work_struct *work)
|
|||
rtnl_unlock();
|
||||
}
|
||||
|
||||
static DECLARE_WORK(cfg80211_disconnect_work, disconnect_work);
|
||||
DECLARE_WORK(cfg80211_disconnect_work, disconnect_work);
|
||||
|
||||
|
||||
/*
|
||||
|
|
Loading…
Reference in a new issue