root/drivers/net/wireless/ath/ath12k/debugfs.h
/* SPDX-License-Identifier: BSD-3-Clause-Clear */
/*
 * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved.
 * Copyright (c) 2021-2025 Qualcomm Innovation Center, Inc. All rights reserved.
 */

#ifndef _ATH12K_DEBUGFS_H_
#define _ATH12K_DEBUGFS_H_

#ifdef CONFIG_ATH12K_DEBUGFS
void ath12k_debugfs_soc_create(struct ath12k_base *ab);
void ath12k_debugfs_soc_destroy(struct ath12k_base *ab);
void ath12k_debugfs_register(struct ath12k *ar);
void ath12k_debugfs_unregister(struct ath12k *ar);
void ath12k_debugfs_op_vif_add(struct ieee80211_hw *hw,
                               struct ieee80211_vif *vif);
void ath12k_debugfs_pdev_create(struct ath12k_base *ab);

static inline bool ath12k_debugfs_is_extd_rx_stats_enabled(struct ath12k *ar)
{
        return ar->debug.extd_rx_stats;
}

static inline int ath12k_debugfs_rx_filter(struct ath12k *ar)
{
        return ar->debug.rx_filter;
}

#define ATH12K_CCK_RATES                        4
#define ATH12K_OFDM_RATES                       8
#define ATH12K_HT_RATES                         8
#define ATH12K_VHT_RATES                        12
#define ATH12K_HE_RATES                         12
#define ATH12K_HE_RATES_WITH_EXTRA_MCS          14
#define ATH12K_EHT_RATES                        16
#define HE_EXTRA_MCS_SUPPORT                    GENMASK(31, 16)
#define ATH12K_NSS_1                            1
#define ATH12K_NSS_4                            4
#define ATH12K_NSS_8                            8
#define ATH12K_HW_NSS(_rcode)                   (((_rcode) >> 5) & 0x7)
#define TPC_STATS_WAIT_TIME                     (1 * HZ)
#define MAX_TPC_PREAM_STR_LEN                   7
#define TPC_INVAL                               -128
#define TPC_MAX                                 127
#define TPC_STATS_WAIT_TIME                     (1 * HZ)
#define TPC_STATS_TOT_ROW                       700
#define TPC_STATS_TOT_COLUMN                    100
#define MODULATION_LIMIT                        126

#define ATH12K_TPC_STATS_BUF_SIZE       (TPC_STATS_TOT_ROW * TPC_STATS_TOT_COLUMN)

enum wmi_tpc_pream_bw {
        WMI_TPC_PREAM_CCK,
        WMI_TPC_PREAM_OFDM,
        WMI_TPC_PREAM_HT20,
        WMI_TPC_PREAM_HT40,
        WMI_TPC_PREAM_VHT20,
        WMI_TPC_PREAM_VHT40,
        WMI_TPC_PREAM_VHT80,
        WMI_TPC_PREAM_VHT160,
        WMI_TPC_PREAM_HE20,
        WMI_TPC_PREAM_HE40,
        WMI_TPC_PREAM_HE80,
        WMI_TPC_PREAM_HE160,
        WMI_TPC_PREAM_EHT20,
        WMI_TPC_PREAM_EHT40,
        WMI_TPC_PREAM_EHT60,
        WMI_TPC_PREAM_EHT80,
        WMI_TPC_PREAM_EHT120,
        WMI_TPC_PREAM_EHT140,
        WMI_TPC_PREAM_EHT160,
        WMI_TPC_PREAM_EHT200,
        WMI_TPC_PREAM_EHT240,
        WMI_TPC_PREAM_EHT280,
        WMI_TPC_PREAM_EHT320,
        WMI_TPC_PREAM_MAX
};

enum ath12k_debug_tpc_stats_ctl_mode {
        ATH12K_TPC_STATS_CTL_MODE_LEGACY_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HT_VHT20_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HE_EHT20_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HT_VHT40_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HE_EHT40_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_VHT80_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HE_EHT80_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_VHT160_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HE_EHT160_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HE_EHT320_5GHZ_6GHZ,
        ATH12K_TPC_STATS_CTL_MODE_CCK_2GHZ,
        ATH12K_TPC_STATS_CTL_MODE_LEGACY_2GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HT20_2GHZ,
        ATH12K_TPC_STATS_CTL_MODE_HT40_2GHZ,

        ATH12K_TPC_STATS_CTL_MODE_EHT80_SU_PUNC20 = 23,
        ATH12K_TPC_STATS_CTL_MODE_EHT160_SU_PUNC20,
        ATH12K_TPC_STATS_CTL_MODE_EHT320_SU_PUNC40,
        ATH12K_TPC_STATS_CTL_MODE_EHT320_SU_PUNC80,
        ATH12K_TPC_STATS_CTL_MODE_EHT320_SU_PUNC120
};

enum ath12k_debug_tpc_stats_support_modes {
        ATH12K_TPC_STATS_SUPPORT_160 = 0,
        ATH12K_TPC_STATS_SUPPORT_320,
        ATH12K_TPC_STATS_SUPPORT_AX,
        ATH12K_TPC_STATS_SUPPORT_AX_EXTRA_MCS,
        ATH12K_TPC_STATS_SUPPORT_BE,
        ATH12K_TPC_STATS_SUPPORT_BE_PUNC,
};
#else
static inline void ath12k_debugfs_soc_create(struct ath12k_base *ab)
{
}

static inline void ath12k_debugfs_soc_destroy(struct ath12k_base *ab)
{
}

static inline void ath12k_debugfs_register(struct ath12k *ar)
{
}

static inline void ath12k_debugfs_unregister(struct ath12k *ar)
{
}

static inline bool ath12k_debugfs_is_extd_rx_stats_enabled(struct ath12k *ar)
{
        return false;
}

static inline int ath12k_debugfs_rx_filter(struct ath12k *ar)
{
        return 0;
}

static inline void ath12k_debugfs_op_vif_add(struct ieee80211_hw *hw,
                                             struct ieee80211_vif *vif)
{
}

static inline void ath12k_debugfs_pdev_create(struct ath12k_base *ab)
{
}
#endif /* CONFIG_ATH12K_DEBUGFS */

#endif /* _ATH12K_DEBUGFS_H_ */