.hybrid_bus_type = false,
                .fixed_fw_mem = false,
                .support_off_channel_tx = false,
+               .supports_multi_bssid = false,
        },
        {
                .hw_rev = ATH11K_HW_IPQ6018_HW10,
                .hybrid_bus_type = false,
                .fixed_fw_mem = false,
                .support_off_channel_tx = false,
+               .supports_multi_bssid = false,
        },
        {
                .name = "qca6390 hw2.0",
                .hybrid_bus_type = false,
                .fixed_fw_mem = false,
                .support_off_channel_tx = true,
+               .supports_multi_bssid = true,
        },
        {
                .name = "qcn9074 hw1.0",
                .hybrid_bus_type = false,
                .fixed_fw_mem = false,
                .support_off_channel_tx = false,
+               .supports_multi_bssid = false,
        },
        {
                .name = "wcn6855 hw2.0",
                .hybrid_bus_type = false,
                .fixed_fw_mem = false,
                .support_off_channel_tx = true,
+               .supports_multi_bssid = true,
        },
        {
                .name = "wcn6855 hw2.1",
                .hybrid_bus_type = false,
                .fixed_fw_mem = false,
                .support_off_channel_tx = true,
+               .supports_multi_bssid = true,
        },
        {
                .name = "wcn6750 hw1.0",
                .hybrid_bus_type = true,
                .fixed_fw_mem = true,
                .support_off_channel_tx = false,
+               .supports_multi_bssid = true,
        },
 };
 
 
        if (ab->hw_params.single_pdev_only && ar->supports_6ghz)
                ieee80211_hw_set(ar->hw, SINGLE_SCAN_ON_ALL_BANDS);
 
+       if (ab->hw_params.supports_multi_bssid) {
+               ieee80211_hw_set(ar->hw, SUPPORTS_MULTI_BSSID);
+               ieee80211_hw_set(ar->hw, SUPPORTS_ONLY_HE_MULTI_BSSID);
+       }
+
        ieee80211_hw_set(ar->hw, SIGNAL_DBM);
        ieee80211_hw_set(ar->hw, SUPPORTS_PS);
        ieee80211_hw_set(ar->hw, SUPPORTS_DYNAMIC_PS);
 
 {
        struct ath11k_pdev_wmi *wmi = ar->wmi;
        struct wmi_vdev_up_cmd *cmd;
+       struct ieee80211_bss_conf *bss_conf;
+       struct ath11k_vif *arvif;
        struct sk_buff *skb;
        int ret;
 
+       arvif = ath11k_mac_get_arvif(ar, vdev_id);
+
        skb = ath11k_wmi_alloc_skb(wmi->wmi_ab, sizeof(*cmd));
        if (!skb)
                return -ENOMEM;
 
        ether_addr_copy(cmd->vdev_bssid.addr, bssid);
 
+       if (arvif && arvif->vif->type == NL80211_IFTYPE_STATION) {
+               bss_conf = &arvif->vif->bss_conf;
+
+               if (bss_conf->nontransmitted) {
+                       ether_addr_copy(cmd->trans_bssid.addr,
+                                       bss_conf->transmitter_bssid);
+                       cmd->profile_idx = bss_conf->bssid_index;
+                       cmd->profile_num = bss_conf->bssid_indicator;
+               }
+       }
+
        ret = ath11k_wmi_cmd_send(wmi, skb, WMI_VDEV_UP_CMDID);
        if (ret) {
                ath11k_warn(ar->ab, "failed to submit WMI_VDEV_UP cmd\n");