wifi: ath12k: send partner device details in QMI MLO capability

Currently, QMI MLO host capability is sent with the details of local links and
hw_link id only for particular device. But in the case of multi device group
abstraction, it has to include the details of hw_link_id, num_local_links of
every partner device that is involved in the group during QMI MLO capability
exchange. Add changes to send partner device details to the firmware in QMI MLO
capability exchange.

Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.3.1-00173-QCAHKSWPL_SILICONZ-1
Tested-on: WCN7850 hw2.0 PCI WLAN.HMT.1.0.c5-00481-QCAHMTSWPL_V1.0_V2.0_SILICONZ-3

Signed-off-by: Karthikeyan Periyasamy <quic_periyasa@quicinc.com>
Signed-off-by: Harshitha Prem <quic_hprem@quicinc.com>
Signed-off-by: Kalle Valo <quic_kvalo@quicinc.com>
Link: https://patch.msgid.link/20241211153432.775335-4-kvalo@kernel.org
Signed-off-by: Jeff Johnson <jeff.johnson@oss.qualcomm.com>
This commit is contained in:
Karthikeyan Periyasamy 2024-12-11 17:34:27 +02:00 committed by Jeff Johnson
parent 908c10c860
commit 08a4c51c6e

View File

@ -2016,17 +2016,19 @@ static const struct qmi_elem_info qmi_wlanfw_wlan_ini_resp_msg_v01_ei[] = {
},
};
static void ath12k_host_cap_parse_mlo(struct ath12k_base *ab,
struct qmi_wlanfw_host_cap_req_msg_v01 *req)
static int ath12k_host_cap_parse_mlo(struct ath12k_base *ab,
struct qmi_wlanfw_host_cap_req_msg_v01 *req)
{
struct wlfw_host_mlo_chip_info_s_v01 *info;
struct ath12k_hw_group *ag = ab->ag;
struct ath12k_base *partner_ab;
u8 hw_link_id = 0;
int i;
int i, j, ret;
if (!ab->ag->mlo_capable) {
if (!ag->mlo_capable) {
ath12k_dbg(ab, ATH12K_DBG_QMI,
"MLO is disabled hence skip QMI MLO cap");
return;
return 0;
}
if (!ab->qmi.num_radios || ab->qmi.num_radios == U8_MAX) {
@ -2035,7 +2037,12 @@ static void ath12k_host_cap_parse_mlo(struct ath12k_base *ab,
ath12k_dbg(ab, ATH12K_DBG_QMI,
"skip QMI MLO cap due to invalid num_radio %d\n",
ab->qmi.num_radios);
return;
return 0;
}
if (ab->device_id == ATH12K_INVALID_DEVICE_ID) {
ath12k_err(ab, "failed to send MLO cap due to invalid device id\n");
return -EINVAL;
}
req->mlo_capable_valid = 1;
@ -2043,27 +2050,74 @@ static void ath12k_host_cap_parse_mlo(struct ath12k_base *ab,
req->mlo_chip_id_valid = 1;
req->mlo_chip_id = ab->device_id;
req->mlo_group_id_valid = 1;
req->mlo_group_id = 0;
req->mlo_group_id = ag->id;
req->max_mlo_peer_valid = 1;
/* Max peer number generally won't change for the same device
* but needs to be synced with host driver.
*/
req->max_mlo_peer = ab->hw_params->max_mlo_peer;
req->mlo_num_chips_valid = 1;
req->mlo_num_chips = 1;
req->mlo_num_chips = ag->num_devices;
info = &req->mlo_chip_info[0];
info->chip_id = ab->device_id;
info->num_local_links = ab->qmi.num_radios;
mutex_lock(&ag->mutex);
for (i = 0; i < info->num_local_links; i++) {
info->hw_link_id[i] = hw_link_id;
info->valid_mlo_link_id[i] = 1;
for (i = 0; i < ag->num_devices; i++) {
info = &req->mlo_chip_info[i];
partner_ab = ag->ab[i];
hw_link_id++;
if (partner_ab->device_id == ATH12K_INVALID_DEVICE_ID) {
ath12k_err(ab, "failed to send MLO cap due to invalid partner device id\n");
ret = -EINVAL;
goto device_cleanup;
}
info->chip_id = partner_ab->device_id;
info->num_local_links = partner_ab->qmi.num_radios;
ath12k_dbg(ab, ATH12K_DBG_QMI, "mlo device id %d num_link %d\n",
info->chip_id, info->num_local_links);
for (j = 0; j < info->num_local_links; j++) {
info->hw_link_id[j] = hw_link_id;
info->valid_mlo_link_id[j] = 1;
hw_link_id++;
}
}
if (hw_link_id <= 0)
ag->mlo_capable = false;
req->mlo_chip_info_valid = 1;
mutex_unlock(&ag->mutex);
return 0;
device_cleanup:
for (i = i - 1; i >= 0; i--) {
info = &req->mlo_chip_info[i];
memset(info, 0, sizeof(*info));
}
req->mlo_num_chips = 0;
req->mlo_num_chips_valid = 0;
req->max_mlo_peer = 0;
req->max_mlo_peer_valid = 0;
req->mlo_group_id = 0;
req->mlo_group_id_valid = 0;
req->mlo_chip_id = 0;
req->mlo_chip_id_valid = 0;
req->mlo_capable = 0;
req->mlo_capable_valid = 0;
ag->mlo_capable = false;
mutex_unlock(&ag->mutex);
return ret;
}
/* clang stack usage explodes if this is inlined */
@ -2113,7 +2167,9 @@ int ath12k_qmi_host_cap_send(struct ath12k_base *ab)
req.nm_modem |= PLATFORM_CAP_PCIE_GLOBAL_RESET;
}
ath12k_host_cap_parse_mlo(ab, &req);
ret = ath12k_host_cap_parse_mlo(ab, &req);
if (ret < 0)
goto out;
ret = qmi_txn_init(&ab->qmi.handle, &txn,
qmi_wlanfw_host_cap_resp_msg_v01_ei, &resp);