blob: 4efbc1c37eb8ea9bb7e10658ce82ec5347d065ec [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef __LINUX_PKT_SCHED_H
20#define __LINUX_PKT_SCHED_H
21#include <linux/types.h>
22#define TC_PRIO_BESTEFFORT 0
Ben Cheng655a7c02013-10-16 16:09:24 -070023#define TC_PRIO_FILLER 1
24#define TC_PRIO_BULK 2
25#define TC_PRIO_INTERACTIVE_BULK 4
26#define TC_PRIO_INTERACTIVE 6
Ben Cheng655a7c02013-10-16 16:09:24 -070027#define TC_PRIO_CONTROL 7
28#define TC_PRIO_MAX 15
29struct tc_stats {
Tao Baod7db5942015-01-28 10:07:51 -080030 __u64 bytes;
Tao Baod7db5942015-01-28 10:07:51 -080031 __u32 packets;
32 __u32 drops;
33 __u32 overlimits;
34 __u32 bps;
Tao Baod7db5942015-01-28 10:07:51 -080035 __u32 pps;
36 __u32 qlen;
37 __u32 backlog;
Ben Cheng655a7c02013-10-16 16:09:24 -070038};
Ben Cheng655a7c02013-10-16 16:09:24 -070039struct tc_estimator {
Tao Baod7db5942015-01-28 10:07:51 -080040 signed char interval;
41 unsigned char ewma_log;
Ben Cheng655a7c02013-10-16 16:09:24 -070042};
Ben Cheng655a7c02013-10-16 16:09:24 -070043#define TC_H_MAJ_MASK (0xFFFF0000U)
44#define TC_H_MIN_MASK (0x0000FFFFU)
Tao Baod7db5942015-01-28 10:07:51 -080045#define TC_H_MAJ(h) ((h) & TC_H_MAJ_MASK)
46#define TC_H_MIN(h) ((h) & TC_H_MIN_MASK)
Tao Baod7db5942015-01-28 10:07:51 -080047#define TC_H_MAKE(maj,min) (((maj) & TC_H_MAJ_MASK) | ((min) & TC_H_MIN_MASK))
Ben Cheng655a7c02013-10-16 16:09:24 -070048#define TC_H_UNSPEC (0U)
49#define TC_H_ROOT (0xFFFFFFFFU)
50#define TC_H_INGRESS (0xFFFFFFF1U)
Christopher Ferris106b3a82016-08-24 12:15:38 -070051#define TC_H_CLSACT TC_H_INGRESS
Christopher Ferris934ec942018-01-31 15:29:16 -080052#define TC_H_MIN_PRIORITY 0xFFE0U
Christopher Ferris106b3a82016-08-24 12:15:38 -070053#define TC_H_MIN_INGRESS 0xFFF2U
54#define TC_H_MIN_EGRESS 0xFFF3U
Christopher Ferris38062f92014-07-09 15:33:25 -070055enum tc_link_layer {
Tao Baod7db5942015-01-28 10:07:51 -080056 TC_LINKLAYER_UNAWARE,
57 TC_LINKLAYER_ETHERNET,
58 TC_LINKLAYER_ATM,
Christopher Ferris38062f92014-07-09 15:33:25 -070059};
60#define TC_LINKLAYER_MASK 0x0F
Ben Cheng655a7c02013-10-16 16:09:24 -070061struct tc_ratespec {
Tao Baod7db5942015-01-28 10:07:51 -080062 unsigned char cell_log;
Tao Baod7db5942015-01-28 10:07:51 -080063 __u8 linklayer;
64 unsigned short overhead;
65 short cell_align;
66 unsigned short mpu;
Tao Baod7db5942015-01-28 10:07:51 -080067 __u32 rate;
Ben Cheng655a7c02013-10-16 16:09:24 -070068};
69#define TC_RTAB_SIZE 1024
70struct tc_sizespec {
Tao Baod7db5942015-01-28 10:07:51 -080071 unsigned char cell_log;
72 unsigned char size_log;
73 short cell_align;
74 int overhead;
Tao Baod7db5942015-01-28 10:07:51 -080075 unsigned int linklayer;
76 unsigned int mpu;
77 unsigned int mtu;
78 unsigned int tsize;
Ben Cheng655a7c02013-10-16 16:09:24 -070079};
80enum {
Tao Baod7db5942015-01-28 10:07:51 -080081 TCA_STAB_UNSPEC,
82 TCA_STAB_BASE,
Tao Baod7db5942015-01-28 10:07:51 -080083 TCA_STAB_DATA,
84 __TCA_STAB_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -070085};
86#define TCA_STAB_MAX (__TCA_STAB_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -070087struct tc_fifo_qopt {
Tao Baod7db5942015-01-28 10:07:51 -080088 __u32 limit;
Ben Cheng655a7c02013-10-16 16:09:24 -070089};
Christopher Ferris9ce28842018-10-25 12:11:39 -070090#define SKBPRIO_MAX_PRIORITY 64
91struct tc_skbprio_qopt {
92 __u32 limit;
93};
Ben Cheng655a7c02013-10-16 16:09:24 -070094#define TCQ_PRIO_BANDS 16
Ben Cheng655a7c02013-10-16 16:09:24 -070095#define TCQ_MIN_PRIO_BANDS 2
96struct tc_prio_qopt {
Tao Baod7db5942015-01-28 10:07:51 -080097 int bands;
98 __u8 priomap[TC_PRIO_MAX + 1];
Ben Cheng655a7c02013-10-16 16:09:24 -070099};
100struct tc_multiq_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800101 __u16 bands;
102 __u16 max_bands;
Ben Cheng655a7c02013-10-16 16:09:24 -0700103};
104#define TCQ_PLUG_BUFFER 0
105#define TCQ_PLUG_RELEASE_ONE 1
106#define TCQ_PLUG_RELEASE_INDEFINITE 2
Ben Cheng655a7c02013-10-16 16:09:24 -0700107#define TCQ_PLUG_LIMIT 3
108struct tc_plug_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800109 int action;
110 __u32 limit;
Ben Cheng655a7c02013-10-16 16:09:24 -0700111};
112struct tc_tbf_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800113 struct tc_ratespec rate;
114 struct tc_ratespec peakrate;
Tao Baod7db5942015-01-28 10:07:51 -0800115 __u32 limit;
116 __u32 buffer;
117 __u32 mtu;
Ben Cheng655a7c02013-10-16 16:09:24 -0700118};
Ben Cheng655a7c02013-10-16 16:09:24 -0700119enum {
Tao Baod7db5942015-01-28 10:07:51 -0800120 TCA_TBF_UNSPEC,
121 TCA_TBF_PARMS,
122 TCA_TBF_RTAB,
Tao Baod7db5942015-01-28 10:07:51 -0800123 TCA_TBF_PTAB,
124 TCA_TBF_RATE64,
125 TCA_TBF_PRATE64,
126 TCA_TBF_BURST,
Tao Baod7db5942015-01-28 10:07:51 -0800127 TCA_TBF_PBURST,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700128 TCA_TBF_PAD,
Tao Baod7db5942015-01-28 10:07:51 -0800129 __TCA_TBF_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700130};
131#define TCA_TBF_MAX (__TCA_TBF_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700132struct tc_sfq_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800133 unsigned quantum;
134 int perturb_period;
135 __u32 limit;
Tao Baod7db5942015-01-28 10:07:51 -0800136 unsigned divisor;
137 unsigned flows;
Ben Cheng655a7c02013-10-16 16:09:24 -0700138};
139struct tc_sfqred_stats {
Tao Baod7db5942015-01-28 10:07:51 -0800140 __u32 prob_drop;
141 __u32 forced_drop;
142 __u32 prob_mark;
143 __u32 forced_mark;
Tao Baod7db5942015-01-28 10:07:51 -0800144 __u32 prob_mark_head;
145 __u32 forced_mark_head;
Ben Cheng655a7c02013-10-16 16:09:24 -0700146};
147struct tc_sfq_qopt_v1 {
Tao Baod7db5942015-01-28 10:07:51 -0800148 struct tc_sfq_qopt v0;
149 unsigned int depth;
150 unsigned int headdrop;
151 __u32 limit;
Tao Baod7db5942015-01-28 10:07:51 -0800152 __u32 qth_min;
153 __u32 qth_max;
154 unsigned char Wlog;
155 unsigned char Plog;
Tao Baod7db5942015-01-28 10:07:51 -0800156 unsigned char Scell_log;
157 unsigned char flags;
158 __u32 max_P;
159 struct tc_sfqred_stats stats;
Ben Cheng655a7c02013-10-16 16:09:24 -0700160};
161struct tc_sfq_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800162 __s32 allot;
Ben Cheng655a7c02013-10-16 16:09:24 -0700163};
Ben Cheng655a7c02013-10-16 16:09:24 -0700164enum {
Tao Baod7db5942015-01-28 10:07:51 -0800165 TCA_RED_UNSPEC,
166 TCA_RED_PARMS,
167 TCA_RED_STAB,
Tao Baod7db5942015-01-28 10:07:51 -0800168 TCA_RED_MAX_P,
169 __TCA_RED_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700170};
171#define TCA_RED_MAX (__TCA_RED_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700172struct tc_red_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800173 __u32 limit;
174 __u32 qth_min;
175 __u32 qth_max;
Tao Baod7db5942015-01-28 10:07:51 -0800176 unsigned char Wlog;
177 unsigned char Plog;
178 unsigned char Scell_log;
179 unsigned char flags;
Ben Cheng655a7c02013-10-16 16:09:24 -0700180#define TC_RED_ECN 1
181#define TC_RED_HARDDROP 2
182#define TC_RED_ADAPTATIVE 4
183};
Ben Cheng655a7c02013-10-16 16:09:24 -0700184struct tc_red_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800185 __u32 early;
186 __u32 pdrop;
187 __u32 other;
Tao Baod7db5942015-01-28 10:07:51 -0800188 __u32 marked;
Ben Cheng655a7c02013-10-16 16:09:24 -0700189};
190#define MAX_DPs 16
191enum {
Tao Baod7db5942015-01-28 10:07:51 -0800192 TCA_GRED_UNSPEC,
193 TCA_GRED_PARMS,
194 TCA_GRED_STAB,
195 TCA_GRED_DPS,
Tao Baod7db5942015-01-28 10:07:51 -0800196 TCA_GRED_MAX_P,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800197 TCA_GRED_LIMIT,
Tao Baod7db5942015-01-28 10:07:51 -0800198 __TCA_GRED_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700199};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800200#define TCA_GRED_MAX (__TCA_GRED_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700201struct tc_gred_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800202 __u32 limit;
203 __u32 qth_min;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800204 __u32 qth_max;
Tao Baod7db5942015-01-28 10:07:51 -0800205 __u32 DP;
206 __u32 backlog;
207 __u32 qave;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800208 __u32 forced;
Tao Baod7db5942015-01-28 10:07:51 -0800209 __u32 early;
210 __u32 other;
211 __u32 pdrop;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800212 __u8 Wlog;
Tao Baod7db5942015-01-28 10:07:51 -0800213 __u8 Plog;
214 __u8 Scell_log;
215 __u8 prio;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800216 __u32 packets;
Tao Baod7db5942015-01-28 10:07:51 -0800217 __u32 bytesin;
Ben Cheng655a7c02013-10-16 16:09:24 -0700218};
219struct tc_gred_sopt {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800220 __u32 DPs;
Tao Baod7db5942015-01-28 10:07:51 -0800221 __u32 def_DP;
222 __u8 grio;
223 __u8 flags;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800224 __u16 pad1;
Ben Cheng655a7c02013-10-16 16:09:24 -0700225};
226enum {
Tao Baod7db5942015-01-28 10:07:51 -0800227 TCA_CHOKE_UNSPEC,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800228 TCA_CHOKE_PARMS,
Tao Baod7db5942015-01-28 10:07:51 -0800229 TCA_CHOKE_STAB,
230 TCA_CHOKE_MAX_P,
231 __TCA_CHOKE_MAX,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800232};
Ben Cheng655a7c02013-10-16 16:09:24 -0700233#define TCA_CHOKE_MAX (__TCA_CHOKE_MAX - 1)
234struct tc_choke_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800235 __u32 limit;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800236 __u32 qth_min;
Tao Baod7db5942015-01-28 10:07:51 -0800237 __u32 qth_max;
238 unsigned char Wlog;
239 unsigned char Plog;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800240 unsigned char Scell_log;
Tao Baod7db5942015-01-28 10:07:51 -0800241 unsigned char flags;
Ben Cheng655a7c02013-10-16 16:09:24 -0700242};
243struct tc_choke_xstats {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800244 __u32 early;
Tao Baod7db5942015-01-28 10:07:51 -0800245 __u32 pdrop;
246 __u32 other;
247 __u32 marked;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800248 __u32 matched;
Ben Cheng655a7c02013-10-16 16:09:24 -0700249};
250#define TC_HTB_NUMPRIO 8
251#define TC_HTB_MAXDEPTH 8
Christopher Ferris05d08e92016-02-04 13:16:38 -0800252#define TC_HTB_PROTOVER 3
Ben Cheng655a7c02013-10-16 16:09:24 -0700253struct tc_htb_opt {
Tao Baod7db5942015-01-28 10:07:51 -0800254 struct tc_ratespec rate;
255 struct tc_ratespec ceil;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800256 __u32 buffer;
Tao Baod7db5942015-01-28 10:07:51 -0800257 __u32 cbuffer;
258 __u32 quantum;
259 __u32 level;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800260 __u32 prio;
Ben Cheng655a7c02013-10-16 16:09:24 -0700261};
262struct tc_htb_glob {
Tao Baod7db5942015-01-28 10:07:51 -0800263 __u32 version;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800264 __u32 rate2quantum;
Tao Baod7db5942015-01-28 10:07:51 -0800265 __u32 defcls;
266 __u32 debug;
267 __u32 direct_pkts;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800268};
Ben Cheng655a7c02013-10-16 16:09:24 -0700269enum {
Tao Baod7db5942015-01-28 10:07:51 -0800270 TCA_HTB_UNSPEC,
271 TCA_HTB_PARMS,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800272 TCA_HTB_INIT,
Tao Baod7db5942015-01-28 10:07:51 -0800273 TCA_HTB_CTAB,
274 TCA_HTB_RTAB,
275 TCA_HTB_DIRECT_QLEN,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800276 TCA_HTB_RATE64,
Tao Baod7db5942015-01-28 10:07:51 -0800277 TCA_HTB_CEIL64,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700278 TCA_HTB_PAD,
Tao Baod7db5942015-01-28 10:07:51 -0800279 __TCA_HTB_MAX,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700280};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800281#define TCA_HTB_MAX (__TCA_HTB_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700282struct tc_htb_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800283 __u32 lends;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700284 __u32 borrows;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800285 __u32 giants;
Tao Baod7db5942015-01-28 10:07:51 -0800286 __u32 tokens;
287 __u32 ctokens;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700288};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800289struct tc_hfsc_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800290 __u16 defcls;
Ben Cheng655a7c02013-10-16 16:09:24 -0700291};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700292struct tc_service_curve {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800293 __u32 m1;
Tao Baod7db5942015-01-28 10:07:51 -0800294 __u32 d;
295 __u32 m2;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700296};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800297struct tc_hfsc_stats {
Tao Baod7db5942015-01-28 10:07:51 -0800298 __u64 work;
299 __u64 rtwork;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700300 __u32 period;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800301 __u32 level;
Ben Cheng655a7c02013-10-16 16:09:24 -0700302};
303enum {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700304 TCA_HFSC_UNSPEC,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800305 TCA_HFSC_RSC,
Tao Baod7db5942015-01-28 10:07:51 -0800306 TCA_HFSC_FSC,
307 TCA_HFSC_USC,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700308 __TCA_HFSC_MAX,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800309};
Ben Cheng655a7c02013-10-16 16:09:24 -0700310#define TCA_HFSC_MAX (__TCA_HFSC_MAX - 1)
311#define TC_CBQ_MAXPRIO 8
Christopher Ferris106b3a82016-08-24 12:15:38 -0700312#define TC_CBQ_MAXLEVEL 8
Christopher Ferris05d08e92016-02-04 13:16:38 -0800313#define TC_CBQ_DEF_EWMA 5
Ben Cheng655a7c02013-10-16 16:09:24 -0700314struct tc_cbq_lssopt {
Tao Baod7db5942015-01-28 10:07:51 -0800315 unsigned char change;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700316 unsigned char flags;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800317#define TCF_CBQ_LSS_BOUNDED 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700318#define TCF_CBQ_LSS_ISOLATED 2
Tao Baod7db5942015-01-28 10:07:51 -0800319 unsigned char ewma_log;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700320 unsigned char level;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800321#define TCF_CBQ_LSS_FLAGS 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700322#define TCF_CBQ_LSS_EWMA 2
323#define TCF_CBQ_LSS_MAXIDLE 4
Christopher Ferris106b3a82016-08-24 12:15:38 -0700324#define TCF_CBQ_LSS_MINIDLE 8
Christopher Ferris05d08e92016-02-04 13:16:38 -0800325#define TCF_CBQ_LSS_OFFTIME 0x10
Ben Cheng655a7c02013-10-16 16:09:24 -0700326#define TCF_CBQ_LSS_AVPKT 0x20
Tao Baod7db5942015-01-28 10:07:51 -0800327 __u32 maxidle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700328 __u32 minidle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800329 __u32 offtime;
Tao Baod7db5942015-01-28 10:07:51 -0800330 __u32 avpkt;
Ben Cheng655a7c02013-10-16 16:09:24 -0700331};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700332struct tc_cbq_wrropt {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800333 unsigned char flags;
Tao Baod7db5942015-01-28 10:07:51 -0800334 unsigned char priority;
335 unsigned char cpriority;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700336 unsigned char __reserved;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800337 __u32 allot;
Tao Baod7db5942015-01-28 10:07:51 -0800338 __u32 weight;
Ben Cheng655a7c02013-10-16 16:09:24 -0700339};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700340struct tc_cbq_ovl {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800341 unsigned char strategy;
Ben Cheng655a7c02013-10-16 16:09:24 -0700342#define TC_CBQ_OVL_CLASSIC 0
343#define TC_CBQ_OVL_DELAY 1
Christopher Ferris106b3a82016-08-24 12:15:38 -0700344#define TC_CBQ_OVL_LOWPRIO 2
Christopher Ferris05d08e92016-02-04 13:16:38 -0800345#define TC_CBQ_OVL_DROP 3
Ben Cheng655a7c02013-10-16 16:09:24 -0700346#define TC_CBQ_OVL_RCLASSIC 4
Tao Baod7db5942015-01-28 10:07:51 -0800347 unsigned char priority2;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700348 __u16 pad;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800349 __u32 penalty;
Ben Cheng655a7c02013-10-16 16:09:24 -0700350};
351struct tc_cbq_police {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700352 unsigned char police;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800353 unsigned char __res1;
Tao Baod7db5942015-01-28 10:07:51 -0800354 unsigned short __res2;
Ben Cheng655a7c02013-10-16 16:09:24 -0700355};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700356struct tc_cbq_fopt {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800357 __u32 split;
Tao Baod7db5942015-01-28 10:07:51 -0800358 __u32 defmap;
359 __u32 defchange;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700360};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800361struct tc_cbq_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800362 __u32 borrows;
363 __u32 overactions;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700364 __s32 avgidle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800365 __s32 undertime;
Ben Cheng655a7c02013-10-16 16:09:24 -0700366};
367enum {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700368 TCA_CBQ_UNSPEC,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800369 TCA_CBQ_LSSOPT,
Tao Baod7db5942015-01-28 10:07:51 -0800370 TCA_CBQ_WRROPT,
371 TCA_CBQ_FOPT,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700372 TCA_CBQ_OVL_STRATEGY,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800373 TCA_CBQ_RATE,
Tao Baod7db5942015-01-28 10:07:51 -0800374 TCA_CBQ_RTAB,
375 TCA_CBQ_POLICE,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700376 __TCA_CBQ_MAX,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800377};
Ben Cheng655a7c02013-10-16 16:09:24 -0700378#define TCA_CBQ_MAX (__TCA_CBQ_MAX - 1)
379enum {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700380 TCA_DSMARK_UNSPEC,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800381 TCA_DSMARK_INDICES,
Tao Baod7db5942015-01-28 10:07:51 -0800382 TCA_DSMARK_DEFAULT_INDEX,
383 TCA_DSMARK_SET_TC_INDEX,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700384 TCA_DSMARK_MASK,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800385 TCA_DSMARK_VALUE,
Tao Baod7db5942015-01-28 10:07:51 -0800386 __TCA_DSMARK_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700387};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700388#define TCA_DSMARK_MAX (__TCA_DSMARK_MAX - 1)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800389enum {
Tao Baod7db5942015-01-28 10:07:51 -0800390 TCA_ATM_UNSPEC,
391 TCA_ATM_FD,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700392 TCA_ATM_PTR,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800393 TCA_ATM_HDR,
Tao Baod7db5942015-01-28 10:07:51 -0800394 TCA_ATM_EXCESS,
395 TCA_ATM_ADDR,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700396 TCA_ATM_STATE,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800397 __TCA_ATM_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700398};
399#define TCA_ATM_MAX (__TCA_ATM_MAX - 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700400enum {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800401 TCA_NETEM_UNSPEC,
Tao Baod7db5942015-01-28 10:07:51 -0800402 TCA_NETEM_CORR,
403 TCA_NETEM_DELAY_DIST,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700404 TCA_NETEM_REORDER,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800405 TCA_NETEM_CORRUPT,
Tao Baod7db5942015-01-28 10:07:51 -0800406 TCA_NETEM_LOSS,
407 TCA_NETEM_RATE,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700408 TCA_NETEM_ECN,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800409 TCA_NETEM_RATE64,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700410 TCA_NETEM_PAD,
Christopher Ferris934ec942018-01-31 15:29:16 -0800411 TCA_NETEM_LATENCY64,
412 TCA_NETEM_JITTER64,
413 TCA_NETEM_SLOT,
Christopher Ferris9ce28842018-10-25 12:11:39 -0700414 TCA_NETEM_SLOT_DIST,
Tao Baod7db5942015-01-28 10:07:51 -0800415 __TCA_NETEM_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700416};
417#define TCA_NETEM_MAX (__TCA_NETEM_MAX - 1)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800418struct tc_netem_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800419 __u32 latency;
420 __u32 limit;
421 __u32 loss;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800422 __u32 gap;
Tao Baod7db5942015-01-28 10:07:51 -0800423 __u32 duplicate;
424 __u32 jitter;
Ben Cheng655a7c02013-10-16 16:09:24 -0700425};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800426struct tc_netem_corr {
Tao Baod7db5942015-01-28 10:07:51 -0800427 __u32 delay_corr;
428 __u32 loss_corr;
429 __u32 dup_corr;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800430};
Ben Cheng655a7c02013-10-16 16:09:24 -0700431struct tc_netem_reorder {
Tao Baod7db5942015-01-28 10:07:51 -0800432 __u32 probability;
433 __u32 correlation;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800434};
Ben Cheng655a7c02013-10-16 16:09:24 -0700435struct tc_netem_corrupt {
Tao Baod7db5942015-01-28 10:07:51 -0800436 __u32 probability;
437 __u32 correlation;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800438};
Christopher Ferris38062f92014-07-09 15:33:25 -0700439struct tc_netem_rate {
Tao Baod7db5942015-01-28 10:07:51 -0800440 __u32 rate;
441 __s32 packet_overhead;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800442 __u32 cell_size;
Tao Baod7db5942015-01-28 10:07:51 -0800443 __s32 cell_overhead;
Ben Cheng655a7c02013-10-16 16:09:24 -0700444};
Christopher Ferris934ec942018-01-31 15:29:16 -0800445struct tc_netem_slot {
446 __s64 min_delay;
447 __s64 max_delay;
448 __s32 max_packets;
449 __s32 max_bytes;
Christopher Ferris9ce28842018-10-25 12:11:39 -0700450 __s64 dist_delay;
451 __s64 dist_jitter;
Christopher Ferris934ec942018-01-31 15:29:16 -0800452};
Ben Cheng655a7c02013-10-16 16:09:24 -0700453enum {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800454 NETEM_LOSS_UNSPEC,
Tao Baod7db5942015-01-28 10:07:51 -0800455 NETEM_LOSS_GI,
456 NETEM_LOSS_GE,
457 __NETEM_LOSS_MAX
Christopher Ferris05d08e92016-02-04 13:16:38 -0800458};
Christopher Ferris38062f92014-07-09 15:33:25 -0700459#define NETEM_LOSS_MAX (__NETEM_LOSS_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700460struct tc_netem_gimodel {
Tao Baod7db5942015-01-28 10:07:51 -0800461 __u32 p13;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800462 __u32 p31;
Tao Baod7db5942015-01-28 10:07:51 -0800463 __u32 p32;
464 __u32 p14;
465 __u32 p23;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800466};
Christopher Ferris38062f92014-07-09 15:33:25 -0700467struct tc_netem_gemodel {
Tao Baod7db5942015-01-28 10:07:51 -0800468 __u32 p;
469 __u32 r;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800470 __u32 h;
Tao Baod7db5942015-01-28 10:07:51 -0800471 __u32 k1;
Ben Cheng655a7c02013-10-16 16:09:24 -0700472};
473#define NETEM_DIST_SCALE 8192
Christopher Ferris05d08e92016-02-04 13:16:38 -0800474#define NETEM_DIST_MAX 16384
Christopher Ferris38062f92014-07-09 15:33:25 -0700475enum {
Tao Baod7db5942015-01-28 10:07:51 -0800476 TCA_DRR_UNSPEC,
477 TCA_DRR_QUANTUM,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800478 __TCA_DRR_MAX
Christopher Ferris38062f92014-07-09 15:33:25 -0700479};
Ben Cheng655a7c02013-10-16 16:09:24 -0700480#define TCA_DRR_MAX (__TCA_DRR_MAX - 1)
481struct tc_drr_stats {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800482 __u32 deficit;
Christopher Ferris38062f92014-07-09 15:33:25 -0700483};
Ben Cheng655a7c02013-10-16 16:09:24 -0700484#define TC_QOPT_BITMASK 15
485#define TC_QOPT_MAX_QUEUE 16
Christopher Ferris525ce912017-07-26 13:12:53 -0700486enum {
487 TC_MQPRIO_HW_OFFLOAD_NONE,
488 TC_MQPRIO_HW_OFFLOAD_TCS,
489 __TC_MQPRIO_HW_OFFLOAD_MAX
490};
491#define TC_MQPRIO_HW_OFFLOAD_MAX (__TC_MQPRIO_HW_OFFLOAD_MAX - 1)
Christopher Ferris934ec942018-01-31 15:29:16 -0800492enum {
493 TC_MQPRIO_MODE_DCB,
494 TC_MQPRIO_MODE_CHANNEL,
495 __TC_MQPRIO_MODE_MAX
496};
497#define __TC_MQPRIO_MODE_MAX (__TC_MQPRIO_MODE_MAX - 1)
498enum {
499 TC_MQPRIO_SHAPER_DCB,
500 TC_MQPRIO_SHAPER_BW_RATE,
501 __TC_MQPRIO_SHAPER_MAX
502};
503#define __TC_MQPRIO_SHAPER_MAX (__TC_MQPRIO_SHAPER_MAX - 1)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800504struct tc_mqprio_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800505 __u8 num_tc;
506 __u8 prio_tc_map[TC_QOPT_BITMASK + 1];
507 __u8 hw;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800508 __u16 count[TC_QOPT_MAX_QUEUE];
Tao Baod7db5942015-01-28 10:07:51 -0800509 __u16 offset[TC_QOPT_MAX_QUEUE];
Ben Cheng655a7c02013-10-16 16:09:24 -0700510};
Christopher Ferris934ec942018-01-31 15:29:16 -0800511#define TC_MQPRIO_F_MODE 0x1
512#define TC_MQPRIO_F_SHAPER 0x2
513#define TC_MQPRIO_F_MIN_RATE 0x4
514#define TC_MQPRIO_F_MAX_RATE 0x8
515enum {
516 TCA_MQPRIO_UNSPEC,
517 TCA_MQPRIO_MODE,
518 TCA_MQPRIO_SHAPER,
519 TCA_MQPRIO_MIN_RATE64,
520 TCA_MQPRIO_MAX_RATE64,
521 __TCA_MQPRIO_MAX,
522};
523#define TCA_MQPRIO_MAX (__TCA_MQPRIO_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700524enum {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800525 TCA_SFB_UNSPEC,
Tao Baod7db5942015-01-28 10:07:51 -0800526 TCA_SFB_PARMS,
527 __TCA_SFB_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700528};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800529#define TCA_SFB_MAX (__TCA_SFB_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700530struct tc_sfb_qopt {
Tao Baod7db5942015-01-28 10:07:51 -0800531 __u32 rehash_interval;
532 __u32 warmup_time;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800533 __u32 max;
Tao Baod7db5942015-01-28 10:07:51 -0800534 __u32 bin_size;
535 __u32 increment;
536 __u32 decrement;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800537 __u32 limit;
Tao Baod7db5942015-01-28 10:07:51 -0800538 __u32 penalty_rate;
539 __u32 penalty_burst;
Ben Cheng655a7c02013-10-16 16:09:24 -0700540};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800541struct tc_sfb_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800542 __u32 earlydrop;
543 __u32 penaltydrop;
544 __u32 bucketdrop;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800545 __u32 queuedrop;
Tao Baod7db5942015-01-28 10:07:51 -0800546 __u32 childdrop;
547 __u32 marked;
548 __u32 maxqlen;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800549 __u32 maxprob;
Tao Baod7db5942015-01-28 10:07:51 -0800550 __u32 avgprob;
Ben Cheng655a7c02013-10-16 16:09:24 -0700551};
552#define SFB_MAX_PROB 0xFFFF
Christopher Ferris05d08e92016-02-04 13:16:38 -0800553enum {
Tao Baod7db5942015-01-28 10:07:51 -0800554 TCA_QFQ_UNSPEC,
555 TCA_QFQ_WEIGHT,
556 TCA_QFQ_LMAX,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800557 __TCA_QFQ_MAX
Christopher Ferris38062f92014-07-09 15:33:25 -0700558};
Ben Cheng655a7c02013-10-16 16:09:24 -0700559#define TCA_QFQ_MAX (__TCA_QFQ_MAX - 1)
560struct tc_qfq_stats {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800561 __u32 weight;
Tao Baod7db5942015-01-28 10:07:51 -0800562 __u32 lmax;
Ben Cheng655a7c02013-10-16 16:09:24 -0700563};
564enum {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800565 TCA_CODEL_UNSPEC,
Tao Baod7db5942015-01-28 10:07:51 -0800566 TCA_CODEL_TARGET,
567 TCA_CODEL_LIMIT,
568 TCA_CODEL_INTERVAL,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800569 TCA_CODEL_ECN,
570 TCA_CODEL_CE_THRESHOLD,
Tao Baod7db5942015-01-28 10:07:51 -0800571 __TCA_CODEL_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700572};
573#define TCA_CODEL_MAX (__TCA_CODEL_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700574struct tc_codel_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800575 __u32 maxpacket;
576 __u32 count;
577 __u32 lastcount;
578 __u32 ldelay;
Tao Baod7db5942015-01-28 10:07:51 -0800579 __s32 drop_next;
580 __u32 drop_overlimit;
581 __u32 ecn_mark;
582 __u32 dropping;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800583 __u32 ce_mark;
Christopher Ferris38062f92014-07-09 15:33:25 -0700584};
Ben Cheng655a7c02013-10-16 16:09:24 -0700585enum {
Tao Baod7db5942015-01-28 10:07:51 -0800586 TCA_FQ_CODEL_UNSPEC,
587 TCA_FQ_CODEL_TARGET,
Tao Baod7db5942015-01-28 10:07:51 -0800588 TCA_FQ_CODEL_LIMIT,
589 TCA_FQ_CODEL_INTERVAL,
590 TCA_FQ_CODEL_ECN,
591 TCA_FQ_CODEL_FLOWS,
Tao Baod7db5942015-01-28 10:07:51 -0800592 TCA_FQ_CODEL_QUANTUM,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800593 TCA_FQ_CODEL_CE_THRESHOLD,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700594 TCA_FQ_CODEL_DROP_BATCH_SIZE,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700595 TCA_FQ_CODEL_MEMORY_LIMIT,
Tao Baod7db5942015-01-28 10:07:51 -0800596 __TCA_FQ_CODEL_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700597};
Ben Cheng655a7c02013-10-16 16:09:24 -0700598#define TCA_FQ_CODEL_MAX (__TCA_FQ_CODEL_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700599enum {
Tao Baod7db5942015-01-28 10:07:51 -0800600 TCA_FQ_CODEL_XSTATS_QDISC,
601 TCA_FQ_CODEL_XSTATS_CLASS,
Ben Cheng655a7c02013-10-16 16:09:24 -0700602};
Christopher Ferris38062f92014-07-09 15:33:25 -0700603struct tc_fq_codel_qd_stats {
Tao Baod7db5942015-01-28 10:07:51 -0800604 __u32 maxpacket;
605 __u32 drop_overlimit;
606 __u32 ecn_mark;
Tao Baod7db5942015-01-28 10:07:51 -0800607 __u32 new_flow_count;
608 __u32 new_flows_len;
609 __u32 old_flows_len;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800610 __u32 ce_mark;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700611 __u32 memory_usage;
612 __u32 drop_overmemory;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800613};
Christopher Ferris38062f92014-07-09 15:33:25 -0700614struct tc_fq_codel_cl_stats {
Tao Baod7db5942015-01-28 10:07:51 -0800615 __s32 deficit;
616 __u32 ldelay;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800617 __u32 count;
Tao Baod7db5942015-01-28 10:07:51 -0800618 __u32 lastcount;
619 __u32 dropping;
620 __s32 drop_next;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800621};
Christopher Ferris38062f92014-07-09 15:33:25 -0700622struct tc_fq_codel_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800623 __u32 type;
624 union {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800625 struct tc_fq_codel_qd_stats qdisc_stats;
Tao Baod7db5942015-01-28 10:07:51 -0800626 struct tc_fq_codel_cl_stats class_stats;
627 };
Ben Cheng655a7c02013-10-16 16:09:24 -0700628};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800629enum {
Tao Baod7db5942015-01-28 10:07:51 -0800630 TCA_FQ_UNSPEC,
631 TCA_FQ_PLIMIT,
632 TCA_FQ_FLOW_PLIMIT,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800633 TCA_FQ_QUANTUM,
Tao Baod7db5942015-01-28 10:07:51 -0800634 TCA_FQ_INITIAL_QUANTUM,
635 TCA_FQ_RATE_ENABLE,
636 TCA_FQ_FLOW_DEFAULT_RATE,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800637 TCA_FQ_FLOW_MAX_RATE,
Tao Baod7db5942015-01-28 10:07:51 -0800638 TCA_FQ_BUCKETS_LOG,
639 TCA_FQ_FLOW_REFILL_DELAY,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800640 TCA_FQ_ORPHAN_MASK,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800641 TCA_FQ_LOW_RATE_THRESHOLD,
Tao Baod7db5942015-01-28 10:07:51 -0800642 __TCA_FQ_MAX
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800643};
Christopher Ferris38062f92014-07-09 15:33:25 -0700644#define TCA_FQ_MAX (__TCA_FQ_MAX - 1)
645struct tc_fq_qd_stats {
Tao Baod7db5942015-01-28 10:07:51 -0800646 __u64 gc_flows;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800647 __u64 highprio_packets;
Tao Baod7db5942015-01-28 10:07:51 -0800648 __u64 tcp_retrans;
649 __u64 throttled;
650 __u64 flows_plimit;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800651 __u64 pkts_too_long;
Tao Baod7db5942015-01-28 10:07:51 -0800652 __u64 allocation_errors;
653 __s64 time_next_delayed_flow;
654 __u32 flows;
655 __u32 inactive_flows;
Tao Baod7db5942015-01-28 10:07:51 -0800656 __u32 throttled_flows;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800657 __u32 unthrottle_latency_ns;
Christopher Ferris38062f92014-07-09 15:33:25 -0700658};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800659enum {
Tao Baod7db5942015-01-28 10:07:51 -0800660 TCA_HHF_UNSPEC,
661 TCA_HHF_BACKLOG_LIMIT,
662 TCA_HHF_QUANTUM,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800663 TCA_HHF_HH_FLOWS_LIMIT,
Tao Baod7db5942015-01-28 10:07:51 -0800664 TCA_HHF_RESET_TIMEOUT,
665 TCA_HHF_ADMIT_BYTES,
666 TCA_HHF_EVICT_TIMEOUT,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800667 TCA_HHF_NON_HH_WEIGHT,
Tao Baod7db5942015-01-28 10:07:51 -0800668 __TCA_HHF_MAX
Christopher Ferris38062f92014-07-09 15:33:25 -0700669};
670#define TCA_HHF_MAX (__TCA_HHF_MAX - 1)
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800671struct tc_hhf_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800672 __u32 drop_overlimit;
673 __u32 hh_overlimit;
674 __u32 hh_tot_count;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800675 __u32 hh_cur_count;
Christopher Ferris38062f92014-07-09 15:33:25 -0700676};
677enum {
Tao Baod7db5942015-01-28 10:07:51 -0800678 TCA_PIE_UNSPEC,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800679 TCA_PIE_TARGET,
Tao Baod7db5942015-01-28 10:07:51 -0800680 TCA_PIE_LIMIT,
681 TCA_PIE_TUPDATE,
682 TCA_PIE_ALPHA,
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800683 TCA_PIE_BETA,
Tao Baod7db5942015-01-28 10:07:51 -0800684 TCA_PIE_ECN,
685 TCA_PIE_BYTEMODE,
686 __TCA_PIE_MAX
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800687};
Christopher Ferris38062f92014-07-09 15:33:25 -0700688#define TCA_PIE_MAX (__TCA_PIE_MAX - 1)
689struct tc_pie_xstats {
Tao Baod7db5942015-01-28 10:07:51 -0800690 __u32 prob;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800691 __u32 delay;
Tao Baod7db5942015-01-28 10:07:51 -0800692 __u32 avg_dq_rate;
693 __u32 packets_in;
694 __u32 dropped;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800695 __u32 overlimit;
Tao Baod7db5942015-01-28 10:07:51 -0800696 __u32 maxq;
697 __u32 ecn_mark;
Christopher Ferris38062f92014-07-09 15:33:25 -0700698};
Christopher Ferris934ec942018-01-31 15:29:16 -0800699struct tc_cbs_qopt {
700 __u8 offload;
701 __u8 _pad[3];
702 __s32 hicredit;
703 __s32 locredit;
704 __s32 idleslope;
705 __s32 sendslope;
706};
707enum {
708 TCA_CBS_UNSPEC,
709 TCA_CBS_PARMS,
710 __TCA_CBS_MAX,
711};
712#define TCA_CBS_MAX (__TCA_CBS_MAX - 1)
Christopher Ferris9ce28842018-10-25 12:11:39 -0700713struct tc_etf_qopt {
714 __s32 delta;
715 __s32 clockid;
716 __u32 flags;
717#define TC_ETF_DEADLINE_MODE_ON BIT(0)
718#define TC_ETF_OFFLOAD_ON BIT(1)
719};
720enum {
721 TCA_ETF_UNSPEC,
722 TCA_ETF_PARMS,
723 __TCA_ETF_MAX,
724};
725#define TCA_ETF_MAX (__TCA_ETF_MAX - 1)
726enum {
727 TCA_CAKE_UNSPEC,
728 TCA_CAKE_PAD,
729 TCA_CAKE_BASE_RATE64,
730 TCA_CAKE_DIFFSERV_MODE,
731 TCA_CAKE_ATM,
732 TCA_CAKE_FLOW_MODE,
733 TCA_CAKE_OVERHEAD,
734 TCA_CAKE_RTT,
735 TCA_CAKE_TARGET,
736 TCA_CAKE_AUTORATE,
737 TCA_CAKE_MEMORY,
738 TCA_CAKE_NAT,
739 TCA_CAKE_RAW,
740 TCA_CAKE_WASH,
741 TCA_CAKE_MPU,
742 TCA_CAKE_INGRESS,
743 TCA_CAKE_ACK_FILTER,
744 TCA_CAKE_SPLIT_GSO,
745 __TCA_CAKE_MAX
746};
747#define TCA_CAKE_MAX (__TCA_CAKE_MAX - 1)
748enum {
749 __TCA_CAKE_STATS_INVALID,
750 TCA_CAKE_STATS_PAD,
751 TCA_CAKE_STATS_CAPACITY_ESTIMATE64,
752 TCA_CAKE_STATS_MEMORY_LIMIT,
753 TCA_CAKE_STATS_MEMORY_USED,
754 TCA_CAKE_STATS_AVG_NETOFF,
755 TCA_CAKE_STATS_MIN_NETLEN,
756 TCA_CAKE_STATS_MAX_NETLEN,
757 TCA_CAKE_STATS_MIN_ADJLEN,
758 TCA_CAKE_STATS_MAX_ADJLEN,
759 TCA_CAKE_STATS_TIN_STATS,
760 TCA_CAKE_STATS_DEFICIT,
761 TCA_CAKE_STATS_COBALT_COUNT,
762 TCA_CAKE_STATS_DROPPING,
763 TCA_CAKE_STATS_DROP_NEXT_US,
764 TCA_CAKE_STATS_P_DROP,
765 TCA_CAKE_STATS_BLUE_TIMER_US,
766 __TCA_CAKE_STATS_MAX
767};
768#define TCA_CAKE_STATS_MAX (__TCA_CAKE_STATS_MAX - 1)
769enum {
770 __TCA_CAKE_TIN_STATS_INVALID,
771 TCA_CAKE_TIN_STATS_PAD,
772 TCA_CAKE_TIN_STATS_SENT_PACKETS,
773 TCA_CAKE_TIN_STATS_SENT_BYTES64,
774 TCA_CAKE_TIN_STATS_DROPPED_PACKETS,
775 TCA_CAKE_TIN_STATS_DROPPED_BYTES64,
776 TCA_CAKE_TIN_STATS_ACKS_DROPPED_PACKETS,
777 TCA_CAKE_TIN_STATS_ACKS_DROPPED_BYTES64,
778 TCA_CAKE_TIN_STATS_ECN_MARKED_PACKETS,
779 TCA_CAKE_TIN_STATS_ECN_MARKED_BYTES64,
780 TCA_CAKE_TIN_STATS_BACKLOG_PACKETS,
781 TCA_CAKE_TIN_STATS_BACKLOG_BYTES,
782 TCA_CAKE_TIN_STATS_THRESHOLD_RATE64,
783 TCA_CAKE_TIN_STATS_TARGET_US,
784 TCA_CAKE_TIN_STATS_INTERVAL_US,
785 TCA_CAKE_TIN_STATS_WAY_INDIRECT_HITS,
786 TCA_CAKE_TIN_STATS_WAY_MISSES,
787 TCA_CAKE_TIN_STATS_WAY_COLLISIONS,
788 TCA_CAKE_TIN_STATS_PEAK_DELAY_US,
789 TCA_CAKE_TIN_STATS_AVG_DELAY_US,
790 TCA_CAKE_TIN_STATS_BASE_DELAY_US,
791 TCA_CAKE_TIN_STATS_SPARSE_FLOWS,
792 TCA_CAKE_TIN_STATS_BULK_FLOWS,
793 TCA_CAKE_TIN_STATS_UNRESPONSIVE_FLOWS,
794 TCA_CAKE_TIN_STATS_MAX_SKBLEN,
795 TCA_CAKE_TIN_STATS_FLOW_QUANTUM,
796 __TCA_CAKE_TIN_STATS_MAX
797};
798#define TCA_CAKE_TIN_STATS_MAX (__TCA_CAKE_TIN_STATS_MAX - 1)
799#define TC_CAKE_MAX_TINS (8)
800enum {
801 CAKE_FLOW_NONE = 0,
802 CAKE_FLOW_SRC_IP,
803 CAKE_FLOW_DST_IP,
804 CAKE_FLOW_HOSTS,
805 CAKE_FLOW_FLOWS,
806 CAKE_FLOW_DUAL_SRC,
807 CAKE_FLOW_DUAL_DST,
808 CAKE_FLOW_TRIPLE,
809 CAKE_FLOW_MAX,
810};
811enum {
812 CAKE_DIFFSERV_DIFFSERV3 = 0,
813 CAKE_DIFFSERV_DIFFSERV4,
814 CAKE_DIFFSERV_DIFFSERV8,
815 CAKE_DIFFSERV_BESTEFFORT,
816 CAKE_DIFFSERV_PRECEDENCE,
817 CAKE_DIFFSERV_MAX
818};
819enum {
820 CAKE_ACK_NONE = 0,
821 CAKE_ACK_FILTER,
822 CAKE_ACK_AGGRESSIVE,
823 CAKE_ACK_MAX
824};
825enum {
826 CAKE_ATM_NONE = 0,
827 CAKE_ATM_ATM,
828 CAKE_ATM_PTM,
829 CAKE_ATM_MAX
830};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800831#endif