cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

rc80211_minstrel_ht.h (5191B)


      1/* SPDX-License-Identifier: GPL-2.0-only */
      2/*
      3 * Copyright (C) 2010 Felix Fietkau <nbd@openwrt.org>
      4 */
      5
      6#ifndef __RC_MINSTREL_HT_H
      7#define __RC_MINSTREL_HT_H
      8
      9#include <linux/bitfield.h>
     10
     11/* number of highest throughput rates to consider*/
     12#define MAX_THR_RATES 4
     13#define SAMPLE_COLUMNS	10	/* number of columns in sample table */
     14
     15/* scaled fraction values */
     16#define MINSTREL_SCALE  12
     17#define MINSTREL_FRAC(val, div) (((val) << MINSTREL_SCALE) / div)
     18#define MINSTREL_TRUNC(val) ((val) >> MINSTREL_SCALE)
     19
     20#define EWMA_LEVEL	96	/* ewma weighting factor [/EWMA_DIV] */
     21#define EWMA_DIV	128
     22
     23/*
     24 * Coefficients for moving average with noise filter (period=16),
     25 * scaled by 10 bits
     26 *
     27 * a1 = exp(-pi * sqrt(2) / period)
     28 * coeff2 = 2 * a1 * cos(sqrt(2) * 2 * pi / period)
     29 * coeff3 = -sqr(a1)
     30 * coeff1 = 1 - coeff2 - coeff3
     31 */
     32#define MINSTREL_AVG_COEFF1		(MINSTREL_FRAC(1, 1) - \
     33					 MINSTREL_AVG_COEFF2 - \
     34					 MINSTREL_AVG_COEFF3)
     35#define MINSTREL_AVG_COEFF2		0x00001499
     36#define MINSTREL_AVG_COEFF3		-0x0000092e
     37
     38/*
     39 * The number of streams can be changed to 2 to reduce code
     40 * size and memory footprint.
     41 */
     42#define MINSTREL_MAX_STREAMS		4
     43#define MINSTREL_HT_STREAM_GROUPS	4 /* BW(=2) * SGI(=2) */
     44#define MINSTREL_VHT_STREAM_GROUPS	6 /* BW(=3) * SGI(=2) */
     45
     46#define MINSTREL_HT_GROUPS_NB	(MINSTREL_MAX_STREAMS *		\
     47				 MINSTREL_HT_STREAM_GROUPS)
     48#define MINSTREL_VHT_GROUPS_NB	(MINSTREL_MAX_STREAMS *		\
     49				 MINSTREL_VHT_STREAM_GROUPS)
     50#define MINSTREL_LEGACY_GROUPS_NB	2
     51#define MINSTREL_GROUPS_NB	(MINSTREL_HT_GROUPS_NB +	\
     52				 MINSTREL_VHT_GROUPS_NB +	\
     53				 MINSTREL_LEGACY_GROUPS_NB)
     54
     55#define MINSTREL_HT_GROUP_0	0
     56#define MINSTREL_CCK_GROUP	(MINSTREL_HT_GROUP_0 + MINSTREL_HT_GROUPS_NB)
     57#define MINSTREL_OFDM_GROUP	(MINSTREL_CCK_GROUP + 1)
     58#define MINSTREL_VHT_GROUP_0	(MINSTREL_OFDM_GROUP + 1)
     59
     60#define MCS_GROUP_RATES		10
     61
     62#define MI_RATE_IDX_MASK	GENMASK(3, 0)
     63#define MI_RATE_GROUP_MASK	GENMASK(15, 4)
     64
     65#define MI_RATE(_group, _idx)				\
     66	(FIELD_PREP(MI_RATE_GROUP_MASK, _group) |	\
     67	 FIELD_PREP(MI_RATE_IDX_MASK, _idx))
     68
     69#define MI_RATE_IDX(_rate) FIELD_GET(MI_RATE_IDX_MASK, _rate)
     70#define MI_RATE_GROUP(_rate) FIELD_GET(MI_RATE_GROUP_MASK, _rate)
     71
     72#define MINSTREL_SAMPLE_RATES		5 /* rates per sample type */
     73#define MINSTREL_SAMPLE_INTERVAL	(HZ / 50)
     74
     75struct minstrel_priv {
     76	struct ieee80211_hw *hw;
     77	bool has_mrr;
     78	unsigned int cw_min;
     79	unsigned int cw_max;
     80	unsigned int max_retry;
     81	unsigned int segment_size;
     82	unsigned int update_interval;
     83
     84	u8 cck_rates[4];
     85	u8 ofdm_rates[NUM_NL80211_BANDS][8];
     86
     87#ifdef CONFIG_MAC80211_DEBUGFS
     88	/*
     89	 * enable fixed rate processing per RC
     90	 *   - write static index to debugfs:ieee80211/phyX/rc/fixed_rate_idx
     91	 *   - write -1 to enable RC processing again
     92	 *   - setting will be applied on next update
     93	 */
     94	u32 fixed_rate_idx;
     95#endif
     96};
     97
     98
     99struct mcs_group {
    100	u16 flags;
    101	u8 streams;
    102	u8 shift;
    103	u8 bw;
    104	u16 duration[MCS_GROUP_RATES];
    105};
    106
    107extern const s16 minstrel_cck_bitrates[4];
    108extern const s16 minstrel_ofdm_bitrates[8];
    109extern const struct mcs_group minstrel_mcs_groups[];
    110
    111struct minstrel_rate_stats {
    112	/* current / last sampling period attempts/success counters */
    113	u16 attempts, last_attempts;
    114	u16 success, last_success;
    115
    116	/* total attempts/success counters */
    117	u32 att_hist, succ_hist;
    118
    119	/* prob_avg - moving average of prob */
    120	u16 prob_avg;
    121	u16 prob_avg_1;
    122
    123	/* maximum retry counts */
    124	u8 retry_count;
    125	u8 retry_count_rtscts;
    126
    127	bool retry_updated;
    128};
    129
    130enum minstrel_sample_type {
    131	MINSTREL_SAMPLE_TYPE_INC,
    132	MINSTREL_SAMPLE_TYPE_JUMP,
    133	MINSTREL_SAMPLE_TYPE_SLOW,
    134	__MINSTREL_SAMPLE_TYPE_MAX
    135};
    136
    137struct minstrel_mcs_group_data {
    138	u8 index;
    139	u8 column;
    140
    141	/* sorted rate set within a MCS group*/
    142	u16 max_group_tp_rate[MAX_THR_RATES];
    143	u16 max_group_prob_rate;
    144
    145	/* MCS rate statistics */
    146	struct minstrel_rate_stats rates[MCS_GROUP_RATES];
    147};
    148
    149struct minstrel_sample_category {
    150	u8 sample_group;
    151	u16 sample_rates[MINSTREL_SAMPLE_RATES];
    152	u16 cur_sample_rates[MINSTREL_SAMPLE_RATES];
    153};
    154
    155struct minstrel_ht_sta {
    156	struct ieee80211_sta *sta;
    157
    158	/* ampdu length (average, per sampling interval) */
    159	unsigned int ampdu_len;
    160	unsigned int ampdu_packets;
    161
    162	/* ampdu length (EWMA) */
    163	unsigned int avg_ampdu_len;
    164
    165	/* overall sorted rate set */
    166	u16 max_tp_rate[MAX_THR_RATES];
    167	u16 max_prob_rate;
    168
    169	/* time of last status update */
    170	unsigned long last_stats_update;
    171
    172	/* overhead time in usec for each frame */
    173	unsigned int overhead;
    174	unsigned int overhead_rtscts;
    175	unsigned int overhead_legacy;
    176	unsigned int overhead_legacy_rtscts;
    177
    178	unsigned int total_packets;
    179	unsigned int sample_packets;
    180
    181	/* tx flags to add for frames for this sta */
    182	u32 tx_flags;
    183	bool use_short_preamble;
    184	u8 band;
    185
    186	u8 sample_seq;
    187	u16 sample_rate;
    188
    189	unsigned long sample_time;
    190	struct minstrel_sample_category sample[__MINSTREL_SAMPLE_TYPE_MAX];
    191
    192	/* Bitfield of supported MCS rates of all groups */
    193	u16 supported[MINSTREL_GROUPS_NB];
    194
    195	/* MCS rate group info and statistics */
    196	struct minstrel_mcs_group_data groups[MINSTREL_GROUPS_NB];
    197};
    198
    199void minstrel_ht_add_sta_debugfs(void *priv, void *priv_sta, struct dentry *dir);
    200int minstrel_ht_get_tp_avg(struct minstrel_ht_sta *mi, int group, int rate,
    201			   int prob_avg);
    202
    203#endif