qcacmn: Fill connect response MLO params from mlo_mgr

After mlo connection is completed driver send the connect resp event
to kernel. As of now, driver gets the ML param info from the assoc_rsp IE.
For stand_by link, driver don't have vdev. Due to this, driver can't send the
stand_by info to kernel.

Fix is, instead of assoc_rsp IE driver will use mlo_mgr to get the links
information.

Change-Id: I8da762bed94de4ad2b024183c09b3d0a0f1b7ca4
CRs-Fixed: 3530712
此提交包含在:
Deeksha Gupta
2023-05-31 04:05:19 -07:00
提交者 Rahul Choudhary
父節點 eeeb952b15
當前提交 d47c717a77

查看文件

@@ -34,6 +34,7 @@
#include "wlan_objmgr_vdev_obj.h"
#include "wlan_objmgr_peer_obj.h"
#include "utils_mlo.h"
#include <wlan_mlo_mgr_link_switch.h>
#ifdef CONN_MGR_ADV_FEATURE
void osif_cm_get_assoc_req_ie_data(struct element_info *assoc_req,
@@ -481,14 +482,14 @@ static
void osif_populate_connect_response_for_link(struct wlan_objmgr_vdev *vdev,
struct cfg80211_connect_resp_params *conn_rsp_params,
uint8_t link_id,
uint8_t *link_addr,
struct cfg80211_bss *bss)
{
osif_debug("Link_id :%d", link_id);
conn_rsp_params->valid_links |= BIT(link_id);
conn_rsp_params->links[link_id].bssid = bss->bssid;
conn_rsp_params->links[link_id].bss = bss;
conn_rsp_params->links[link_id].addr =
wlan_vdev_mlme_get_macaddr(vdev);
conn_rsp_params->links[link_id].addr = link_addr;
}
static QDF_STATUS
@@ -516,50 +517,34 @@ osif_fill_peer_mld_mac_connect_resp(struct wlan_objmgr_vdev *vdev,
}
static void
osif_populate_partner_links_mlo_params(struct wlan_objmgr_pdev *pdev,
osif_populate_partner_links_mlo_params(struct wlan_objmgr_vdev *vdev,
struct wlan_cm_connect_resp *rsp,
struct cfg80211_connect_resp_params *conn_rsp_params)
{
struct wlan_objmgr_vdev *partner_vdev;
struct mlo_link_info *rsp_partner_info;
struct mlo_partner_info assoc_partner_info = {0};
struct cfg80211_bss *bss = NULL;
QDF_STATUS qdf_status;
uint8_t link_id = 0, num_links;
int i;
qdf_status = osif_get_partner_info_from_mlie(rsp, &assoc_partner_info);
if (QDF_IS_STATUS_ERROR(qdf_status))
return;
struct mlo_link_info *link_info;
num_links = rsp->ml_parnter_info.num_partner_links;
for (i = 0 ; i < num_links; i++) {
rsp_partner_info = &rsp->ml_parnter_info.partner_link_info[i];
link_id = rsp_partner_info->link_id;
qdf_status = osif_get_link_id_from_assoc_ml_ie(rsp_partner_info,
&assoc_partner_info,
&link_id);
if (QDF_IS_STATUS_ERROR(qdf_status))
link_info = mlo_mgr_get_ap_link_by_link_id(vdev, link_id);
if (!link_info)
continue;
partner_vdev = wlan_objmgr_get_vdev_by_id_from_pdev(pdev,
rsp_partner_info->vdev_id,
WLAN_MLO_MGR_ID);
if (!partner_vdev)
bss = osif_get_chan_bss_from_kernel(vdev, rsp_partner_info,
rsp);
if (!bss)
continue;
bss = osif_get_chan_bss_from_kernel(partner_vdev,
rsp_partner_info, rsp);
if (!bss) {
wlan_objmgr_vdev_release_ref(partner_vdev,
WLAN_MLO_MGR_ID);
continue;
}
osif_populate_connect_response_for_link(partner_vdev,
conn_rsp_params,
link_id, bss);
wlan_objmgr_vdev_release_ref(partner_vdev, WLAN_MLO_MGR_ID);
osif_populate_connect_response_for_link(vdev, conn_rsp_params,
link_id,
link_info->ap_link_addr.bytes,
bss);
}
}
@@ -570,6 +555,7 @@ static void osif_fill_connect_resp_mlo_params(struct wlan_objmgr_vdev *vdev,
{
uint8_t assoc_link_id;
QDF_STATUS qdf_status;
struct mlo_link_info *link_info = NULL;
if (!wlan_vdev_mlme_is_mlo_vdev(vdev))
return;
@@ -582,11 +568,18 @@ static void osif_fill_connect_resp_mlo_params(struct wlan_objmgr_vdev *vdev,
}
assoc_link_id = wlan_vdev_get_link_id(vdev);
osif_populate_connect_response_for_link(vdev, conn_rsp_params,
assoc_link_id, bss);
link_info = mlo_mgr_get_ap_link_by_link_id(vdev, assoc_link_id);
if (!link_info) {
osif_err("Unable to find link_info for link_id: %d",
assoc_link_id);
return;
}
osif_populate_partner_links_mlo_params(wlan_vdev_get_pdev(vdev), rsp,
conn_rsp_params);
osif_populate_connect_response_for_link(vdev, conn_rsp_params,
assoc_link_id,
link_info->ap_link_addr.bytes,
bss);
osif_populate_partner_links_mlo_params(vdev, rsp, conn_rsp_params);
}
static void