diff options
author | Johannes Berg <johannes.berg@intel.com> | 2019-02-05 21:08:29 +0100 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2019-02-11 15:46:29 +0100 |
commit | e646a0257b64dbef9d168e0f90daafa3fc1a83af (patch) | |
tree | 305a86576873ac7e682a2f2639c760731be6026c /net/wireless/Kconfig | |
parent | ieee80211: fix for_each_element_extid() (diff) | |
download | linux-e646a0257b64dbef9d168e0f90daafa3fc1a83af.tar.xz linux-e646a0257b64dbef9d168e0f90daafa3fc1a83af.zip |
cfg80211: restore regulatory without calling userspace
Jouni reports that in some cases it is possible that getting
disconnected (or stopping AP, after previous patches) results
in further operations hitting the window within the regulatory
core restoring the regdomain to the defaults. The reason for
this is that we have to call out to CRDA or otherwise do some
asynchronous work, and thus can't do the restore atomically.
However, we've previously seen all the data we need to do the
restore, so we can hang on to that data and use it later for
the restore. This makes the whole thing happen within a single
locked section and thus atomic.
However, we can't *always* do this - there are unfortunately
cases where the restore needs to re-request, because this is
also used (abused?) as an error recovery process, so make the
new behaviour optional and only use it when doing a regular
restore as described above.
Reported-by: Jouni Malinen <j@w1.fi>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/wireless/Kconfig')
0 files changed, 0 insertions, 0 deletions