Thomas Gleixner | d2912cb | 2019-06-04 10:11:33 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 2 | /* |
| 3 | * Copyright (C) 2010 Felix Fietkau <nbd@openwrt.org> |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 4 | */ |
| 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 Fietkau | 7f2e12e | 2019-03-25 09:50:15 +0100 | [diff] [blame] | 13 | #define MINSTREL_MAX_STREAMS 4 |
Karl Beldan | 8a0ee4f | 2014-10-20 15:46:00 +0200 | [diff] [blame] | 14 | #define MINSTREL_HT_STREAM_GROUPS 4 /* BW(=2) * SGI(=2) */ |
Karl Beldan | 9208247 | 2014-10-21 10:38:38 +0200 | [diff] [blame] | 15 | #define MINSTREL_VHT_STREAM_GROUPS 6 /* BW(=3) * SGI(=2) */ |
Karl Beldan | 8a0ee4f | 2014-10-20 15:46:00 +0200 | [diff] [blame] | 16 | |
| 17 | #define MINSTREL_HT_GROUPS_NB (MINSTREL_MAX_STREAMS * \ |
| 18 | MINSTREL_HT_STREAM_GROUPS) |
Karl Beldan | 9208247 | 2014-10-21 10:38:38 +0200 | [diff] [blame] | 19 | #define MINSTREL_VHT_GROUPS_NB (MINSTREL_MAX_STREAMS * \ |
| 20 | MINSTREL_VHT_STREAM_GROUPS) |
Karl Beldan | 8a0ee4f | 2014-10-20 15:46:00 +0200 | [diff] [blame] | 21 | #define MINSTREL_CCK_GROUPS_NB 1 |
| 22 | #define MINSTREL_GROUPS_NB (MINSTREL_HT_GROUPS_NB + \ |
Karl Beldan | 9208247 | 2014-10-21 10:38:38 +0200 | [diff] [blame] | 23 | MINSTREL_VHT_GROUPS_NB + \ |
Karl Beldan | 8a0ee4f | 2014-10-20 15:46:00 +0200 | [diff] [blame] | 24 | 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 Beldan | 9208247 | 2014-10-21 10:38:38 +0200 | [diff] [blame] | 28 | #define MINSTREL_VHT_GROUP_0 (MINSTREL_CCK_GROUP + 1) |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 29 | |
Karl Beldan | 9208247 | 2014-10-21 10:38:38 +0200 | [diff] [blame] | 30 | #define MCS_GROUP_RATES 10 |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 31 | |
| 32 | struct mcs_group { |
Felix Fietkau | 202df50 | 2018-10-06 19:35:02 +0200 | [diff] [blame] | 33 | u16 flags; |
| 34 | u8 streams; |
| 35 | u8 shift; |
Felix Fietkau | 48cb395 | 2019-08-20 11:54:49 +0200 | [diff] [blame] | 36 | u8 bw; |
Felix Fietkau | 202df50 | 2018-10-06 19:35:02 +0200 | [diff] [blame] | 37 | u16 duration[MCS_GROUP_RATES]; |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 38 | }; |
| 39 | |
John W. Linville | de66bfd | 2010-06-24 13:03:14 -0400 | [diff] [blame] | 40 | extern const struct mcs_group minstrel_mcs_groups[]; |
| 41 | |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 42 | struct minstrel_mcs_group_data { |
| 43 | u8 index; |
| 44 | u8 column; |
| 45 | |
Thomas Huehn | 5935839 | 2014-09-09 23:22:14 +0200 | [diff] [blame] | 46 | /* sorted rate set within a MCS group*/ |
Karl Beldan | d4d141c | 2014-10-20 15:45:59 +0200 | [diff] [blame] | 47 | u16 max_group_tp_rate[MAX_THR_RATES]; |
| 48 | u16 max_group_prob_rate; |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 49 | |
| 50 | /* MCS rate statistics */ |
| 51 | struct minstrel_rate_stats rates[MCS_GROUP_RATES]; |
| 52 | }; |
| 53 | |
Felix Fietkau | 48cb395 | 2019-08-20 11:54:49 +0200 | [diff] [blame] | 54 | enum minstrel_sample_mode { |
| 55 | MINSTREL_SAMPLE_IDLE, |
| 56 | MINSTREL_SAMPLE_ACTIVE, |
| 57 | MINSTREL_SAMPLE_PENDING, |
| 58 | }; |
| 59 | |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 60 | struct minstrel_ht_sta { |
Felix Fietkau | a856666 | 2013-04-22 16:14:42 +0200 | [diff] [blame] | 61 | struct ieee80211_sta *sta; |
| 62 | |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 63 | /* 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 Huehn | 5935839 | 2014-09-09 23:22:14 +0200 | [diff] [blame] | 70 | /* overall sorted rate set */ |
Karl Beldan | d4d141c | 2014-10-20 15:45:59 +0200 | [diff] [blame] | 71 | u16 max_tp_rate[MAX_THR_RATES]; |
| 72 | u16 max_prob_rate; |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 73 | |
| 74 | /* time of last status update */ |
Thomas Huehn | 9134073 | 2015-03-24 21:09:39 +0100 | [diff] [blame] | 75 | unsigned long last_stats_update; |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 76 | |
| 77 | /* overhead time in usec for each frame */ |
| 78 | unsigned int overhead; |
| 79 | unsigned int overhead_rtscts; |
| 80 | |
Felix Fietkau | 48cb395 | 2019-08-20 11:54:49 +0200 | [diff] [blame] | 81 | unsigned int total_packets_last; |
| 82 | unsigned int total_packets_cur; |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 83 | 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 Fietkau | 48cb395 | 2019-08-20 11:54:49 +0200 | [diff] [blame] | 94 | enum minstrel_sample_mode sample_mode; |
| 95 | u16 sample_rate; |
| 96 | |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 97 | /* current MCS group to be sampled */ |
| 98 | u8 sample_group; |
| 99 | |
Felix Fietkau | a0497f9 | 2013-02-13 10:51:08 +0100 | [diff] [blame] | 100 | u8 cck_supported; |
| 101 | u8 cck_supported_short; |
| 102 | |
Felix Fietkau | 41d0858 | 2016-12-14 20:46:54 +0100 | [diff] [blame] | 103 | /* Bitfield of supported MCS rates of all groups */ |
| 104 | u16 supported[MINSTREL_GROUPS_NB]; |
| 105 | |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 106 | /* MCS rate group info and statistics */ |
Karl Beldan | 8a0ee4f | 2014-10-20 15:46:00 +0200 | [diff] [blame] | 107 | struct minstrel_mcs_group_data groups[MINSTREL_GROUPS_NB]; |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 108 | }; |
| 109 | |
| 110 | struct minstrel_ht_sta_priv { |
| 111 | union { |
| 112 | struct minstrel_ht_sta ht; |
| 113 | struct minstrel_sta_info legacy; |
| 114 | }; |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 115 | void *ratelist; |
| 116 | void *sample_table; |
| 117 | bool is_ht; |
| 118 | }; |
| 119 | |
| 120 | void minstrel_ht_add_sta_debugfs(void *priv, void *priv_sta, struct dentry *dir); |
Thomas Huehn | 50e55a8 | 2015-03-24 21:09:41 +0100 | [diff] [blame] | 121 | int minstrel_ht_get_tp_avg(struct minstrel_ht_sta *mi, int group, int rate, |
Felix Fietkau | 5f63afe | 2019-10-08 19:11:39 +0200 | [diff] [blame] | 122 | int prob_avg); |
Felix Fietkau | ec8aa66 | 2010-05-13 16:48:03 +0200 | [diff] [blame] | 123 | |
| 124 | #endif |