/*
|
* Header file for QOS Algorithm on DHD
|
*
|
* Provides type definitions and function prototypes for the QOS Algorithm
|
* Note that this algorithm is a platform independent layer
|
*
|
* Copyright (C) 2020, Broadcom.
|
*
|
* Unless you and Broadcom execute a separate written software license
|
* agreement governing use of this software, this software is licensed to you
|
* under the terms of the GNU General Public License version 2 (the "GPL"),
|
* available at http://www.broadcom.com/licenses/GPLv2.php, with the
|
* following added to such license:
|
*
|
* As a special exception, the copyright holders of this software give you
|
* permission to link this software with independent modules, and to copy and
|
* distribute the resulting executable under terms of your choice, provided that
|
* you also meet, for each linked independent module, the terms and conditions of
|
* the license of that module. An independent module is a module which is not
|
* derived from this software. The special exception does not apply to any
|
* modifications of the software.
|
*
|
*
|
* <<Broadcom-WL-IPTag/Open:>>
|
*
|
* $Id$
|
*/
|
|
#ifndef _DHD_QOS_ALGO_H_
|
#define _DHD_QOS_ALGO_H_
|
|
#define LOWLAT_AVG_PKT_SIZE_LOW 50u
|
#define LOWLAT_AVG_PKT_SIZE_HIGH 200u
|
#define LOWLAT_NUM_PKTS_LOW 1u
|
#define LOWLAT_NUM_PKTS_HIGH 8u
|
#define LOWLAT_DETECT_CNT_INC_THRESH 10u
|
#define LOWLAT_DETECT_CNT_DEC_THRESH 0u
|
#define LOWLAT_DETECT_CNT_UPGRADE_THRESH 4u
|
|
typedef struct qos_stat
|
{
|
/* Statistics */
|
unsigned long tx_pkts_prev;
|
unsigned long tx_bytes_prev;
|
unsigned long tx_pkts;
|
unsigned long tx_bytes;
|
|
/* low latency flow detection algorithm counts */
|
unsigned char lowlat_detect_count;
|
bool lowlat_flow;
|
} qos_stat_t;
|
|
/* QoS alogrithm parameter, controllable at runtime */
|
typedef struct _qos_algo_params
|
{
|
/* The avg Tx packet size in the sampling interval must be between
|
* these two thresholds for QoS upgrade to take place.
|
* default values = LOWLAT_AVG_PKT_SIZE_LOW, LOWLAT_AVG_PKT_SIZE_HIGH
|
*/
|
unsigned long avg_pkt_size_low_thresh;
|
unsigned long avg_pkt_size_high_thresh;
|
/* The number of Tx packets in the sampling interval must be
|
* between these two thresholds for QoS upgrade to happen.
|
* default values = LOWLAT_NUM_PKTS_LOW, LOWLAT_NUM_PKTS_HIGH
|
*/
|
unsigned long num_pkts_low_thresh;
|
unsigned long num_pkts_high_thresh;
|
/* If low latency traffic is detected, then the low latency count
|
* is incremented till the first threshold is hit.
|
* If traffic ceases to be low latency, then the count is
|
* decremented till the second threshold is hit.
|
* default values = LOWLAT_DETECT_CNT_INC_THRESH, LOWLAT_DETECT_CNT_DEC_THRESH
|
*/
|
unsigned char detect_cnt_inc_thresh;
|
unsigned char detect_cnt_dec_thresh;
|
/* If the low latency count crosses this threshold, the flow will be upgraded.
|
* Default value = LOWLAT_DETECT_CNT_UPGRADE_THRESH
|
*/
|
unsigned char detect_cnt_upgrade_thresh;
|
} qos_algo_params_t;
|
|
#define QOS_PARAMS(x) (&x->psk_qos->qos_params);
|
|
/*
|
* Operates on a flow and returns 1 for upgrade and 0 for
|
* no up-grade
|
*/
|
int dhd_qos_algo(dhd_info_t *dhd, qos_stat_t *qos, qos_algo_params_t *qos_params);
|
int qos_algo_params_init(qos_algo_params_t *qos_params);
|
#endif /* _DHD_QOS_ALGO_H_ */
|