Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit cf8767dd authored by Michal Kazior's avatar Michal Kazior Committed by Johannes Berg
Browse files

mac80211: disconnect iface if CSA unexpectedly fails



It doesn't make much sense to leave a crippled
interface running.

As a side effect this will unblock tx queues with
CSA reason immediately after failure instead of
until after userspace requests interface to stop.

This also gives userspace an opportunity to
indirectly see CSA failure.

Signed-off-by: default avatarMichal Kazior <michal.kazior@tieto.com>
[small code cleanup]
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent 771bb3dd
Loading
Loading
Loading
Loading
+15 −4
Original line number Diff line number Diff line
@@ -3090,7 +3090,7 @@ static int ieee80211_set_after_csa_beacon(struct ieee80211_sub_if_data *sdata,
	return 0;
}

static void ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata)
static int __ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata)
{
	struct ieee80211_local *local = sdata->local;
	u32 changed = 0;
@@ -3101,8 +3101,8 @@ static void ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata)

	sdata->radar_required = sdata->csa_radar_required;
	err = ieee80211_vif_change_channel(sdata, &changed);
	if (WARN_ON(err < 0))
		return;
	if (err < 0)
		return err;

	if (!local->use_chanctx) {
		local->_oper_chandef = sdata->csa_chandef;
@@ -3113,7 +3113,7 @@ static void ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata)

	err = ieee80211_set_after_csa_beacon(sdata, &changed);
	if (err)
		return;
		return err;

	ieee80211_bss_info_change_notify(sdata, changed);
	cfg80211_ch_switch_notify(sdata->dev, &sdata->csa_chandef);
@@ -3122,6 +3122,17 @@ static void ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata)
		ieee80211_wake_queues_by_reason(&local->hw,
					IEEE80211_MAX_QUEUE_MAP,
					IEEE80211_QUEUE_STOP_REASON_CSA);

	return 0;
}

static void ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata)
{
	if (__ieee80211_csa_finalize(sdata)) {
		sdata_info(sdata, "failed to finalize CSA, disconnecting\n");
		cfg80211_stop_iface(sdata->local->hw.wiphy, &sdata->wdev,
				    GFP_KERNEL);
	}
}

void ieee80211_csa_finalize_work(struct work_struct *work)