blob: 5b64096f1b00dec5d973e2386281532c65e90e57 [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
23/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
24#define TC_PRIO_FILLER 1
25#define TC_PRIO_BULK 2
26#define TC_PRIO_INTERACTIVE_BULK 4
27#define TC_PRIO_INTERACTIVE 6
28/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
29#define TC_PRIO_CONTROL 7
30#define TC_PRIO_MAX 15
31struct tc_stats {
32 __u64 bytes;
33/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
34 __u32 packets;
35 __u32 drops;
36 __u32 overlimits;
37 __u32 bps;
38/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
39 __u32 pps;
40 __u32 qlen;
41 __u32 backlog;
42};
43/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
44struct tc_estimator {
45 signed char interval;
46 unsigned char ewma_log;
47};
48/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
49#define TC_H_MAJ_MASK (0xFFFF0000U)
50#define TC_H_MIN_MASK (0x0000FFFFU)
51#define TC_H_MAJ(h) ((h)&TC_H_MAJ_MASK)
52#define TC_H_MIN(h) ((h)&TC_H_MIN_MASK)
53/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
54#define TC_H_MAKE(maj,min) (((maj)&TC_H_MAJ_MASK)|((min)&TC_H_MIN_MASK))
55#define TC_H_UNSPEC (0U)
56#define TC_H_ROOT (0xFFFFFFFFU)
57#define TC_H_INGRESS (0xFFFFFFF1U)
58/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -070059enum tc_link_layer {
60 TC_LINKLAYER_UNAWARE,
61 TC_LINKLAYER_ETHERNET,
62 TC_LINKLAYER_ATM,
63/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
64};
65#define TC_LINKLAYER_MASK 0x0F
Ben Cheng655a7c02013-10-16 16:09:24 -070066struct tc_ratespec {
67 unsigned char cell_log;
Elliott Hughes8cb52b02013-11-21 13:43:23 -080068/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -070069 __u8 linklayer;
70 unsigned short overhead;
Ben Cheng655a7c02013-10-16 16:09:24 -070071 short cell_align;
72 unsigned short mpu;
Christopher Ferris38062f92014-07-09 15:33:25 -070073/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -070074 __u32 rate;
75};
76#define TC_RTAB_SIZE 1024
77struct tc_sizespec {
Christopher Ferris38062f92014-07-09 15:33:25 -070078/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -070079 unsigned char cell_log;
80 unsigned char size_log;
81 short cell_align;
82 int overhead;
Christopher Ferris38062f92014-07-09 15:33:25 -070083/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -070084 unsigned int linklayer;
85 unsigned int mpu;
86 unsigned int mtu;
87 unsigned int tsize;
Christopher Ferris38062f92014-07-09 15:33:25 -070088/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -070089};
90enum {
91 TCA_STAB_UNSPEC,
92 TCA_STAB_BASE,
Christopher Ferris38062f92014-07-09 15:33:25 -070093/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -070094 TCA_STAB_DATA,
95 __TCA_STAB_MAX
96};
97#define TCA_STAB_MAX (__TCA_STAB_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -070098/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -070099struct tc_fifo_qopt {
100 __u32 limit;
101};
102#define TCQ_PRIO_BANDS 16
Christopher Ferris38062f92014-07-09 15:33:25 -0700103/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700104#define TCQ_MIN_PRIO_BANDS 2
105struct tc_prio_qopt {
106 int bands;
107 __u8 priomap[TC_PRIO_MAX+1];
Christopher Ferris38062f92014-07-09 15:33:25 -0700108/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700109};
110struct tc_multiq_qopt {
111 __u16 bands;
112 __u16 max_bands;
Christopher Ferris38062f92014-07-09 15:33:25 -0700113/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700114};
115#define TCQ_PLUG_BUFFER 0
116#define TCQ_PLUG_RELEASE_ONE 1
117#define TCQ_PLUG_RELEASE_INDEFINITE 2
Christopher Ferris38062f92014-07-09 15:33:25 -0700118/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700119#define TCQ_PLUG_LIMIT 3
120struct tc_plug_qopt {
121 int action;
122 __u32 limit;
Christopher Ferris38062f92014-07-09 15:33:25 -0700123/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700124};
125struct tc_tbf_qopt {
126 struct tc_ratespec rate;
127 struct tc_ratespec peakrate;
Christopher Ferris38062f92014-07-09 15:33:25 -0700128/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700129 __u32 limit;
130 __u32 buffer;
131 __u32 mtu;
132};
Christopher Ferris38062f92014-07-09 15:33:25 -0700133/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700134enum {
135 TCA_TBF_UNSPEC,
136 TCA_TBF_PARMS,
137 TCA_TBF_RTAB,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800138/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700139 TCA_TBF_PTAB,
140 TCA_TBF_RATE64,
141 TCA_TBF_PRATE64,
142 TCA_TBF_BURST,
143/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
144 TCA_TBF_PBURST,
145 __TCA_TBF_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700146};
147#define TCA_TBF_MAX (__TCA_TBF_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700148/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700149struct tc_sfq_qopt {
150 unsigned quantum;
151 int perturb_period;
152 __u32 limit;
Christopher Ferris38062f92014-07-09 15:33:25 -0700153/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700154 unsigned divisor;
155 unsigned flows;
156};
157struct tc_sfqred_stats {
Christopher Ferris38062f92014-07-09 15:33:25 -0700158/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700159 __u32 prob_drop;
160 __u32 forced_drop;
161 __u32 prob_mark;
162 __u32 forced_mark;
Christopher Ferris38062f92014-07-09 15:33:25 -0700163/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700164 __u32 prob_mark_head;
165 __u32 forced_mark_head;
166};
167struct tc_sfq_qopt_v1 {
Christopher Ferris38062f92014-07-09 15:33:25 -0700168/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700169 struct tc_sfq_qopt v0;
170 unsigned int depth;
171 unsigned int headdrop;
172 __u32 limit;
Christopher Ferris38062f92014-07-09 15:33:25 -0700173/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700174 __u32 qth_min;
175 __u32 qth_max;
176 unsigned char Wlog;
177 unsigned char Plog;
Christopher Ferris38062f92014-07-09 15:33:25 -0700178/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700179 unsigned char Scell_log;
180 unsigned char flags;
181 __u32 max_P;
182 struct tc_sfqred_stats stats;
Christopher Ferris38062f92014-07-09 15:33:25 -0700183/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700184};
185struct tc_sfq_xstats {
186 __s32 allot;
187};
Christopher Ferris38062f92014-07-09 15:33:25 -0700188/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700189enum {
190 TCA_RED_UNSPEC,
191 TCA_RED_PARMS,
192 TCA_RED_STAB,
Christopher Ferris38062f92014-07-09 15:33:25 -0700193/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700194 TCA_RED_MAX_P,
195 __TCA_RED_MAX,
196};
197#define TCA_RED_MAX (__TCA_RED_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700198/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700199struct tc_red_qopt {
200 __u32 limit;
201 __u32 qth_min;
202 __u32 qth_max;
Christopher Ferris38062f92014-07-09 15:33:25 -0700203/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700204 unsigned char Wlog;
205 unsigned char Plog;
206 unsigned char Scell_log;
207 unsigned char flags;
Christopher Ferris38062f92014-07-09 15:33:25 -0700208/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700209#define TC_RED_ECN 1
210#define TC_RED_HARDDROP 2
211#define TC_RED_ADAPTATIVE 4
212};
Christopher Ferris38062f92014-07-09 15:33:25 -0700213/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700214struct tc_red_xstats {
215 __u32 early;
216 __u32 pdrop;
217 __u32 other;
Christopher Ferris38062f92014-07-09 15:33:25 -0700218/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700219 __u32 marked;
220};
221#define MAX_DPs 16
222enum {
Christopher Ferris38062f92014-07-09 15:33:25 -0700223/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700224 TCA_GRED_UNSPEC,
225 TCA_GRED_PARMS,
226 TCA_GRED_STAB,
227 TCA_GRED_DPS,
Christopher Ferris38062f92014-07-09 15:33:25 -0700228/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700229 TCA_GRED_MAX_P,
230 __TCA_GRED_MAX,
231};
232#define TCA_GRED_MAX (__TCA_GRED_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700233/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700234struct tc_gred_qopt {
235 __u32 limit;
236 __u32 qth_min;
237 __u32 qth_max;
Christopher Ferris38062f92014-07-09 15:33:25 -0700238/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700239 __u32 DP;
240 __u32 backlog;
241 __u32 qave;
242 __u32 forced;
Christopher Ferris38062f92014-07-09 15:33:25 -0700243/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700244 __u32 early;
245 __u32 other;
246 __u32 pdrop;
247 __u8 Wlog;
Christopher Ferris38062f92014-07-09 15:33:25 -0700248/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700249 __u8 Plog;
250 __u8 Scell_log;
251 __u8 prio;
252 __u32 packets;
Christopher Ferris38062f92014-07-09 15:33:25 -0700253/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700254 __u32 bytesin;
255};
256struct tc_gred_sopt {
257 __u32 DPs;
Christopher Ferris38062f92014-07-09 15:33:25 -0700258/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700259 __u32 def_DP;
260 __u8 grio;
261 __u8 flags;
262 __u16 pad1;
Christopher Ferris38062f92014-07-09 15:33:25 -0700263/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700264};
265enum {
266 TCA_CHOKE_UNSPEC,
267 TCA_CHOKE_PARMS,
Christopher Ferris38062f92014-07-09 15:33:25 -0700268/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700269 TCA_CHOKE_STAB,
270 TCA_CHOKE_MAX_P,
271 __TCA_CHOKE_MAX,
272};
Christopher Ferris38062f92014-07-09 15:33:25 -0700273/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700274#define TCA_CHOKE_MAX (__TCA_CHOKE_MAX - 1)
275struct tc_choke_qopt {
276 __u32 limit;
277 __u32 qth_min;
Christopher Ferris38062f92014-07-09 15:33:25 -0700278/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700279 __u32 qth_max;
280 unsigned char Wlog;
281 unsigned char Plog;
282 unsigned char Scell_log;
Christopher Ferris38062f92014-07-09 15:33:25 -0700283/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700284 unsigned char flags;
285};
286struct tc_choke_xstats {
287 __u32 early;
Christopher Ferris38062f92014-07-09 15:33:25 -0700288/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700289 __u32 pdrop;
290 __u32 other;
291 __u32 marked;
292 __u32 matched;
Christopher Ferris38062f92014-07-09 15:33:25 -0700293/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700294};
295#define TC_HTB_NUMPRIO 8
296#define TC_HTB_MAXDEPTH 8
297#define TC_HTB_PROTOVER 3
Christopher Ferris38062f92014-07-09 15:33:25 -0700298/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700299struct tc_htb_opt {
300 struct tc_ratespec rate;
301 struct tc_ratespec ceil;
302 __u32 buffer;
Christopher Ferris38062f92014-07-09 15:33:25 -0700303/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700304 __u32 cbuffer;
305 __u32 quantum;
306 __u32 level;
307 __u32 prio;
Christopher Ferris38062f92014-07-09 15:33:25 -0700308/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700309};
310struct tc_htb_glob {
311 __u32 version;
312 __u32 rate2quantum;
Christopher Ferris38062f92014-07-09 15:33:25 -0700313/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700314 __u32 defcls;
315 __u32 debug;
316 __u32 direct_pkts;
317};
Christopher Ferris38062f92014-07-09 15:33:25 -0700318/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700319enum {
320 TCA_HTB_UNSPEC,
321 TCA_HTB_PARMS,
322 TCA_HTB_INIT,
Christopher Ferris38062f92014-07-09 15:33:25 -0700323/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700324 TCA_HTB_CTAB,
325 TCA_HTB_RTAB,
326 TCA_HTB_DIRECT_QLEN,
Christopher Ferris38062f92014-07-09 15:33:25 -0700327 TCA_HTB_RATE64,
328/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
329 TCA_HTB_CEIL64,
Ben Cheng655a7c02013-10-16 16:09:24 -0700330 __TCA_HTB_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700331};
332#define TCA_HTB_MAX (__TCA_HTB_MAX - 1)
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800333/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700334struct tc_htb_xstats {
335 __u32 lends;
Ben Cheng655a7c02013-10-16 16:09:24 -0700336 __u32 borrows;
337 __u32 giants;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800338/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700339 __u32 tokens;
340 __u32 ctokens;
Ben Cheng655a7c02013-10-16 16:09:24 -0700341};
342struct tc_hfsc_qopt {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800343/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700344 __u16 defcls;
345};
Ben Cheng655a7c02013-10-16 16:09:24 -0700346struct tc_service_curve {
347 __u32 m1;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800348/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700349 __u32 d;
350 __u32 m2;
Ben Cheng655a7c02013-10-16 16:09:24 -0700351};
352struct tc_hfsc_stats {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800353/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700354 __u64 work;
355 __u64 rtwork;
Ben Cheng655a7c02013-10-16 16:09:24 -0700356 __u32 period;
357 __u32 level;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800358/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700359};
360enum {
Ben Cheng655a7c02013-10-16 16:09:24 -0700361 TCA_HFSC_UNSPEC,
362 TCA_HFSC_RSC,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800363/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700364 TCA_HFSC_FSC,
365 TCA_HFSC_USC,
Ben Cheng655a7c02013-10-16 16:09:24 -0700366 __TCA_HFSC_MAX,
367};
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800368/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700369#define TCA_HFSC_MAX (__TCA_HFSC_MAX - 1)
370#define TC_CBQ_MAXPRIO 8
Ben Cheng655a7c02013-10-16 16:09:24 -0700371#define TC_CBQ_MAXLEVEL 8
372#define TC_CBQ_DEF_EWMA 5
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800373/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700374struct tc_cbq_lssopt {
375 unsigned char change;
Ben Cheng655a7c02013-10-16 16:09:24 -0700376 unsigned char flags;
377#define TCF_CBQ_LSS_BOUNDED 1
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800378/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700379#define TCF_CBQ_LSS_ISOLATED 2
380 unsigned char ewma_log;
Ben Cheng655a7c02013-10-16 16:09:24 -0700381 unsigned char level;
382#define TCF_CBQ_LSS_FLAGS 1
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800383/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700384#define TCF_CBQ_LSS_EWMA 2
385#define TCF_CBQ_LSS_MAXIDLE 4
Ben Cheng655a7c02013-10-16 16:09:24 -0700386#define TCF_CBQ_LSS_MINIDLE 8
387#define TCF_CBQ_LSS_OFFTIME 0x10
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800388/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700389#define TCF_CBQ_LSS_AVPKT 0x20
390 __u32 maxidle;
Ben Cheng655a7c02013-10-16 16:09:24 -0700391 __u32 minidle;
392 __u32 offtime;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800393/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700394 __u32 avpkt;
395};
Ben Cheng655a7c02013-10-16 16:09:24 -0700396struct tc_cbq_wrropt {
397 unsigned char flags;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800398/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700399 unsigned char priority;
400 unsigned char cpriority;
Ben Cheng655a7c02013-10-16 16:09:24 -0700401 unsigned char __reserved;
402 __u32 allot;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800403/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700404 __u32 weight;
405};
Ben Cheng655a7c02013-10-16 16:09:24 -0700406struct tc_cbq_ovl {
407 unsigned char strategy;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800408/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700409#define TC_CBQ_OVL_CLASSIC 0
410#define TC_CBQ_OVL_DELAY 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700411#define TC_CBQ_OVL_LOWPRIO 2
412#define TC_CBQ_OVL_DROP 3
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800413/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700414#define TC_CBQ_OVL_RCLASSIC 4
415 unsigned char priority2;
Ben Cheng655a7c02013-10-16 16:09:24 -0700416 __u16 pad;
417 __u32 penalty;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800418/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700419};
420struct tc_cbq_police {
Ben Cheng655a7c02013-10-16 16:09:24 -0700421 unsigned char police;
422 unsigned char __res1;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800423/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700424 unsigned short __res2;
425};
Ben Cheng655a7c02013-10-16 16:09:24 -0700426struct tc_cbq_fopt {
427 __u32 split;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800428/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700429 __u32 defmap;
430 __u32 defchange;
Ben Cheng655a7c02013-10-16 16:09:24 -0700431};
432struct tc_cbq_xstats {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800433/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700434 __u32 borrows;
435 __u32 overactions;
Ben Cheng655a7c02013-10-16 16:09:24 -0700436 __s32 avgidle;
437 __s32 undertime;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800438/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700439};
440enum {
Ben Cheng655a7c02013-10-16 16:09:24 -0700441 TCA_CBQ_UNSPEC,
442 TCA_CBQ_LSSOPT,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800443/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700444 TCA_CBQ_WRROPT,
445 TCA_CBQ_FOPT,
Ben Cheng655a7c02013-10-16 16:09:24 -0700446 TCA_CBQ_OVL_STRATEGY,
447 TCA_CBQ_RATE,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800448/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700449 TCA_CBQ_RTAB,
450 TCA_CBQ_POLICE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700451 __TCA_CBQ_MAX,
452};
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800453/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700454#define TCA_CBQ_MAX (__TCA_CBQ_MAX - 1)
455enum {
Ben Cheng655a7c02013-10-16 16:09:24 -0700456 TCA_DSMARK_UNSPEC,
457 TCA_DSMARK_INDICES,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800458/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700459 TCA_DSMARK_DEFAULT_INDEX,
460 TCA_DSMARK_SET_TC_INDEX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700461 TCA_DSMARK_MASK,
462 TCA_DSMARK_VALUE,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800463/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700464 __TCA_DSMARK_MAX,
465};
Ben Cheng655a7c02013-10-16 16:09:24 -0700466#define TCA_DSMARK_MAX (__TCA_DSMARK_MAX - 1)
467enum {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800468/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700469 TCA_ATM_UNSPEC,
470 TCA_ATM_FD,
Ben Cheng655a7c02013-10-16 16:09:24 -0700471 TCA_ATM_PTR,
472 TCA_ATM_HDR,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800473/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700474 TCA_ATM_EXCESS,
475 TCA_ATM_ADDR,
Ben Cheng655a7c02013-10-16 16:09:24 -0700476 TCA_ATM_STATE,
477 __TCA_ATM_MAX,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800478/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700479};
480#define TCA_ATM_MAX (__TCA_ATM_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700481enum {
482 TCA_NETEM_UNSPEC,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800483/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700484 TCA_NETEM_CORR,
485 TCA_NETEM_DELAY_DIST,
Ben Cheng655a7c02013-10-16 16:09:24 -0700486 TCA_NETEM_REORDER,
487 TCA_NETEM_CORRUPT,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800488/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700489 TCA_NETEM_LOSS,
490 TCA_NETEM_RATE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700491 TCA_NETEM_ECN,
Christopher Ferris38062f92014-07-09 15:33:25 -0700492 TCA_NETEM_RATE64,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800493/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700494 __TCA_NETEM_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700495};
496#define TCA_NETEM_MAX (__TCA_NETEM_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700497struct tc_netem_qopt {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800498/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700499 __u32 latency;
Ben Cheng655a7c02013-10-16 16:09:24 -0700500 __u32 limit;
501 __u32 loss;
Ben Cheng655a7c02013-10-16 16:09:24 -0700502 __u32 gap;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800503/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700504 __u32 duplicate;
Ben Cheng655a7c02013-10-16 16:09:24 -0700505 __u32 jitter;
506};
Ben Cheng655a7c02013-10-16 16:09:24 -0700507struct tc_netem_corr {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800508/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700509 __u32 delay_corr;
Ben Cheng655a7c02013-10-16 16:09:24 -0700510 __u32 loss_corr;
511 __u32 dup_corr;
Ben Cheng655a7c02013-10-16 16:09:24 -0700512};
Christopher Ferris38062f92014-07-09 15:33:25 -0700513/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700514struct tc_netem_reorder {
515 __u32 probability;
516 __u32 correlation;
Ben Cheng655a7c02013-10-16 16:09:24 -0700517};
Christopher Ferris38062f92014-07-09 15:33:25 -0700518/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Ben Cheng655a7c02013-10-16 16:09:24 -0700519struct tc_netem_corrupt {
520 __u32 probability;
521 __u32 correlation;
Ben Cheng655a7c02013-10-16 16:09:24 -0700522};
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800523/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700524struct tc_netem_rate {
Ben Cheng655a7c02013-10-16 16:09:24 -0700525 __u32 rate;
526 __s32 packet_overhead;
Ben Cheng655a7c02013-10-16 16:09:24 -0700527 __u32 cell_size;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800528/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700529 __s32 cell_overhead;
Ben Cheng655a7c02013-10-16 16:09:24 -0700530};
531enum {
Ben Cheng655a7c02013-10-16 16:09:24 -0700532 NETEM_LOSS_UNSPEC,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800533/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700534 NETEM_LOSS_GI,
Ben Cheng655a7c02013-10-16 16:09:24 -0700535 NETEM_LOSS_GE,
536 __NETEM_LOSS_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700537};
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800538/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700539#define NETEM_LOSS_MAX (__NETEM_LOSS_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700540struct tc_netem_gimodel {
541 __u32 p13;
Ben Cheng655a7c02013-10-16 16:09:24 -0700542 __u32 p31;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800543/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700544 __u32 p32;
Ben Cheng655a7c02013-10-16 16:09:24 -0700545 __u32 p14;
546 __u32 p23;
Ben Cheng655a7c02013-10-16 16:09:24 -0700547};
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800548/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700549struct tc_netem_gemodel {
Ben Cheng655a7c02013-10-16 16:09:24 -0700550 __u32 p;
551 __u32 r;
Ben Cheng655a7c02013-10-16 16:09:24 -0700552 __u32 h;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800553/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700554 __u32 k1;
Ben Cheng655a7c02013-10-16 16:09:24 -0700555};
556#define NETEM_DIST_SCALE 8192
Ben Cheng655a7c02013-10-16 16:09:24 -0700557#define NETEM_DIST_MAX 16384
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800558/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700559enum {
Ben Cheng655a7c02013-10-16 16:09:24 -0700560 TCA_DRR_UNSPEC,
561 TCA_DRR_QUANTUM,
Ben Cheng655a7c02013-10-16 16:09:24 -0700562 __TCA_DRR_MAX
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800563/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700564};
Ben Cheng655a7c02013-10-16 16:09:24 -0700565#define TCA_DRR_MAX (__TCA_DRR_MAX - 1)
566struct tc_drr_stats {
Ben Cheng655a7c02013-10-16 16:09:24 -0700567 __u32 deficit;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800568/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700569};
Ben Cheng655a7c02013-10-16 16:09:24 -0700570#define TC_QOPT_BITMASK 15
571#define TC_QOPT_MAX_QUEUE 16
Ben Cheng655a7c02013-10-16 16:09:24 -0700572struct tc_mqprio_qopt {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800573/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700574 __u8 num_tc;
Ben Cheng655a7c02013-10-16 16:09:24 -0700575 __u8 prio_tc_map[TC_QOPT_BITMASK + 1];
576 __u8 hw;
Ben Cheng655a7c02013-10-16 16:09:24 -0700577 __u16 count[TC_QOPT_MAX_QUEUE];
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800578/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700579 __u16 offset[TC_QOPT_MAX_QUEUE];
Ben Cheng655a7c02013-10-16 16:09:24 -0700580};
581enum {
Ben Cheng655a7c02013-10-16 16:09:24 -0700582 TCA_SFB_UNSPEC,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800583/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700584 TCA_SFB_PARMS,
Ben Cheng655a7c02013-10-16 16:09:24 -0700585 __TCA_SFB_MAX,
586};
Ben Cheng655a7c02013-10-16 16:09:24 -0700587#define TCA_SFB_MAX (__TCA_SFB_MAX - 1)
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800588/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700589struct tc_sfb_qopt {
Ben Cheng655a7c02013-10-16 16:09:24 -0700590 __u32 rehash_interval;
591 __u32 warmup_time;
Ben Cheng655a7c02013-10-16 16:09:24 -0700592 __u32 max;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800593/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700594 __u32 bin_size;
Ben Cheng655a7c02013-10-16 16:09:24 -0700595 __u32 increment;
596 __u32 decrement;
Ben Cheng655a7c02013-10-16 16:09:24 -0700597 __u32 limit;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800598/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700599 __u32 penalty_rate;
Ben Cheng655a7c02013-10-16 16:09:24 -0700600 __u32 penalty_burst;
601};
Ben Cheng655a7c02013-10-16 16:09:24 -0700602struct tc_sfb_xstats {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800603/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700604 __u32 earlydrop;
Ben Cheng655a7c02013-10-16 16:09:24 -0700605 __u32 penaltydrop;
606 __u32 bucketdrop;
Ben Cheng655a7c02013-10-16 16:09:24 -0700607 __u32 queuedrop;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800608/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700609 __u32 childdrop;
Ben Cheng655a7c02013-10-16 16:09:24 -0700610 __u32 marked;
611 __u32 maxqlen;
Ben Cheng655a7c02013-10-16 16:09:24 -0700612 __u32 maxprob;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800613/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700614 __u32 avgprob;
Ben Cheng655a7c02013-10-16 16:09:24 -0700615};
616#define SFB_MAX_PROB 0xFFFF
Ben Cheng655a7c02013-10-16 16:09:24 -0700617enum {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800618/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700619 TCA_QFQ_UNSPEC,
Ben Cheng655a7c02013-10-16 16:09:24 -0700620 TCA_QFQ_WEIGHT,
621 TCA_QFQ_LMAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700622 __TCA_QFQ_MAX
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800623/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700624};
Ben Cheng655a7c02013-10-16 16:09:24 -0700625#define TCA_QFQ_MAX (__TCA_QFQ_MAX - 1)
626struct tc_qfq_stats {
Ben Cheng655a7c02013-10-16 16:09:24 -0700627 __u32 weight;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800628/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700629 __u32 lmax;
Ben Cheng655a7c02013-10-16 16:09:24 -0700630};
631enum {
Ben Cheng655a7c02013-10-16 16:09:24 -0700632 TCA_CODEL_UNSPEC,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800633/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700634 TCA_CODEL_TARGET,
Ben Cheng655a7c02013-10-16 16:09:24 -0700635 TCA_CODEL_LIMIT,
636 TCA_CODEL_INTERVAL,
Ben Cheng655a7c02013-10-16 16:09:24 -0700637 TCA_CODEL_ECN,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800638/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700639 __TCA_CODEL_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700640};
641#define TCA_CODEL_MAX (__TCA_CODEL_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700642struct tc_codel_xstats {
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800643/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700644 __u32 maxpacket;
Ben Cheng655a7c02013-10-16 16:09:24 -0700645 __u32 count;
646 __u32 lastcount;
Ben Cheng655a7c02013-10-16 16:09:24 -0700647 __u32 ldelay;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800648/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700649 __s32 drop_next;
Ben Cheng655a7c02013-10-16 16:09:24 -0700650 __u32 drop_overlimit;
651 __u32 ecn_mark;
Ben Cheng655a7c02013-10-16 16:09:24 -0700652 __u32 dropping;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800653/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700654};
Ben Cheng655a7c02013-10-16 16:09:24 -0700655enum {
656 TCA_FQ_CODEL_UNSPEC,
Ben Cheng655a7c02013-10-16 16:09:24 -0700657 TCA_FQ_CODEL_TARGET,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800658/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700659 TCA_FQ_CODEL_LIMIT,
Ben Cheng655a7c02013-10-16 16:09:24 -0700660 TCA_FQ_CODEL_INTERVAL,
661 TCA_FQ_CODEL_ECN,
Ben Cheng655a7c02013-10-16 16:09:24 -0700662 TCA_FQ_CODEL_FLOWS,
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800663/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700664 TCA_FQ_CODEL_QUANTUM,
Ben Cheng655a7c02013-10-16 16:09:24 -0700665 __TCA_FQ_CODEL_MAX
666};
Ben Cheng655a7c02013-10-16 16:09:24 -0700667#define TCA_FQ_CODEL_MAX (__TCA_FQ_CODEL_MAX - 1)
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800668/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700669enum {
Ben Cheng655a7c02013-10-16 16:09:24 -0700670 TCA_FQ_CODEL_XSTATS_QDISC,
671 TCA_FQ_CODEL_XSTATS_CLASS,
Ben Cheng655a7c02013-10-16 16:09:24 -0700672};
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800673/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700674struct tc_fq_codel_qd_stats {
Ben Cheng655a7c02013-10-16 16:09:24 -0700675 __u32 maxpacket;
676 __u32 drop_overlimit;
Ben Cheng655a7c02013-10-16 16:09:24 -0700677 __u32 ecn_mark;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800678/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700679 __u32 new_flow_count;
Ben Cheng655a7c02013-10-16 16:09:24 -0700680 __u32 new_flows_len;
681 __u32 old_flows_len;
Ben Cheng655a7c02013-10-16 16:09:24 -0700682};
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800683/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700684struct tc_fq_codel_cl_stats {
Ben Cheng655a7c02013-10-16 16:09:24 -0700685 __s32 deficit;
686 __u32 ldelay;
Ben Cheng655a7c02013-10-16 16:09:24 -0700687 __u32 count;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800688/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700689 __u32 lastcount;
Ben Cheng655a7c02013-10-16 16:09:24 -0700690 __u32 dropping;
691 __s32 drop_next;
Ben Cheng655a7c02013-10-16 16:09:24 -0700692};
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800693/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700694struct tc_fq_codel_xstats {
Ben Cheng655a7c02013-10-16 16:09:24 -0700695 __u32 type;
696 union {
Ben Cheng655a7c02013-10-16 16:09:24 -0700697 struct tc_fq_codel_qd_stats qdisc_stats;
Elliott Hughes8cb52b02013-11-21 13:43:23 -0800698/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris38062f92014-07-09 15:33:25 -0700699 struct tc_fq_codel_cl_stats class_stats;
Ben Cheng655a7c02013-10-16 16:09:24 -0700700 };
701};
Christopher Ferris38062f92014-07-09 15:33:25 -0700702enum {
703/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
704 TCA_FQ_UNSPEC,
705 TCA_FQ_PLIMIT,
706 TCA_FQ_FLOW_PLIMIT,
707 TCA_FQ_QUANTUM,
708/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
709 TCA_FQ_INITIAL_QUANTUM,
710 TCA_FQ_RATE_ENABLE,
711 TCA_FQ_FLOW_DEFAULT_RATE,
712 TCA_FQ_FLOW_MAX_RATE,
713/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
714 TCA_FQ_BUCKETS_LOG,
715 TCA_FQ_FLOW_REFILL_DELAY,
716 __TCA_FQ_MAX
717};
718/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
719#define TCA_FQ_MAX (__TCA_FQ_MAX - 1)
720struct tc_fq_qd_stats {
721 __u64 gc_flows;
722 __u64 highprio_packets;
723/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
724 __u64 tcp_retrans;
725 __u64 throttled;
726 __u64 flows_plimit;
727 __u64 pkts_too_long;
728/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
729 __u64 allocation_errors;
730 __s64 time_next_delayed_flow;
731 __u32 flows;
732 __u32 inactive_flows;
733/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
734 __u32 throttled_flows;
735 __u32 pad;
736};
737enum {
738/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
739 TCA_HHF_UNSPEC,
740 TCA_HHF_BACKLOG_LIMIT,
741 TCA_HHF_QUANTUM,
742 TCA_HHF_HH_FLOWS_LIMIT,
743/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
744 TCA_HHF_RESET_TIMEOUT,
745 TCA_HHF_ADMIT_BYTES,
746 TCA_HHF_EVICT_TIMEOUT,
747 TCA_HHF_NON_HH_WEIGHT,
748/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
749 __TCA_HHF_MAX
750};
751#define TCA_HHF_MAX (__TCA_HHF_MAX - 1)
752struct tc_hhf_xstats {
753/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
754 __u32 drop_overlimit;
755 __u32 hh_overlimit;
756 __u32 hh_tot_count;
757 __u32 hh_cur_count;
758/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
759};
760enum {
761 TCA_PIE_UNSPEC,
762 TCA_PIE_TARGET,
763/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
764 TCA_PIE_LIMIT,
765 TCA_PIE_TUPDATE,
766 TCA_PIE_ALPHA,
767 TCA_PIE_BETA,
768/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
769 TCA_PIE_ECN,
770 TCA_PIE_BYTEMODE,
771 __TCA_PIE_MAX
772};
773/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
774#define TCA_PIE_MAX (__TCA_PIE_MAX - 1)
775struct tc_pie_xstats {
776 __u32 prob;
777 __u32 delay;
778/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
779 __u32 avg_dq_rate;
780 __u32 packets_in;
781 __u32 dropped;
782 __u32 overlimit;
783/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
784 __u32 maxq;
785 __u32 ecn_mark;
786};
Ben Cheng655a7c02013-10-16 16:09:24 -0700787#endif
Christopher Ferris38062f92014-07-09 15:33:25 -0700788/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */