msta_link = container_of(wcid, struct mt7996_sta_link, wcid);
msta = msta_link->sta;
- if (!msta->vif)
+ if (!msta || !msta->vif)
return NULL;
- return &msta->vif->deflink.sta.deflink.wcid;
+ return &msta->vif->deflink.msta_link.wcid;
}
bool mt7996_mac_wtbl_update(struct mt7996_dev *dev, int idx, u32 mask)
struct ieee80211_vif *vif, bool enable)
{
struct mt7996_vif *mvif = (struct mt7996_vif *)vif->drv_priv;
- struct mt7996_sta_link *msta_link = &mvif->deflink.sta.deflink;
+ struct mt7996_sta_link *msta_link = &mvif->deflink.msta_link;
u32 addr;
addr = mt7996_mac_wtbl_lmac_addr(dev, msta_link->wcid.idx, 5);
struct mt7996_vif_link *mlink, struct ieee80211_key_conf *key)
{
struct mt7996_dev *dev = mt7996_hw_dev(hw);
- struct mt7996_sta *msta = sta ? (struct mt7996_sta *)sta->drv_priv :
- &mlink->sta;
- struct mt76_wcid *wcid = &msta->deflink.wcid;
- u8 *wcid_keyidx = &wcid->hw_key_idx;
+ struct mt76_wcid *wcid = &mlink->msta_link.wcid;
struct mt7996_phy *phy;
int idx = key->keyidx;
+ u8 *wcid_keyidx;
phy = mt7996_vif_link_phy(mlink);
if (!phy)
return -EINVAL;
- if (sta && !wcid->sta)
- return -EOPNOTSUPP;
+ if (sta) {
+ struct mt7996_sta *msta = (struct mt7996_sta *)sta->drv_priv;
+
+ wcid = &msta->deflink.wcid;
+ if (!wcid->sta)
+ return -EOPNOTSUPP;
+ }
+ wcid_keyidx = &wcid->hw_key_idx;
switch (key->cipher) {
case WLAN_CIPHER_SUITE_AES_CMAC:
struct mt76_vif_link *mlink)
{
struct mt7996_vif_link *link = container_of(mlink, struct mt7996_vif_link, mt76);
- struct mt7996_sta_link *msta_link = &link->sta.deflink;
+ struct mt7996_sta_link *msta_link = &link->msta_link;
struct mt7996_phy *phy = mphy->priv;
struct mt7996_dev *dev = phy->dev;
u8 band_idx = phy->mt76->band_idx;
idx = MT7996_WTBL_RESERVED - mlink->idx;
INIT_LIST_HEAD(&msta_link->rc_list);
- msta_link->sta = &link->sta;
msta_link->wcid.idx = idx;
msta_link->wcid.tx_info |= MT_WCID_TX_INFO_SET;
mt76_wcid_init(&msta_link->wcid, band_idx);
struct mt76_vif_link *mlink)
{
struct mt7996_vif_link *link = container_of(mlink, struct mt7996_vif_link, mt76);
+ struct mt7996_sta_link *msta_link = &link->msta_link;
struct mt7996_phy *phy = mphy->priv;
struct mt7996_dev *dev = phy->dev;
- struct mt7996_sta *msta = &link->sta;
- struct mt7996_sta_link *msta_link = &msta->deflink;
int idx = msta_link->wcid.idx;
mt7996_mcu_add_sta(dev, vif, mlink, NULL, CONN_STATE_DISCONNECT, false);
struct mt7996_vif *mvif;
mvif = (struct mt7996_vif *)vif->drv_priv;
- wcid = &mvif->deflink.sta.deflink.wcid;
+ wcid = &mvif->deflink.msta_link.wcid;
if (mvif->mt76.roc_phy &&
(info->flags & IEEE80211_TX_CTL_TX_OFFCHAN)) {
.val = cpu_to_le32(mvif->deflink.mt76.idx % 16),
};
- msta = sta ? (struct mt7996_sta *)sta->drv_priv : &mvif->deflink.sta;
- msta_link = &msta->deflink;
+ msta = sta ? (struct mt7996_sta *)sta->drv_priv : NULL;
+ msta_link = msta ? &msta->deflink : &mvif->deflink.msta_link;
req.wlan_idx = cpu_to_le16(msta_link->wcid.idx);
return mt76_mcu_send_msg(&dev->mt76, MCU_WM_UNI_CMD(VOW), &req,
{
#define TSC_TYPE_BIGTK_PN 2
struct mt7996_vif *mvif = (struct mt7996_vif *)vif->drv_priv;
- struct mt7996_sta_link *msta_link = &mvif->deflink.sta.deflink;
+ struct mt7996_sta_link *msta_link = &mvif->deflink.msta_link;
struct sta_rec_pn_info *pn_info;
struct sk_buff *skb, *rskb;
struct tlv *tlv;
struct mt7996_sta *msta;
struct sk_buff *skb;
- msta = sta ? (struct mt7996_sta *)sta->drv_priv : &mvif->deflink.sta;
- msta_link = &msta->deflink;
+ msta = sta ? (struct mt7996_sta *)sta->drv_priv : NULL;
+ msta_link = msta ? &msta->deflink : &mvif->deflink.msta_link;
skb = __mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->deflink.mt76,
&msta_link->wcid,