blob: 43aff83f740ee017ab3c16f85013b52e14fa63d5 [file] [log] [blame]
/*
* Copyright (c) 2016-2019 The Linux Foundation. All rights reserved.
*
* Permission to use, copy, modify, and/or distribute this software for
* any purpose with or without fee is hereby granted, provided that the
* above copyright notice and this permission notice appear in all
* copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
* WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
* AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
* PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/
/**
* @file cdp_txrx_host_stats.h
* @brief Define the host data path stats API functions
* called by the host control SW and the OS interface module
*/
#ifndef _CDP_TXRX_HOST_STATS_H_
#define _CDP_TXRX_HOST_STATS_H_
#include "cdp_txrx_handle.h"
#include <wmi_unified_api.h>
/**
* cdp_host_stats_get: cdp call to get host stats
* @soc: SOC handle
* @vdev_id: vdev id of vdev
* @req: Requirement type
*
* return: 0 for Success, Failure returns error message
*/
static inline int cdp_host_stats_get(ol_txrx_soc_handle soc,
uint8_t vdev_id,
struct ol_txrx_stats_req *req)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_host_stats_get)
return 0;
return soc->ops->host_stats_ops->txrx_host_stats_get(soc, vdev_id, req);
}
/**
* cdp_host_stats_get_ratekbps: cdp call to get rate in kbps
* @soc: SOC handle
* @preamb: Preamble
* @mcs: Modulation and Coding scheme index
* @htflag: Flag to identify HT or VHT
* @gintval: Gaurd Interval value
*
* return: 0 for Failure, Returns rate on Success
*/
static inline int cdp_host_stats_get_ratekbps(ol_txrx_soc_handle soc,
int preamb, int mcs,
int htflag, int gintval)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_get_ratekbps)
return 0;
return soc->ops->host_stats_ops->txrx_get_ratekbps(preamb,
mcs, htflag,
gintval);
}
/**
* cdp_host_stats_clr: cdp call to clear host stats
* @soc: soc handle
* @vdev_id: vdev handle id
*
* return: QDF_STATUS
*/
static inline QDF_STATUS
cdp_host_stats_clr(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_host_stats_clr)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_host_stats_clr(soc, vdev_id);
}
static inline QDF_STATUS
cdp_host_ce_stats(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_host_ce_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_host_ce_stats(soc, vdev_id);
}
static inline int cdp_stats_publish
(ol_txrx_soc_handle soc, uint8_t pdev_id,
struct cdp_stats_extd *buf)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_stats_publish)
return 0;
return soc->ops->host_stats_ops->txrx_stats_publish(soc, pdev_id, buf);
}
/**
* @brief Enable enhanced stats functionality.
*
* @param soc - the soc object
* @param pdev_id - id of the physical device object
* @return - QDF_STATUS
*/
static inline QDF_STATUS
cdp_enable_enhanced_stats(ol_txrx_soc_handle soc, uint8_t pdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_enable_enhanced_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_enable_enhanced_stats
(soc, pdev_id);
}
/**
* @brief Disable enhanced stats functionality.
*
* @param soc - the soc object
* @param pdev_id - id of the physical device object
* @return - QDF_STATUS
*/
static inline QDF_STATUS
cdp_disable_enhanced_stats(ol_txrx_soc_handle soc, uint8_t pdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_disable_enhanced_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_disable_enhanced_stats
(soc, pdev_id);
}
static inline QDF_STATUS
cdp_tx_print_tso_stats(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->tx_print_tso_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->tx_print_tso_stats(soc, vdev_id);
}
static inline QDF_STATUS
cdp_tx_rst_tso_stats(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->tx_rst_tso_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->tx_rst_tso_stats(soc, vdev_id);
}
static inline QDF_STATUS
cdp_tx_print_sg_stats(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->tx_print_sg_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->tx_print_sg_stats(soc, vdev_id);
}
static inline QDF_STATUS
cdp_tx_rst_sg_stats(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->tx_rst_sg_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->tx_rst_sg_stats(soc, vdev_id);
}
static inline QDF_STATUS
cdp_print_rx_cksum_stats(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->print_rx_cksum_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->print_rx_cksum_stats(soc, vdev_id);
}
static inline QDF_STATUS
cdp_rst_rx_cksum_stats(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->rst_rx_cksum_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->rst_rx_cksum_stats(soc, vdev_id);
}
static inline QDF_STATUS
cdp_host_me_stats(ol_txrx_soc_handle soc, uint8_t vdev_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_host_me_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_host_me_stats(soc, vdev_id);
}
/**
* cdp_per_peer_stats(): function to print per peer REO Queue stats
* @soc: soc handle
* @pdev: physical device
* @addr: peer address
*
* return: status
*/
static inline QDF_STATUS cdp_per_peer_stats(ol_txrx_soc_handle soc,
uint8_t *addr)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_per_peer_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_per_peer_stats(soc, addr);
}
static inline int cdp_host_msdu_ttl_stats(ol_txrx_soc_handle soc,
uint8_t vdev_id,
struct ol_txrx_stats_req *req)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_host_msdu_ttl_stats)
return 0;
return soc->ops->host_stats_ops->txrx_host_msdu_ttl_stats
(soc, vdev_id, req);
}
static inline QDF_STATUS cdp_update_peer_stats(ol_txrx_soc_handle soc,
uint8_t vdev_id, uint8_t *mac,
void *stats,
uint32_t last_tx_rate_mcs,
uint32_t stats_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_update_peer_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_update_peer_stats
(soc, vdev_id, mac, stats, last_tx_rate_mcs, stats_id);
}
static inline QDF_STATUS cdp_get_dp_fw_peer_stats(ol_txrx_soc_handle soc,
uint8_t pdev_id,
uint8_t *mac, uint32_t caps,
uint32_t copy_stats)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->get_fw_peer_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->get_fw_peer_stats
(soc, pdev_id, mac, caps, copy_stats);
}
static inline QDF_STATUS cdp_get_dp_htt_stats(ol_txrx_soc_handle soc,
uint8_t pdev_id,
void *data, uint32_t data_len)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->get_htt_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->get_htt_stats(soc, pdev_id, data,
data_len);
}
/**
* @brief Update pdev host stats received from firmware
* (wmi_host_pdev_stats and wmi_host_pdev_ext_stats) into dp
*
* @param soc - soc handle
* @param pdev_id - id of the physical device object
* @param data - pdev stats
* @return - QDF_STATUS
*/
static inline QDF_STATUS
cdp_update_pdev_host_stats(ol_txrx_soc_handle soc,
uint8_t pdev_id,
void *data,
uint16_t stats_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_update_pdev_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_update_pdev_stats(soc, pdev_id,
data,
stats_id);
}
/**
* @brief Update vdev host stats
*
* @param soc - soc handle
* @param vdev_id - id of the virtual device object
* @param data - pdev stats
* @param stats_id - type of stats
*
* @return - QDF_STATUS
*/
static inline QDF_STATUS
cdp_update_vdev_host_stats(ol_txrx_soc_handle soc,
uint8_t vdev_id,
void *data,
uint16_t stats_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_update_vdev_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_update_vdev_stats(soc, vdev_id,
data,
stats_id);
}
/**
* @brief Call to get peer stats
*
* @param soc - soc handle
* @param vdev_id - vdev_id of vdev object
* @param peer_mac - mac address of the peer
* @return - struct cdp_peer_stats
*/
static inline QDF_STATUS
cdp_host_get_peer_stats(ol_txrx_soc_handle soc, uint8_t vdev_id,
uint8_t *peer_mac,
struct cdp_peer_stats *peer_stats)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_get_peer_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_get_peer_stats(soc, vdev_id,
peer_mac,
peer_stats);
}
/**
* @brief Call to reset ald stats
*
* @param soc - soc handle
* @param vdev_id - vdev_id of vdev object
* @param peer_mac - mac address of the peer
* @return - void
*/
static inline QDF_STATUS
cdp_host_reset_peer_ald_stats(ol_txrx_soc_handle soc, uint8_t vdev_id,
uint8_t *peer_mac)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_reset_peer_ald_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_reset_peer_ald_stats(soc,
vdev_id,
peer_mac);
}
/**
* @brief Call to reset peer stats
*
* @param soc - soc handle
* @param vdev_id - vdev_id of vdev object
* @param peer_mac - mac address of the peer
* @return - QDF_STATUS
*/
static inline QDF_STATUS
cdp_host_reset_peer_stats(ol_txrx_soc_handle soc,
uint8_t vdev_id, uint8_t *peer_mac)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_reset_peer_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->txrx_reset_peer_stats(soc,
vdev_id,
peer_mac);
}
/**
* @brief Call to get vdev stats
*
* @param soc - dp soc object
* @param vdev_id - id of dp vdev object
* @param buf - buffer
* @return - int
*/
static inline int
cdp_host_get_vdev_stats(ol_txrx_soc_handle soc,
uint8_t vdev_id,
struct cdp_vdev_stats *buf,
bool is_aggregate)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_get_vdev_stats)
return 0;
return soc->ops->host_stats_ops->txrx_get_vdev_stats(soc, vdev_id,
buf,
is_aggregate);
}
/**
* @brief Call to update vdev stats received from firmware
* (wmi_host_vdev_stats and wmi_host_vdev_extd_stats) into dp
*
* @param data - stats data to be updated
* @param size - size of stats data
* @param stats_id - stats id
* @return - int
*/
static inline int
cdp_update_host_vdev_stats(ol_txrx_soc_handle soc,
void *data,
uint32_t size,
uint32_t stats_id)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_process_wmi_host_vdev_stats)
return 0;
return soc->ops->host_stats_ops->txrx_process_wmi_host_vdev_stats
(soc,
data,
size,
stats_id);
}
/**
* @brief Call to get vdev extd stats
*
* @param soc - soc handle
* @param vdev_id - id of dp vdev object
* @param buf - buffer
* @return - int
*/
static inline int
cdp_get_vdev_extd_stats(ol_txrx_soc_handle soc,
uint8_t vdev_id,
wmi_host_vdev_extd_stats *buf)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_get_vdev_extd_stats)
return 0;
return soc->ops->host_stats_ops->txrx_get_vdev_extd_stats(soc, vdev_id,
buf);
}
/**
* @brief Call to get cdp_pdev_stats
*
* @param soc - soc handle
* @param pdev_id - id of dp pdev object
* @param buf - buffer to hold cdp_pdev_stats
* @return - success/failure
*/
static inline int
cdp_host_get_pdev_stats(ol_txrx_soc_handle soc,
uint8_t pdev_id, struct cdp_pdev_stats *buf)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_get_pdev_stats)
return 0;
return soc->ops->host_stats_ops->txrx_get_pdev_stats(soc, pdev_id, buf);
}
/**
* @brief Call to get radio stats
*
* @param soc - soc handle
* @param pdev_id - id of dp pdev object
* @param scn_stats_user - stats buffer
* @return - int
*/
static inline int
cdp_host_get_radio_stats(ol_txrx_soc_handle soc,
uint8_t pdev_id,
void *buf)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return 0;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->txrx_get_radio_stats)
return 0;
return soc->ops->host_stats_ops->txrx_get_radio_stats(soc, pdev_id,
buf);
}
/**
* @brief confgure rate stats at soc
*
* @param soc - opaque soc handle
* @param val - capabilities
* @return - QDF_STATUS
*/
static inline QDF_STATUS
cdp_soc_configure_rate_stats(ol_txrx_soc_handle soc, uint8_t val)
{
if (!soc || !soc->ops) {
QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
"%s: Invalid Instance", __func__);
QDF_BUG(0);
return QDF_STATUS_E_FAILURE;
}
if (!soc->ops->host_stats_ops ||
!soc->ops->host_stats_ops->configure_rate_stats)
return QDF_STATUS_E_FAILURE;
return soc->ops->host_stats_ops->configure_rate_stats(soc, val);
}
#endif /* _CDP_TXRX_HOST_STATS_H_ */