blob: 53ea3c29debfdff7986ec6263c3ef1faf37db47c [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Felix Fietkauec8aa662010-05-13 16:48:03 +02002/*
3 * Copyright (C) 2010 Felix Fietkau <nbd@openwrt.org>
Felix Fietkauec8aa662010-05-13 16:48:03 +02004 */
5
6#ifndef __RC_MINSTREL_HT_H
7#define __RC_MINSTREL_HT_H
8
9/*
10 * The number of streams can be changed to 2 to reduce code
11 * size and memory footprint.
12 */
Felix Fietkau7f2e12e2019-03-25 09:50:15 +010013#define MINSTREL_MAX_STREAMS 4
Karl Beldan8a0ee4f2014-10-20 15:46:00 +020014#define MINSTREL_HT_STREAM_GROUPS 4 /* BW(=2) * SGI(=2) */
Karl Beldan92082472014-10-21 10:38:38 +020015#define MINSTREL_VHT_STREAM_GROUPS 6 /* BW(=3) * SGI(=2) */
Karl Beldan8a0ee4f2014-10-20 15:46:00 +020016
17#define MINSTREL_HT_GROUPS_NB (MINSTREL_MAX_STREAMS * \
18 MINSTREL_HT_STREAM_GROUPS)
Karl Beldan92082472014-10-21 10:38:38 +020019#define MINSTREL_VHT_GROUPS_NB (MINSTREL_MAX_STREAMS * \
20 MINSTREL_VHT_STREAM_GROUPS)
Karl Beldan8a0ee4f2014-10-20 15:46:00 +020021#define MINSTREL_CCK_GROUPS_NB 1
22#define MINSTREL_GROUPS_NB (MINSTREL_HT_GROUPS_NB + \
Karl Beldan92082472014-10-21 10:38:38 +020023 MINSTREL_VHT_GROUPS_NB + \
Karl Beldan8a0ee4f2014-10-20 15:46:00 +020024 MINSTREL_CCK_GROUPS_NB)
25
26#define MINSTREL_HT_GROUP_0 0
27#define MINSTREL_CCK_GROUP (MINSTREL_HT_GROUP_0 + MINSTREL_HT_GROUPS_NB)
Karl Beldan92082472014-10-21 10:38:38 +020028#define MINSTREL_VHT_GROUP_0 (MINSTREL_CCK_GROUP + 1)
Felix Fietkauec8aa662010-05-13 16:48:03 +020029
Karl Beldan92082472014-10-21 10:38:38 +020030#define MCS_GROUP_RATES 10
Felix Fietkauec8aa662010-05-13 16:48:03 +020031
32struct mcs_group {
Felix Fietkau202df502018-10-06 19:35:02 +020033 u16 flags;
34 u8 streams;
35 u8 shift;
Felix Fietkau48cb3952019-08-20 11:54:49 +020036 u8 bw;
Felix Fietkau202df502018-10-06 19:35:02 +020037 u16 duration[MCS_GROUP_RATES];
Felix Fietkauec8aa662010-05-13 16:48:03 +020038};
39
John W. Linvillede66bfd2010-06-24 13:03:14 -040040extern const struct mcs_group minstrel_mcs_groups[];
41
Felix Fietkauec8aa662010-05-13 16:48:03 +020042struct minstrel_mcs_group_data {
43 u8 index;
44 u8 column;
45
Thomas Huehn59358392014-09-09 23:22:14 +020046 /* sorted rate set within a MCS group*/
Karl Beldand4d141c2014-10-20 15:45:59 +020047 u16 max_group_tp_rate[MAX_THR_RATES];
48 u16 max_group_prob_rate;
Felix Fietkauec8aa662010-05-13 16:48:03 +020049
50 /* MCS rate statistics */
51 struct minstrel_rate_stats rates[MCS_GROUP_RATES];
52};
53
Felix Fietkau48cb3952019-08-20 11:54:49 +020054enum minstrel_sample_mode {
55 MINSTREL_SAMPLE_IDLE,
56 MINSTREL_SAMPLE_ACTIVE,
57 MINSTREL_SAMPLE_PENDING,
58};
59
Felix Fietkauec8aa662010-05-13 16:48:03 +020060struct minstrel_ht_sta {
Felix Fietkaua8566662013-04-22 16:14:42 +020061 struct ieee80211_sta *sta;
62
Felix Fietkauec8aa662010-05-13 16:48:03 +020063 /* ampdu length (average, per sampling interval) */
64 unsigned int ampdu_len;
65 unsigned int ampdu_packets;
66
67 /* ampdu length (EWMA) */
68 unsigned int avg_ampdu_len;
69
Thomas Huehn59358392014-09-09 23:22:14 +020070 /* overall sorted rate set */
Karl Beldand4d141c2014-10-20 15:45:59 +020071 u16 max_tp_rate[MAX_THR_RATES];
72 u16 max_prob_rate;
Felix Fietkauec8aa662010-05-13 16:48:03 +020073
74 /* time of last status update */
Thomas Huehn91340732015-03-24 21:09:39 +010075 unsigned long last_stats_update;
Felix Fietkauec8aa662010-05-13 16:48:03 +020076
77 /* overhead time in usec for each frame */
78 unsigned int overhead;
79 unsigned int overhead_rtscts;
80
Felix Fietkau48cb3952019-08-20 11:54:49 +020081 unsigned int total_packets_last;
82 unsigned int total_packets_cur;
Felix Fietkauec8aa662010-05-13 16:48:03 +020083 unsigned int total_packets;
84 unsigned int sample_packets;
85
86 /* tx flags to add for frames for this sta */
87 u32 tx_flags;
88
89 u8 sample_wait;
90 u8 sample_tries;
91 u8 sample_count;
92 u8 sample_slow;
93
Felix Fietkau48cb3952019-08-20 11:54:49 +020094 enum minstrel_sample_mode sample_mode;
95 u16 sample_rate;
96
Felix Fietkauec8aa662010-05-13 16:48:03 +020097 /* current MCS group to be sampled */
98 u8 sample_group;
99
Felix Fietkaua0497f92013-02-13 10:51:08 +0100100 u8 cck_supported;
101 u8 cck_supported_short;
102
Felix Fietkau41d08582016-12-14 20:46:54 +0100103 /* Bitfield of supported MCS rates of all groups */
104 u16 supported[MINSTREL_GROUPS_NB];
105
Felix Fietkauec8aa662010-05-13 16:48:03 +0200106 /* MCS rate group info and statistics */
Karl Beldan8a0ee4f2014-10-20 15:46:00 +0200107 struct minstrel_mcs_group_data groups[MINSTREL_GROUPS_NB];
Felix Fietkauec8aa662010-05-13 16:48:03 +0200108};
109
110struct minstrel_ht_sta_priv {
111 union {
112 struct minstrel_ht_sta ht;
113 struct minstrel_sta_info legacy;
114 };
Felix Fietkauec8aa662010-05-13 16:48:03 +0200115 void *ratelist;
116 void *sample_table;
117 bool is_ht;
118};
119
120void minstrel_ht_add_sta_debugfs(void *priv, void *priv_sta, struct dentry *dir);
Thomas Huehn50e55a82015-03-24 21:09:41 +0100121int minstrel_ht_get_tp_avg(struct minstrel_ht_sta *mi, int group, int rate,
Felix Fietkau5f63afe2019-10-08 19:11:39 +0200122 int prob_avg);
Felix Fietkauec8aa662010-05-13 16:48:03 +0200123
124#endif