Commit 9f472520 authored by Johannes Berg's avatar Johannes Berg

wifi: mac80211: refactor chanreq.ap setting

There are now three places setting up chanreq.ap which always
depends on the mode (EHT being used or not) and override flag.
Refactor that code into a common function with a comment, to
make that clearer.
Reviewed-by: default avatarMiriam Rachel Korenblit <miriam.rachel.korenblit@intel.com>
Link: https://msgid.link/20240506215543.5cd6a209e58a.I3be318959d9e2df5dccd2d0938c3d2fcc6688030@changeidSigned-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent 45405681
...@@ -789,6 +789,29 @@ static void ieee80211_rearrange_tpe(struct ieee80211_parsed_tpe *tpe, ...@@ -789,6 +789,29 @@ static void ieee80211_rearrange_tpe(struct ieee80211_parsed_tpe *tpe,
} }
} }
/*
* The AP part of the channel request is used to distinguish settings
* to the device used for wider bandwidth OFDMA. This is used in the
* channel context code to assign two channel contexts even if they're
* both for the same channel, if the AP bandwidths are incompatible.
* If not EHT (or driver override) then ap.chan == NULL indicates that
* there's no wider BW OFDMA used.
*/
static void ieee80211_set_chanreq_ap(struct ieee80211_sub_if_data *sdata,
struct ieee80211_chan_req *chanreq,
struct ieee80211_conn_settings *conn,
struct cfg80211_chan_def *ap_chandef)
{
chanreq->ap.chan = NULL;
if (conn->mode < IEEE80211_CONN_MODE_EHT)
return;
if (sdata->vif.driver_flags & IEEE80211_VIF_IGNORE_OFDMA_WIDER_BW)
return;
chanreq->ap = *ap_chandef;
}
static struct ieee802_11_elems * static struct ieee802_11_elems *
ieee80211_determine_chan_mode(struct ieee80211_sub_if_data *sdata, ieee80211_determine_chan_mode(struct ieee80211_sub_if_data *sdata,
struct ieee80211_conn_settings *conn, struct ieee80211_conn_settings *conn,
...@@ -886,12 +909,7 @@ ieee80211_determine_chan_mode(struct ieee80211_sub_if_data *sdata, ...@@ -886,12 +909,7 @@ ieee80211_determine_chan_mode(struct ieee80211_sub_if_data *sdata,
chanreq->oper = *ap_chandef; chanreq->oper = *ap_chandef;
/* wider-bandwidth OFDMA is only done in EHT */ ieee80211_set_chanreq_ap(sdata, chanreq, conn, ap_chandef);
if (conn->mode >= IEEE80211_CONN_MODE_EHT &&
!(sdata->vif.driver_flags & IEEE80211_VIF_IGNORE_OFDMA_WIDER_BW))
chanreq->ap = *ap_chandef;
else
chanreq->ap.chan = NULL;
while (!ieee80211_chandef_usable(sdata, &chanreq->oper, while (!ieee80211_chandef_usable(sdata, &chanreq->oper,
IEEE80211_CHAN_DISABLED)) { IEEE80211_CHAN_DISABLED)) {
...@@ -999,11 +1017,9 @@ static int ieee80211_config_bw(struct ieee80211_link_data *link, ...@@ -999,11 +1017,9 @@ static int ieee80211_config_bw(struct ieee80211_link_data *link,
return -EINVAL; return -EINVAL;
} }
chanreq.ap = ap_chandef;
chanreq.oper = ap_chandef; chanreq.oper = ap_chandef;
if (link->u.mgd.conn.mode < IEEE80211_CONN_MODE_EHT || ieee80211_set_chanreq_ap(sdata, &chanreq, &link->u.mgd.conn,
sdata->vif.driver_flags & IEEE80211_VIF_IGNORE_OFDMA_WIDER_BW) &ap_chandef);
chanreq.ap.chan = NULL;
/* /*
* if HT operation mode changed store the new one - * if HT operation mode changed store the new one -
...@@ -2535,10 +2551,9 @@ ieee80211_sta_process_chanswitch(struct ieee80211_link_data *link, ...@@ -2535,10 +2551,9 @@ ieee80211_sta_process_chanswitch(struct ieee80211_link_data *link,
link->u.mgd.csa.ap_chandef = csa_ie.chanreq.ap; link->u.mgd.csa.ap_chandef = csa_ie.chanreq.ap;
link->csa.chanreq = csa_ie.chanreq; link->csa.chanreq.oper = csa_ie.chanreq.oper;
if (link->u.mgd.conn.mode < IEEE80211_CONN_MODE_EHT || ieee80211_set_chanreq_ap(sdata, &link->csa.chanreq, &link->u.mgd.conn,
sdata->vif.driver_flags & IEEE80211_VIF_IGNORE_OFDMA_WIDER_BW) &csa_ie.chanreq.ap);
link->csa.chanreq.ap.chan = NULL;
if (chanctx) { if (chanctx) {
res = ieee80211_link_reserve_chanctx(link, &link->csa.chanreq, res = ieee80211_link_reserve_chanctx(link, &link->csa.chanreq,
......
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