wifi: ath12k: Support BE OFDMA Pdev Rate Stats
authorPradeep Kumar Chitrapu <quic_pradeepc@quicinc.com>
Mon, 14 Oct 2024 07:06:10 +0000 (12:36 +0530)
committerJeff Johnson <quic_jjohnson@quicinc.com>
Wed, 16 Oct 2024 14:43:08 +0000 (07:43 -0700)
Add support to request BE OFDMA pdev rate stats from firmware
through HTT stats type 51. These stats give information such
as number of spatial streams, bandwidth, MCS, etc.

Note: WCN7850 firmware version -
WLAN.HMT.1.0-03427-QCAHMTSWPL_V1.0_V2.0_SILICONZ-1.15378.4
does not support HTT stats type 51.

Sample output:
-------------
echo 51 > /sys/kernel/debug/ath12k/pci-0000\:06\:00.0/mac0/htt_stats_type
cat /sys/kernel/debug/ath12k/pci-0000\:06\:00.0/mac0/htt_stats
HTT_TX_PDEV_RATE_STATS_BE_OFDMA_TLV:
mac_id = 0
be_ofdma_tx_ldpc = 0
be_ofdma_tx_mcs =  0:0, 1:0, 2:0, 3:0, 4:0, 5:0, 6:0, 7:0, 8:0, 9:0, 10:0, 11:0, 12:0, 13:0, 14:0, 15:0
be_ofdma_eht_sig_mcs =  0:0, 1:0, 2:0, 3:0
be_ofdma_tx_ru_size =  26:0  52:0  52+26:0  106:0  106+26:0  242:0  484:0  484+242:0  996:0  996+484:0  996+484+242:0  996x2:0  996x2+484:0  996x3:0  996x3+484:0  996x4:0
be_ofdma_tx_nss =  =  1:0, 2:0, 3:0, 4:0, 5:0, 6:0, 7:0, 8:0
be_ofdma_tx_bw =  0:0, 1:0, 2:0, 3:0, 4:0
be_ofdma_tx_gi[0] =  0:0, 1:0, 2:0, 3:0, 4:0, 5:0, 6:0, 7:0, 8:0, 9:0, 10:0, 11:0, 12:0, 13:0, 14:0, 15:0
be_ofdma_tx_gi[1] =  0:0, 1:0, 2:0, 3:0, 4:0, 5:0, 6:0, 7:0, 8:0, 9:0, 10:0, 11:0, 12:0, 13:0, 14:0, 15:0
be_ofdma_tx_gi[2] =  0:0, 1:0, 2:0, 3:0, 4:0, 5:0, 6:0, 7:0, 8:0, 9:0, 10:0, 11:0, 12:0, 13:0, 14:0, 15:0
be_ofdma_tx_gi[3] =  0:0, 1:0, 2:0, 3:0, 4:0, 5:0, 6:0, 7:0, 8:0, 9:0, 10:0, 11:0, 12:0, 13:0, 14:0, 15:0

Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.1.1-00214-QCAHKSWPL_SILICONZ-1

Signed-off-by: Pradeep Kumar Chitrapu <quic_pradeepc@quicinc.com>
Signed-off-by: Roopni Devanathan <quic_rdevanat@quicinc.com>
Link: https://patch.msgid.link/20241014070610.3982173-3-quic_rdevanat@quicinc.com
Signed-off-by: Jeff Johnson <quic_jjohnson@quicinc.com>
drivers/net/wireless/ath/ath12k/debugfs_htt_stats.c
drivers/net/wireless/ath/ath12k/debugfs_htt_stats.h

index 6d4870ab93d724f27d39eb4a76a7028ee1595458..799b865b89e54df77b7afcf05b10660b24bdc0e2 100644 (file)
@@ -48,6 +48,46 @@ print_array_to_buf(u8 *buf, u32 offset, const char *header,
                                        footer);
 }
 
+static const char *ath12k_htt_be_tx_rx_ru_size_to_str(u8 ru_size)
+{
+       switch (ru_size) {
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_26:
+               return "26";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_52:
+               return "52";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_52_26:
+               return "52+26";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_106:
+               return "106";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_106_26:
+               return "106+26";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_242:
+               return "242";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_484:
+               return "484";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_484_242:
+               return "484+242";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996:
+               return "996";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996_484:
+               return "996+484";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996_484_242:
+               return "996+484+242";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x2:
+               return "996x2";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x2_484:
+               return "996x2+484";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x3:
+               return "996x3";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x3_484:
+               return "996x3+484";
+       case ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x4:
+               return "996x4";
+       default:
+               return "unknown";
+       }
+}
+
 static void
 htt_print_tx_pdev_stats_cmn_tlv(const void *tag_buf, u16 tag_len,
                                struct debug_htt_stats_req *stats_req)
@@ -2612,6 +2652,58 @@ ath12k_htt_print_pdev_sched_algo_ofdma_stats_tlv(const void *tag_buf, u16 tag_le
        stats_req->buf_len = len;
 }
 
+static void
+ath12k_htt_print_tx_pdev_rate_stats_be_ofdma_tlv(const void *tag_buf, u16 tag_len,
+                                                struct debug_htt_stats_req *stats_req)
+{
+       const struct ath12k_htt_tx_pdev_rate_stats_be_ofdma_tlv *htt_stats_buf = tag_buf;
+       u8 *buf = stats_req->buf;
+       u32 len = stats_req->buf_len;
+       u32 buf_len = ATH12K_HTT_STATS_BUF_SIZE;
+       u32 mac_id_word;
+       u8 i;
+
+       if (tag_len < sizeof(*htt_stats_buf))
+               return;
+
+       mac_id_word = le32_to_cpu(htt_stats_buf->mac_id__word);
+
+       len += scnprintf(buf + len, buf_len - len,
+                        "HTT_TX_PDEV_RATE_STATS_BE_OFDMA_TLV:\n");
+       len += scnprintf(buf + len, buf_len - len, "mac_id = %u\n",
+                        u32_get_bits(mac_id_word, ATH12K_HTT_STATS_MAC_ID));
+       len += scnprintf(buf + len, buf_len - len, "be_ofdma_tx_ldpc = %u\n",
+                        le32_to_cpu(htt_stats_buf->be_ofdma_tx_ldpc));
+       len += print_array_to_buf(buf, len, "be_ofdma_tx_mcs",
+                                 htt_stats_buf->be_ofdma_tx_mcs,
+                                 ATH12K_HTT_TX_PDEV_NUM_BE_MCS_CNTRS, "\n");
+       len += print_array_to_buf(buf, len, "be_ofdma_eht_sig_mcs",
+                                 htt_stats_buf->be_ofdma_eht_sig_mcs,
+                                 ATH12K_HTT_TX_PDEV_NUM_EHT_SIG_MCS_CNTRS, "\n");
+       len += scnprintf(buf + len, buf_len - len, "be_ofdma_tx_ru_size = ");
+       for (i = 0; i < ATH12K_HTT_TX_RX_PDEV_NUM_BE_RU_SIZE_CNTRS; i++)
+               len += scnprintf(buf + len, buf_len - len, " %s:%u ",
+                                ath12k_htt_be_tx_rx_ru_size_to_str(i),
+                                le32_to_cpu(htt_stats_buf->be_ofdma_tx_ru_size[i]));
+       len += scnprintf(buf + len, buf_len - len, "\n");
+       len += print_array_to_buf_index(buf, len, "be_ofdma_tx_nss = ", 1,
+                                       htt_stats_buf->be_ofdma_tx_nss,
+                                       ATH12K_HTT_TX_PDEV_STATS_NUM_SPATIAL_STREAMS,
+                                       "\n");
+       len += print_array_to_buf(buf, len, "be_ofdma_tx_bw",
+                                 htt_stats_buf->be_ofdma_tx_bw,
+                                 ATH12K_HTT_TX_PDEV_NUM_BE_BW_CNTRS, "\n");
+       for (i = 0; i < ATH12K_HTT_TX_PDEV_NUM_GI_CNTRS; i++) {
+               len += scnprintf(buf + len, buf_len - len,
+                                "be_ofdma_tx_gi[%u]", i);
+               len += print_array_to_buf(buf, len, "", htt_stats_buf->gi[i],
+                                         ATH12K_HTT_TX_PDEV_NUM_BE_MCS_CNTRS, "\n");
+       }
+       len += scnprintf(buf + len, buf_len - len, "\n");
+
+       stats_req->buf_len = len;
+}
+
 static int ath12k_dbg_htt_ext_stats_parse(struct ath12k_base *ab,
                                          u16 tag, u16 len, const void *tag_buf,
                                          void *user_data)
@@ -2791,6 +2883,9 @@ static int ath12k_dbg_htt_ext_stats_parse(struct ath12k_base *ab,
        case HTT_STATS_PDEV_SCHED_ALGO_OFDMA_STATS_TAG:
                ath12k_htt_print_pdev_sched_algo_ofdma_stats_tlv(tag_buf, len, stats_req);
                break;
+       case HTT_STATS_TX_PDEV_RATE_STATS_BE_OFDMA_TAG:
+               ath12k_htt_print_tx_pdev_rate_stats_be_ofdma_tlv(tag_buf, len, stats_req);
+               break;
        default:
                break;
        }
index ae738396b10ad24d579612c04a0a6c8018c7599f..ac86cab234ecb70e149507cd81aa599abd0f0e05 100644 (file)
@@ -137,6 +137,7 @@ enum ath12k_dbg_htt_ext_stats_type {
        ATH12K_DBG_HTT_EXT_STATS_PDEV_OBSS_PD_STATS     = 23,
        ATH12K_DBG_HTT_EXT_STATS_SOC_ERROR              = 45,
        ATH12K_DBG_HTT_EXT_STATS_PDEV_SCHED_ALGO        = 49,
+       ATH12K_DBG_HTT_EXT_STATS_MANDATORY_MUOFDMA      = 51,
 
        /* keep this last */
        ATH12K_DBG_HTT_NUM_EXT_STATS,
@@ -195,6 +196,7 @@ enum ath12k_dbg_htt_tlv_tag {
        HTT_STATS_TX_SELFGEN_AX_SCHED_STATUS_STATS_TAG  = 112,
        HTT_STATS_MU_PPDU_DIST_TAG                      = 129,
        HTT_STATS_TX_PDEV_MUMIMO_GRP_STATS_TAG          = 130,
+       HTT_STATS_TX_PDEV_RATE_STATS_BE_OFDMA_TAG       = 135,
        HTT_STATS_TX_SELFGEN_BE_ERR_STATS_TAG           = 137,
        HTT_STATS_TX_SELFGEN_BE_STATS_TAG               = 138,
        HTT_STATS_TX_SELFGEN_BE_SCHED_STATUS_STATS_TAG  = 139,
@@ -1083,4 +1085,41 @@ struct ath12k_htt_pdev_sched_algo_ofdma_stats_tlv {
        __le32 dlofdma_disabled_consec_no_mpdus_success[ATH12K_HTT_NUM_AC_WMM];
 } __packed;
 
+enum ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE {
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_26,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_52,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_52_26,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_106,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_106_26,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_242,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_484,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_484_242,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996_484,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996_484_242,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x2,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x2_484,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x3,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x3_484,
+       ATH12K_HTT_TX_RX_PDEV_STATS_BE_RU_SIZE_996x4,
+       ATH12K_HTT_TX_RX_PDEV_NUM_BE_RU_SIZE_CNTRS,
+};
+
+#define ATH12K_HTT_TX_PDEV_STATS_NUM_SPATIAL_STREAMS   8
+#define ATH12K_HTT_TX_PDEV_NUM_BE_MCS_CNTRS            16
+#define ATH12K_HTT_TX_PDEV_NUM_BE_BW_CNTRS             5
+#define ATH12K_HTT_TX_PDEV_NUM_EHT_SIG_MCS_CNTRS       4
+#define ATH12K_HTT_TX_PDEV_NUM_GI_CNTRS                        4
+
+struct ath12k_htt_tx_pdev_rate_stats_be_ofdma_tlv {
+       __le32 mac_id__word;
+       __le32 be_ofdma_tx_ldpc;
+       __le32 be_ofdma_tx_mcs[ATH12K_HTT_TX_PDEV_NUM_BE_MCS_CNTRS];
+       __le32 be_ofdma_tx_nss[ATH12K_HTT_TX_PDEV_STATS_NUM_SPATIAL_STREAMS];
+       __le32 be_ofdma_tx_bw[ATH12K_HTT_TX_PDEV_NUM_BE_BW_CNTRS];
+       __le32 gi[ATH12K_HTT_TX_PDEV_NUM_GI_CNTRS][ATH12K_HTT_TX_PDEV_NUM_BE_MCS_CNTRS];
+       __le32 be_ofdma_tx_ru_size[ATH12K_HTT_TX_RX_PDEV_NUM_BE_RU_SIZE_CNTRS];
+       __le32 be_ofdma_eht_sig_mcs[ATH12K_HTT_TX_PDEV_NUM_EHT_SIG_MCS_CNTRS];
+} __packed;
+
 #endif