Commit 104f5a62 authored by Eliad Peller's avatar Eliad Peller Committed by Johannes Berg

mac80211: clear sdata->radar_required

If ieee80211_vif_use_channel() fails, we have to clear
sdata->radar_required (which we might have just set).

Failing to do it results in stale radar_required field
which prevents starting new scan requests.
Reported-by: default avatarJouni Malinen <j@w1.fi>
Signed-off-by: default avatarEliad Peller <eliad@wizery.com>
[use false instead of 0]
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent f2831e20
...@@ -1508,6 +1508,8 @@ static void __ieee80211_vif_release_channel(struct ieee80211_sub_if_data *sdata) ...@@ -1508,6 +1508,8 @@ static void __ieee80211_vif_release_channel(struct ieee80211_sub_if_data *sdata)
if (ieee80211_chanctx_refcount(local, ctx) == 0) if (ieee80211_chanctx_refcount(local, ctx) == 0)
ieee80211_free_chanctx(local, ctx); ieee80211_free_chanctx(local, ctx);
sdata->radar_required = false;
/* Unreserving may ready an in-place reservation. */ /* Unreserving may ready an in-place reservation. */
if (use_reserved_switch) if (use_reserved_switch)
ieee80211_vif_use_reserved_switch(local); ieee80211_vif_use_reserved_switch(local);
...@@ -1566,6 +1568,9 @@ int ieee80211_vif_use_channel(struct ieee80211_sub_if_data *sdata, ...@@ -1566,6 +1568,9 @@ int ieee80211_vif_use_channel(struct ieee80211_sub_if_data *sdata,
ieee80211_recalc_smps_chanctx(local, ctx); ieee80211_recalc_smps_chanctx(local, ctx);
ieee80211_recalc_radar_chanctx(local, ctx); ieee80211_recalc_radar_chanctx(local, ctx);
out: out:
if (ret)
sdata->radar_required = false;
mutex_unlock(&local->chanctx_mtx); mutex_unlock(&local->chanctx_mtx);
return ret; return ret;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment