mirror of
https://git.openwrt.org/openwrt/openwrt.git
synced 2025-08-21 13:24:14 +00:00
380 lines
15 KiB
Diff
380 lines
15 KiB
Diff
From patchwork Wed May 21 22:45:38 2025
|
|
Content-Type: text/plain; charset="utf-8"
|
|
MIME-Version: 1.0
|
|
Content-Transfer-Encoding: 7bit
|
|
X-Patchwork-Submitter: Pradeep Kumar Chitrapu <quic_pradeepc@quicinc.com>
|
|
X-Patchwork-Id: 14096124
|
|
X-Patchwork-Delegate: quic_jjohnson@quicinc.com
|
|
Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com
|
|
[205.220.180.131])
|
|
(using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits))
|
|
(No client certificate requested)
|
|
by smtp.subspace.kernel.org (Postfix) with ESMTPS id DEE9223A9AA
|
|
for <linux-wireless@vger.kernel.org>; Wed, 21 May 2025 22:45:59 +0000 (UTC)
|
|
Authentication-Results: smtp.subspace.kernel.org;
|
|
arc=none smtp.client-ip=205.220.180.131
|
|
ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;
|
|
t=1747867561; cv=none;
|
|
b=qWgm5H8L0Zhrc5crkCw7SBoGEQ8yf+aC0TSWOzfiTwcAddeStpjorEa3XaBl0GOhHPRaECOhMSNqu88tQ5CzCGmumBQ3QLC6mod6Tb0Y0PdeUJm3YoGKcI+F0oE3g5kCHaU9LRKKnmMZQS72kE7dO+lEBfwMIuCX/VwV066B1p8=
|
|
ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org;
|
|
s=arc-20240116; t=1747867561; c=relaxed/simple;
|
|
bh=61S52HJJJauXcXkg3NpFqkwtGSPNO+bmTpNYu1v9AKM=;
|
|
h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References:
|
|
MIME-Version:Content-Type;
|
|
b=gi5WIxM8SYlljyfdAVTdIK6JQ5jJHPGGfdxPkwbtEaPElRA55vurxkaaJ0RktTtDYYJEn7KLZFieBHAv5/nEcrDjL4NGvgT3wiAoGcbsd+TIF6w5J2RSmAwhAP008N5swveLHDzJ0M9TrtQj2HHndc8JPD4oGWbcEqKQqHSq8ck=
|
|
ARC-Authentication-Results: i=1; smtp.subspace.kernel.org;
|
|
dmarc=pass (p=none dis=none) header.from=quicinc.com;
|
|
spf=pass smtp.mailfrom=quicinc.com;
|
|
dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com
|
|
header.b=lMYw009C; arc=none smtp.client-ip=205.220.180.131
|
|
Authentication-Results: smtp.subspace.kernel.org;
|
|
dmarc=pass (p=none dis=none) header.from=quicinc.com
|
|
Authentication-Results: smtp.subspace.kernel.org;
|
|
spf=pass smtp.mailfrom=quicinc.com
|
|
Authentication-Results: smtp.subspace.kernel.org;
|
|
dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com
|
|
header.b="lMYw009C"
|
|
Received: from pps.filterd (m0279868.ppops.net [127.0.0.1])
|
|
by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id
|
|
54LJgEPE029249;
|
|
Wed, 21 May 2025 22:45:56 GMT
|
|
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h=
|
|
cc:content-transfer-encoding:content-type:date:from:in-reply-to
|
|
:message-id:mime-version:references:subject:to; s=qcppdkim1; bh=
|
|
ph+yJaIkwYsZzzEsymzTjupgmHjdwFMJhbEzuPrYvfY=; b=lMYw009CSvZqDxkz
|
|
+HCEzcZhy6QO8G2ut93TJxHdCbVLlRaMNReXGlGqx2KRNracyLRkAQsC16i+QcpJ
|
|
aHBvIE2c0/TEtBiyv3HzBf3/89R0POT080sz81P6go3m8w9bcIE+Q2DqjdhVNqu3
|
|
AlV8qb6pj/QUVvDbJQxO1M9eCXSO6g2BBDjgRCktOu+x2TlxhdBZ/tJP+h0AUk+j
|
|
YsH1LhcLOZYCFTJyB6IFmHWvtGk5Ef6i6D/tXyCL7nQiDP/R1v2PcdlLlI5e5/PO
|
|
FhKB2+RCmSyJUtyaAHHi/mVen5yqFX2K3/vL3BtprRAJINhFxQrLs6xLIQabELzj
|
|
KCstuQ==
|
|
Received: from nalasppmta04.qualcomm.com (Global_NAT1.qualcomm.com
|
|
[129.46.96.20])
|
|
by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 46rwfb4b3x-1
|
|
(version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT);
|
|
Wed, 21 May 2025 22:45:55 +0000 (GMT)
|
|
Received: from nalasex01a.na.qualcomm.com (nalasex01a.na.qualcomm.com
|
|
[10.47.209.196])
|
|
by NALASPPMTA04.qualcomm.com (8.18.1.2/8.18.1.2) with ESMTPS id
|
|
54LMjtX2022238
|
|
(version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT);
|
|
Wed, 21 May 2025 22:45:55 GMT
|
|
Received: from ath12k-linux2.qualcomm.com (10.80.80.8) by
|
|
nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server
|
|
(version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id
|
|
15.2.1544.9; Wed, 21 May 2025 15:45:54 -0700
|
|
From: Pradeep Kumar Chitrapu <quic_pradeepc@quicinc.com>
|
|
To: <ath12k@lists.infradead.org>
|
|
CC: <linux-wireless@vger.kernel.org>,
|
|
Pradeep Kumar Chitrapu
|
|
<quic_pradeepc@quicinc.com>,
|
|
P Praneesh <quic_ppranees@quicinc.com>,
|
|
"Jeff
|
|
Johnson" <quic_jjohnson@quicinc.com>
|
|
Subject: [PATCH ath-next V14 8/9] wifi: ath12k: add support for 160 MHz
|
|
bandwidth
|
|
Date: Wed, 21 May 2025 15:45:38 -0700
|
|
Message-ID: <20250521224539.355985-9-quic_pradeepc@quicinc.com>
|
|
X-Mailer: git-send-email 2.43.0
|
|
In-Reply-To: <20250521224539.355985-1-quic_pradeepc@quicinc.com>
|
|
References: <20250521224539.355985-1-quic_pradeepc@quicinc.com>
|
|
Precedence: bulk
|
|
X-Mailing-List: linux-wireless@vger.kernel.org
|
|
List-Id: <linux-wireless.vger.kernel.org>
|
|
List-Subscribe: <mailto:linux-wireless+subscribe@vger.kernel.org>
|
|
List-Unsubscribe: <mailto:linux-wireless+unsubscribe@vger.kernel.org>
|
|
MIME-Version: 1.0
|
|
X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To
|
|
nalasex01a.na.qualcomm.com (10.47.209.196)
|
|
X-QCInternal: smtphost
|
|
X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800
|
|
signatures=585085
|
|
X-Proofpoint-ORIG-GUID: T9MbsOp4F8M93FD6ZEyfm1BTh5tEiCIl
|
|
X-Proofpoint-Spam-Details-Enc: AW1haW4tMjUwNTIxMDIyNiBTYWx0ZWRfX0EeEFBAyVxZV
|
|
WX6jh2dkCn4P+eViI8Gvz/6S+yZ+Avx9/8To2mbulh5j1kDm92bEDu7iQtI17ILPnOgbUXWAjjt
|
|
Z2LvemtbMzJe0lY0EjJNWWunihdlsXPAdOnZFjV0rOtakq8Xx4y8K45/1cGY9dQOApxDFC9HiLZ
|
|
+FK9apopZ2DyP6haLf5HQI+6DC3wwgbEQlE+89g69hXEM8UePlFlsf0fpfIVgiWG73gfzHkrRPM
|
|
8ByVGmKpFSXIBmvY+EZZOPuPsQHt/91pIisXw5Joxdbl6Qf2anjuC0X4LPrTgTxgXWhljS4JdXo
|
|
djhNt09IBnNuagxN9aMx/frUhqQPNL54kp/cXbpgcLQX0XQg8SOvwyxJs+CALQUyymluDLHyH9w
|
|
UQUznCXFrps86AX/Fpnhrl9hqR5NO0/6oR340zsS7mvryRucOqzT7vc3WPMJEhW68VMCAl5Z
|
|
X-Proofpoint-GUID: T9MbsOp4F8M93FD6ZEyfm1BTh5tEiCIl
|
|
X-Authority-Analysis: v=2.4 cv=dLCmmPZb c=1 sm=1 tr=0 ts=682e57a4 cx=c_pps
|
|
a=ouPCqIW2jiPt+lZRy3xVPw==:117 a=ouPCqIW2jiPt+lZRy3xVPw==:17
|
|
a=GEpy-HfZoHoA:10 a=dt9VzEwgFbYA:10 a=COk6AnOGAAAA:8 a=dOJm2eNAaUnF9U8lSB4A:9
|
|
a=TjNXssC_j7lpFel5tvFf:22
|
|
X-Proofpoint-Virus-Version: vendor=baseguard
|
|
engine=ICAP:2.0.293,Aquarius:18.0.1099,Hydra:6.0.736,FMLib:17.12.80.40
|
|
definitions=2025-05-21_07,2025-05-20_03,2025-03-28_01
|
|
X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0
|
|
mlxscore=0 clxscore=1015 adultscore=0 bulkscore=0 phishscore=0 suspectscore=0
|
|
impostorscore=0 malwarescore=0 lowpriorityscore=0 mlxlogscore=999 spamscore=0
|
|
priorityscore=1501 classifier=spam authscore=0 authtc=n/a authcc=
|
|
route=outbound adjust=0 reason=mlx scancount=1 engine=8.19.0-2505160000
|
|
definitions=main-2505210226
|
|
|
|
Add support to configure maximum NSS in 160 MHz bandwidth.
|
|
Firmware advertises support for handling NSS ratio information
|
|
as a part of service ready ext event using nss_ratio_enabled
|
|
flag. Save this information in ath12k_pdev_cap to calculate
|
|
NSS ratio.
|
|
|
|
Additionally, reorder the code by moving
|
|
ath12k_peer_assoc_h_phymode() before ath12k_peer_assoc_h_vht()
|
|
to ensure that arg->peer_phymode correctly reflects the bandwidth
|
|
in the max NSS calculation.
|
|
|
|
Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.0.1-00029-QCAHKSWPL_SILICONZ-1
|
|
|
|
Co-developed-by: P Praneesh <quic_ppranees@quicinc.com>
|
|
Signed-off-by: P Praneesh <quic_ppranees@quicinc.com>
|
|
Signed-off-by: Pradeep Kumar Chitrapu <quic_pradeepc@quicinc.com>
|
|
Acked-by: Jeff Johnson <quic_jjohnson@quicinc.com>
|
|
---
|
|
drivers/net/wireless/ath/ath12k/core.h | 2 +
|
|
drivers/net/wireless/ath/ath12k/mac.c | 89 ++++++++++++++++++++++----
|
|
drivers/net/wireless/ath/ath12k/mac.h | 2 +
|
|
drivers/net/wireless/ath/ath12k/wmi.c | 7 +-
|
|
drivers/net/wireless/ath/ath12k/wmi.h | 28 ++++++++
|
|
5 files changed, 115 insertions(+), 13 deletions(-)
|
|
|
|
--- a/drivers/net/wireless/ath/ath12k/core.h
|
|
+++ b/drivers/net/wireless/ath/ath12k/core.h
|
|
@@ -879,6 +879,8 @@ struct ath12k_pdev_cap {
|
|
struct ath12k_band_cap band[NUM_NL80211_BANDS];
|
|
u32 eml_cap;
|
|
u32 mld_cap;
|
|
+ bool nss_ratio_enabled;
|
|
+ u8 nss_ratio_info;
|
|
};
|
|
|
|
struct mlo_timestamp {
|
|
--- a/drivers/net/wireless/ath/ath12k/mac.c
|
|
+++ b/drivers/net/wireless/ath/ath12k/mac.c
|
|
@@ -2185,6 +2185,34 @@ ath12k_peer_assoc_h_vht_limit(u16 tx_mcs
|
|
return tx_mcs_set;
|
|
}
|
|
|
|
+static u8 ath12k_get_nss_160mhz(struct ath12k *ar,
|
|
+ u8 max_nss)
|
|
+{
|
|
+ u8 nss_ratio_info = ar->pdev->cap.nss_ratio_info;
|
|
+ u8 max_sup_nss = 0;
|
|
+
|
|
+ switch (nss_ratio_info) {
|
|
+ case WMI_NSS_RATIO_1BY2_NSS:
|
|
+ max_sup_nss = max_nss >> 1;
|
|
+ break;
|
|
+ case WMI_NSS_RATIO_3BY4_NSS:
|
|
+ ath12k_warn(ar->ab, "WMI_NSS_RATIO_3BY4_NSS not supported\n");
|
|
+ break;
|
|
+ case WMI_NSS_RATIO_1_NSS:
|
|
+ max_sup_nss = max_nss;
|
|
+ break;
|
|
+ case WMI_NSS_RATIO_2_NSS:
|
|
+ ath12k_warn(ar->ab, "WMI_NSS_RATIO_2_NSS not supported\n");
|
|
+ break;
|
|
+ default:
|
|
+ ath12k_warn(ar->ab, "invalid nss ratio received from fw: %d\n",
|
|
+ nss_ratio_info);
|
|
+ break;
|
|
+ }
|
|
+
|
|
+ return max_sup_nss;
|
|
+}
|
|
+
|
|
static void ath12k_peer_assoc_h_vht(struct ath12k *ar,
|
|
struct ath12k_link_vif *arvif,
|
|
struct ath12k_link_sta *arsta,
|
|
@@ -2202,6 +2230,7 @@ static void ath12k_peer_assoc_h_vht(stru
|
|
u8 max_nss, vht_mcs;
|
|
int i, vht_nss, nss_idx;
|
|
bool user_rate_valid = true;
|
|
+ u32 rx_nss, tx_nss, nss_160;
|
|
|
|
lockdep_assert_wiphy(ath12k_ar_to_hw(ar)->wiphy);
|
|
|
|
@@ -2306,10 +2335,24 @@ static void ath12k_peer_assoc_h_vht(stru
|
|
/* TODO: Check */
|
|
arg->tx_max_mcs_nss = 0xFF;
|
|
|
|
- ath12k_dbg(ar->ab, ATH12K_DBG_MAC, "mac vht peer %pM max_mpdu %d flags 0x%x\n",
|
|
- arsta->addr, arg->peer_max_mpdu, arg->peer_flags);
|
|
+ if (arg->peer_phymode == MODE_11AC_VHT160) {
|
|
+ tx_nss = ath12k_get_nss_160mhz(ar, max_nss);
|
|
+ rx_nss = min(arg->peer_nss, tx_nss);
|
|
+ arg->peer_bw_rxnss_override = ATH12K_BW_NSS_MAP_ENABLE;
|
|
+
|
|
+ if (!rx_nss) {
|
|
+ ath12k_warn(ar->ab, "invalid max_nss\n");
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ nss_160 = u32_encode_bits(rx_nss - 1, ATH12K_PEER_RX_NSS_160MHZ);
|
|
+ arg->peer_bw_rxnss_override |= nss_160;
|
|
+ }
|
|
|
|
- /* TODO: rxnss_override */
|
|
+ ath12k_dbg(ar->ab, ATH12K_DBG_MAC,
|
|
+ "mac vht peer %pM max_mpdu %d flags 0x%x nss_override 0x%x\n",
|
|
+ arsta->addr, arg->peer_max_mpdu, arg->peer_flags,
|
|
+ arg->peer_bw_rxnss_override);
|
|
}
|
|
|
|
static int ath12k_mac_get_max_he_mcs_map(u16 mcs_map, int nss)
|
|
@@ -2402,6 +2445,7 @@ static void ath12k_peer_assoc_h_he(struc
|
|
u16 he_tx_mcs = 0, v = 0;
|
|
int he_nss, nss_idx;
|
|
bool user_rate_valid = true;
|
|
+ u32 rx_nss, tx_nss, nss_160;
|
|
|
|
if (WARN_ON(ath12k_mac_vif_link_chan(vif, link_id, &def)))
|
|
return;
|
|
@@ -2599,9 +2643,25 @@ static void ath12k_peer_assoc_h_he(struc
|
|
max_nss = min(max_nss, ar->num_tx_chains);
|
|
arg->peer_nss = min(link_sta->rx_nss, max_nss);
|
|
|
|
+ if (arg->peer_phymode == MODE_11AX_HE160) {
|
|
+ tx_nss = ath12k_get_nss_160mhz(ar, max_nss);
|
|
+ rx_nss = min(arg->peer_nss, tx_nss);
|
|
+ arg->peer_bw_rxnss_override = ATH12K_BW_NSS_MAP_ENABLE;
|
|
+
|
|
+ if (!rx_nss) {
|
|
+ ath12k_warn(ar->ab, "invalid max_nss\n");
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ nss_160 = u32_encode_bits(rx_nss - 1, ATH12K_PEER_RX_NSS_160MHZ);
|
|
+ arg->peer_bw_rxnss_override |= nss_160;
|
|
+ }
|
|
+
|
|
ath12k_dbg(ar->ab, ATH12K_DBG_MAC,
|
|
- "mac he peer %pM nss %d mcs cnt %d\n",
|
|
- arsta->addr, arg->peer_nss, arg->peer_he_mcs_count);
|
|
+ "mac he peer %pM nss %d mcs cnt %d nss_override 0x%x\n",
|
|
+ arsta->addr, arg->peer_nss,
|
|
+ arg->peer_he_mcs_count,
|
|
+ arg->peer_bw_rxnss_override);
|
|
}
|
|
|
|
static void ath12k_peer_assoc_h_he_6ghz(struct ath12k *ar,
|
|
@@ -2842,10 +2902,13 @@ static enum wmi_phy_mode ath12k_mac_get_
|
|
struct ieee80211_link_sta *link_sta)
|
|
{
|
|
if (link_sta->bandwidth == IEEE80211_STA_RX_BW_160) {
|
|
- if (link_sta->vht_cap.cap & IEEE80211_VHT_CAP_SUPP_CHAN_WIDTH_160MHZ)
|
|
+ if (link_sta->vht_cap.cap & (IEEE80211_VHT_CAP_SUPP_CHAN_WIDTH_160MHZ |
|
|
+ IEEE80211_VHT_CAP_EXT_NSS_BW_MASK))
|
|
return MODE_11AC_VHT160;
|
|
|
|
- /* not sure if this is a valid case? */
|
|
+ /* Allow STA to connect even if it does not explicitly advertise 160 MHz
|
|
+ * support
|
|
+ */
|
|
return MODE_11AC_VHT160;
|
|
}
|
|
|
|
@@ -7379,10 +7442,8 @@ ath12k_create_vht_cap(struct ath12k *ar,
|
|
|
|
ath12k_set_vht_txbf_cap(ar, &vht_cap.cap);
|
|
|
|
- /* TODO: Enable back VHT160 mode once association issues are fixed */
|
|
- /* Disabling VHT160 and VHT80+80 modes */
|
|
- vht_cap.cap &= ~IEEE80211_VHT_CAP_SUPP_CHAN_WIDTH_MASK;
|
|
- vht_cap.cap &= ~IEEE80211_VHT_CAP_SHORT_GI_160;
|
|
+ /* 80P80 is not supported */
|
|
+ vht_cap.cap &= ~IEEE80211_VHT_CAP_SUPP_CHAN_WIDTH_160_80PLUS80MHZ;
|
|
|
|
rxmcs_map = 0;
|
|
txmcs_map = 0;
|
|
@@ -12654,7 +12715,8 @@ ath12k_mac_setup_radio_iface_comb(struct
|
|
comb[0].radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
|
|
BIT(NL80211_CHAN_WIDTH_20) |
|
|
BIT(NL80211_CHAN_WIDTH_40) |
|
|
- BIT(NL80211_CHAN_WIDTH_80);
|
|
+ BIT(NL80211_CHAN_WIDTH_80) |
|
|
+ BIT(NL80211_CHAN_WIDTH_160);
|
|
}
|
|
|
|
return 0;
|
|
@@ -13031,6 +13093,9 @@ static int ath12k_mac_hw_register(struct
|
|
ieee80211_hw_set(hw, REPORTS_LOW_ACK);
|
|
ieee80211_hw_set(hw, NO_VIRTUAL_MONITOR);
|
|
|
|
+ if (cap->nss_ratio_enabled)
|
|
+ ieee80211_hw_set(hw, SUPPORTS_VHT_EXT_NSS_BW);
|
|
+
|
|
if ((ht_cap & WMI_HT_CAP_ENABLED) || is_6ghz) {
|
|
ieee80211_hw_set(hw, AMPDU_AGGREGATION);
|
|
ieee80211_hw_set(hw, TX_AMPDU_SETUP_IN_HW);
|
|
--- a/drivers/net/wireless/ath/ath12k/mac.h
|
|
+++ b/drivers/net/wireless/ath/ath12k/mac.h
|
|
@@ -41,6 +41,8 @@ struct ath12k_generic_iter {
|
|
#define IEEE80211_DISABLE_VHT_MCS_SUPPORT_0_11 BIT(24)
|
|
|
|
#define ATH12K_CHAN_WIDTH_NUM 14
|
|
+#define ATH12K_BW_NSS_MAP_ENABLE BIT(31)
|
|
+#define ATH12K_PEER_RX_NSS_160MHZ GENMASK(2, 0)
|
|
|
|
#define ATH12K_TX_POWER_MAX_VAL 70
|
|
#define ATH12K_TX_POWER_MIN_VAL 0
|
|
--- a/drivers/net/wireless/ath/ath12k/wmi.c
|
|
+++ b/drivers/net/wireless/ath/ath12k/wmi.c
|
|
@@ -537,6 +537,10 @@ ath12k_pull_mac_phy_cap_svc_ready_ext(st
|
|
pdev_cap->he_mcs = le32_to_cpu(mac_caps->he_supp_mcs_5g);
|
|
pdev_cap->tx_chain_mask = le32_to_cpu(mac_caps->tx_chain_mask_5g);
|
|
pdev_cap->rx_chain_mask = le32_to_cpu(mac_caps->rx_chain_mask_5g);
|
|
+ pdev_cap->nss_ratio_enabled =
|
|
+ WMI_NSS_RATIO_EN_DIS_GET(mac_caps->nss_ratio);
|
|
+ pdev_cap->nss_ratio_info =
|
|
+ WMI_NSS_RATIO_INFO_GET(mac_caps->nss_ratio);
|
|
} else {
|
|
return -EINVAL;
|
|
}
|
|
@@ -1059,7 +1063,8 @@ static void ath12k_wmi_put_wmi_channel(s
|
|
|
|
chan->band_center_freq2 = cpu_to_le32(center_freq1);
|
|
|
|
- } else if (arg->mode == MODE_11BE_EHT160) {
|
|
+ } else if (arg->mode == MODE_11BE_EHT160 ||
|
|
+ arg->mode == MODE_11AX_HE160) {
|
|
if (arg->freq > center_freq1)
|
|
chan->band_center_freq1 = cpu_to_le32(center_freq1 + 40);
|
|
else
|
|
--- a/drivers/net/wireless/ath/ath12k/wmi.h
|
|
+++ b/drivers/net/wireless/ath/ath12k/wmi.h
|
|
@@ -2328,6 +2328,21 @@ enum wmi_direct_buffer_module {
|
|
WMI_DIRECT_BUF_MAX
|
|
};
|
|
|
|
+/**
|
|
+ * enum wmi_nss_ratio - NSS ratio received from FW during service ready ext event
|
|
+ * @WMI_NSS_RATIO_1BY2_NSS: Max nss of 160MHz is equals to half of the max nss of 80MHz
|
|
+ * @WMI_NSS_RATIO_3BY4_NSS: Max nss of 160MHz is equals to 3/4 of the max nss of 80MHz
|
|
+ * @WMI_NSS_RATIO_1_NSS: Max nss of 160MHz is equals to the max nss of 80MHz
|
|
+ * @WMI_NSS_RATIO_2_NSS: Max nss of 160MHz is equals to two times the max nss of 80MHz
|
|
+ */
|
|
+
|
|
+enum wmi_nss_ratio {
|
|
+ WMI_NSS_RATIO_1BY2_NSS,
|
|
+ WMI_NSS_RATIO_3BY4_NSS,
|
|
+ WMI_NSS_RATIO_1_NSS,
|
|
+ WMI_NSS_RATIO_2_NSS
|
|
+};
|
|
+
|
|
struct ath12k_wmi_pdev_band_arg {
|
|
u32 pdev_id;
|
|
u32 start_freq;
|
|
@@ -2647,6 +2662,12 @@ struct ath12k_wmi_hw_mode_cap_params {
|
|
} __packed;
|
|
|
|
#define WMI_MAX_HECAP_PHY_SIZE (3)
|
|
+#define WMI_NSS_RATIO_EN_DIS_BITPOS BIT(0)
|
|
+#define WMI_NSS_RATIO_EN_DIS_GET(_val) \
|
|
+ le32_get_bits(_val, WMI_NSS_RATIO_EN_DIS_BITPOS)
|
|
+#define WMI_NSS_RATIO_INFO_BITPOS GENMASK(4, 1)
|
|
+#define WMI_NSS_RATIO_INFO_GET(_val) \
|
|
+ le32_get_bits(_val, WMI_NSS_RATIO_INFO_BITPOS)
|
|
|
|
/* pdev_id is present in lower 16 bits of pdev_and_hw_link_ids in
|
|
* ath12k_wmi_mac_phy_caps_params & ath12k_wmi_caps_ext_params.
|