if (cmd == SET_KEY && !sta && !mlink->mt76.cipher) {
                mlink->mt76.cipher = mt76_connac_mcu_get_cipher(key->cipher);
-               mt7996_mcu_add_bss_info(phy, vif, &vif->bss_conf, &mlink->mt76, true);
+               mt7996_mcu_add_bss_info(phy, vif, &vif->bss_conf, &mlink->mt76,
+                                       &mlink->msta_link, true);
        }
 
        if (cmd == SET_KEY) {
 
        mt7996_init_bitrate_mask(vif, link);
 
-       mt7996_mcu_add_bss_info(phy, vif, link_conf, mlink, true);
+       mt7996_mcu_add_bss_info(phy, vif, link_conf, mlink, msta_link, true);
        /* defer the first STA_REC of BMC entry to BSS_CHANGED_BSSID for STA
         * interface, since firmware only records BSSID when the entry is new
         */
 
        mt7996_mcu_add_sta(dev, link_conf, NULL, link, NULL,
                           CONN_STATE_DISCONNECT, false);
-       mt7996_mcu_add_bss_info(phy, vif, link_conf, mlink, false);
+       mt7996_mcu_add_bss_info(phy, vif, link_conf, mlink, msta_link, false);
 
        mt7996_mcu_add_dev_info(phy, vif, link_conf, mlink, false);
 
                                continue;
 
                        mt7996_mcu_add_bss_info(link->phy, vif, link_conf,
-                                               &link->mt76, true);
+                                               &link->mt76, &link->msta_link,
+                                               true);
                        mt7996_mcu_add_sta(dev, link_conf, NULL, link, NULL,
                                           CONN_STATE_PORT_SECURE,
                                           !!(changed & BSS_CHANGED_BSSID));
         */
        if ((changed & BSS_CHANGED_BSSID && !is_zero_ether_addr(info->bssid)) ||
            (changed & BSS_CHANGED_BEACON_ENABLED && info->enable_beacon)) {
-               mt7996_mcu_add_bss_info(phy, vif, info, &link->mt76, true);
+               mt7996_mcu_add_bss_info(phy, vif, info, &link->mt76,
+                                       &link->msta_link, true);
                mt7996_mcu_add_sta(dev, info, NULL, link, NULL,
                                   CONN_STATE_PORT_SECURE,
                                   !!(changed & BSS_CHANGED_BSSID));
 
 
 int mt7996_mcu_add_bss_info(struct mt7996_phy *phy, struct ieee80211_vif *vif,
                            struct ieee80211_bss_conf *link_conf,
-                           struct mt76_vif_link *mlink, int enable)
+                           struct mt76_vif_link *mlink,
+                           struct mt7996_sta_link *msta_link, int enable)
 {
        struct mt7996_dev *dev = phy->dev;
        struct sk_buff *skb;
 
        /* bss_basic must be first */
        mt7996_mcu_bss_basic_tlv(skb, vif, link_conf, mlink, phy->mt76,
-                                mlink->wcid->idx, enable);
+                                msta_link->wcid.idx, enable);
        mt7996_mcu_bss_sec_tlv(skb, mlink);
 
        if (vif->type == NL80211_IFTYPE_MONITOR)
 
                            struct mt76_vif_link *mlink, bool enable);
 int mt7996_mcu_add_bss_info(struct mt7996_phy *phy, struct ieee80211_vif *vif,
                            struct ieee80211_bss_conf *link_conf,
-                           struct mt76_vif_link *mlink, int enable);
+                           struct mt76_vif_link *mlink,
+                           struct mt7996_sta_link *msta_link, int enable);
 int mt7996_mcu_add_sta(struct mt7996_dev *dev,
                       struct ieee80211_bss_conf *link_conf,
                       struct ieee80211_link_sta *link_sta,