Commit 21760dcd authored by Sean Wang's avatar Sean Wang Committed by Felix Fietkau

wifi: mt76: mt7925: extend mt7925_mcu_bss_basic_tlv for per-link BSS

Extend mt7925_mcu_bss_basic_tlv with per-link BSS configuration.

The patch we created is a prerequisite to enable the MLO function in the
driver. It is purely a refactoring patch so the functionality should
remain unchanged.
Co-developed-by: default avatarDeren Wu <deren.wu@mediatek.com>
Signed-off-by: default avatarDeren Wu <deren.wu@mediatek.com>
Signed-off-by: default avatarSean Wang <sean.wang@mediatek.com>
Link: https://patch.msgid.link/20240613030241.5771-18-sean.wang@kernel.orgSigned-off-by: default avatarFelix Fietkau <nbd@nbd.name>
parent ff5efcd4
...@@ -338,6 +338,7 @@ mt7925_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif) ...@@ -338,6 +338,7 @@ mt7925_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
mvif->phy = phy; mvif->phy = phy;
mvif->bss_conf.mt76.band_idx = 0; mvif->bss_conf.mt76.band_idx = 0;
mvif->bss_conf.mt76.wmm_idx = mvif->bss_conf.mt76.idx % MT76_CONNAC_MAX_WMM_SETS; mvif->bss_conf.mt76.wmm_idx = mvif->bss_conf.mt76.idx % MT76_CONNAC_MAX_WMM_SETS;
mvif->bss_conf.vif = mvif;
if (phy->mt76->chandef.chan->band != NL80211_BAND_2GHZ) if (phy->mt76->chandef.chan->band != NL80211_BAND_2GHZ)
mvif->bss_conf.mt76.basic_rates_idx = MT792x_BASIC_RATES_TBL + 4; mvif->bss_conf.mt76.basic_rates_idx = MT792x_BASIC_RATES_TBL + 4;
......
...@@ -2062,15 +2062,16 @@ mt7925_get_phy_mode_ext(struct mt76_phy *phy, struct ieee80211_vif *vif, ...@@ -2062,15 +2062,16 @@ mt7925_get_phy_mode_ext(struct mt76_phy *phy, struct ieee80211_vif *vif,
static void static void
mt7925_mcu_bss_basic_tlv(struct sk_buff *skb, mt7925_mcu_bss_basic_tlv(struct sk_buff *skb,
struct ieee80211_vif *vif, struct ieee80211_bss_conf *link_conf,
struct ieee80211_sta *sta, struct ieee80211_sta *sta,
struct ieee80211_chanctx_conf *ctx, struct ieee80211_chanctx_conf *ctx,
struct mt76_phy *phy, u16 wlan_idx, struct mt76_phy *phy, u16 wlan_idx,
bool enable) bool enable)
{ {
struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv; struct ieee80211_vif *vif = link_conf->vif;
struct mt792x_bss_conf *mconf = mt792x_link_conf_to_mconf(link_conf);
struct mt792x_sta *msta = sta ? (struct mt792x_sta *)sta->drv_priv : struct mt792x_sta *msta = sta ? (struct mt792x_sta *)sta->drv_priv :
&mvif->sta; &mconf->vif->sta;
struct cfg80211_chan_def *chandef = ctx ? &ctx->def : &phy->chandef; struct cfg80211_chan_def *chandef = ctx ? &ctx->def : &phy->chandef;
enum nl80211_band band = chandef->chan->band; enum nl80211_band band = chandef->chan->band;
struct mt76_connac_bss_basic_tlv *basic_req; struct mt76_connac_bss_basic_tlv *basic_req;
...@@ -2081,8 +2082,8 @@ mt7925_mcu_bss_basic_tlv(struct sk_buff *skb, ...@@ -2081,8 +2082,8 @@ mt7925_mcu_bss_basic_tlv(struct sk_buff *skb,
tlv = mt76_connac_mcu_add_tlv(skb, UNI_BSS_INFO_BASIC, sizeof(*basic_req)); tlv = mt76_connac_mcu_add_tlv(skb, UNI_BSS_INFO_BASIC, sizeof(*basic_req));
basic_req = (struct mt76_connac_bss_basic_tlv *)tlv; basic_req = (struct mt76_connac_bss_basic_tlv *)tlv;
idx = mvif->bss_conf.mt76.omac_idx > EXT_BSSID_START ? HW_BSSID_0 : idx = mconf->mt76.omac_idx > EXT_BSSID_START ? HW_BSSID_0 :
mvif->bss_conf.mt76.omac_idx; mconf->mt76.omac_idx;
basic_req->hw_bss_idx = idx; basic_req->hw_bss_idx = idx;
basic_req->phymode_ext = mt7925_get_phy_mode_ext(phy, vif, band, sta); basic_req->phymode_ext = mt7925_get_phy_mode_ext(phy, vif, band, sta);
...@@ -2092,15 +2093,15 @@ mt7925_mcu_bss_basic_tlv(struct sk_buff *skb, ...@@ -2092,15 +2093,15 @@ mt7925_mcu_bss_basic_tlv(struct sk_buff *skb,
else else
basic_req->nonht_basic_phy = cpu_to_le16(PHY_TYPE_OFDM_INDEX); basic_req->nonht_basic_phy = cpu_to_le16(PHY_TYPE_OFDM_INDEX);
memcpy(basic_req->bssid, vif->bss_conf.bssid, ETH_ALEN); memcpy(basic_req->bssid, link_conf->bssid, ETH_ALEN);
basic_req->phymode = mt76_connac_get_phy_mode(phy, vif, band, sta); basic_req->phymode = mt76_connac_get_phy_mode(phy, vif, band, sta);
basic_req->bcn_interval = cpu_to_le16(vif->bss_conf.beacon_int); basic_req->bcn_interval = cpu_to_le16(link_conf->beacon_int);
basic_req->dtim_period = vif->bss_conf.dtim_period; basic_req->dtim_period = link_conf->dtim_period;
basic_req->bmc_tx_wlan_idx = cpu_to_le16(wlan_idx); basic_req->bmc_tx_wlan_idx = cpu_to_le16(wlan_idx);
basic_req->sta_idx = cpu_to_le16(msta->deflink.wcid.idx); basic_req->sta_idx = cpu_to_le16(msta->deflink.wcid.idx);
basic_req->omac_idx = mvif->bss_conf.mt76.omac_idx; basic_req->omac_idx = mconf->mt76.omac_idx;
basic_req->band_idx = mvif->bss_conf.mt76.band_idx; basic_req->band_idx = mconf->mt76.band_idx;
basic_req->wmm_idx = mvif->bss_conf.mt76.wmm_idx; basic_req->wmm_idx = mconf->mt76.wmm_idx;
basic_req->conn_state = !enable; basic_req->conn_state = !enable;
switch (vif->type) { switch (vif->type) {
...@@ -2333,7 +2334,7 @@ int mt7925_mcu_add_bss_info(struct mt792x_phy *phy, ...@@ -2333,7 +2334,7 @@ int mt7925_mcu_add_bss_info(struct mt792x_phy *phy,
return PTR_ERR(skb); return PTR_ERR(skb);
/* bss_basic must be first */ /* bss_basic must be first */
mt7925_mcu_bss_basic_tlv(skb, link_conf->vif, sta, ctx, phy->mt76, mt7925_mcu_bss_basic_tlv(skb, link_conf, sta, ctx, phy->mt76,
mvif->sta.deflink.wcid.idx, enable); mvif->sta.deflink.wcid.idx, enable);
mt7925_mcu_bss_sec_tlv(skb, link_conf); mt7925_mcu_bss_sec_tlv(skb, link_conf);
......
...@@ -108,6 +108,7 @@ struct mt792x_chanctx { ...@@ -108,6 +108,7 @@ struct mt792x_chanctx {
struct mt792x_bss_conf { struct mt792x_bss_conf {
struct mt76_vif mt76; /* must be first */ struct mt76_vif mt76; /* must be first */
struct mt792x_vif *vif;
struct ewma_rssi rssi; struct ewma_rssi rssi;
struct ieee80211_tx_queue_params queue_params[IEEE80211_NUM_ACS]; struct ieee80211_tx_queue_params queue_params[IEEE80211_NUM_ACS];
}; };
......
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