pkt_sched.h revision 96c1db7b9d601c31d103389cac074a6cce0d7633
1/****************************************************************************
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#define TC_PRIO_FILLER 1
24#define TC_PRIO_BULK 2
25#define TC_PRIO_INTERACTIVE_BULK 4
26#define TC_PRIO_INTERACTIVE 6
27#define TC_PRIO_CONTROL 7
28#define TC_PRIO_MAX 15
29struct tc_stats {
30  __u64 bytes;
31  __u32 packets;
32  __u32 drops;
33  __u32 overlimits;
34  __u32 bps;
35  __u32 pps;
36  __u32 qlen;
37  __u32 backlog;
38};
39struct tc_estimator {
40  signed char interval;
41  unsigned char ewma_log;
42};
43#define TC_H_MAJ_MASK (0xFFFF0000U)
44#define TC_H_MIN_MASK (0x0000FFFFU)
45#define TC_H_MAJ(h) ((h) & TC_H_MAJ_MASK)
46#define TC_H_MIN(h) ((h) & TC_H_MIN_MASK)
47#define TC_H_MAKE(maj,min) (((maj) & TC_H_MAJ_MASK) | ((min) & TC_H_MIN_MASK))
48#define TC_H_UNSPEC (0U)
49#define TC_H_ROOT (0xFFFFFFFFU)
50#define TC_H_INGRESS (0xFFFFFFF1U)
51#define TC_H_CLSACT TC_H_INGRESS
52#define TC_H_MIN_INGRESS 0xFFF2U
53#define TC_H_MIN_EGRESS 0xFFF3U
54enum tc_link_layer {
55  TC_LINKLAYER_UNAWARE,
56  TC_LINKLAYER_ETHERNET,
57  TC_LINKLAYER_ATM,
58};
59#define TC_LINKLAYER_MASK 0x0F
60struct tc_ratespec {
61  unsigned char cell_log;
62  __u8 linklayer;
63  unsigned short overhead;
64  short cell_align;
65  unsigned short mpu;
66  __u32 rate;
67};
68#define TC_RTAB_SIZE 1024
69struct tc_sizespec {
70  unsigned char cell_log;
71  unsigned char size_log;
72  short cell_align;
73  int overhead;
74  unsigned int linklayer;
75  unsigned int mpu;
76  unsigned int mtu;
77  unsigned int tsize;
78};
79enum {
80  TCA_STAB_UNSPEC,
81  TCA_STAB_BASE,
82  TCA_STAB_DATA,
83  __TCA_STAB_MAX
84};
85#define TCA_STAB_MAX (__TCA_STAB_MAX - 1)
86struct tc_fifo_qopt {
87  __u32 limit;
88};
89#define TCQ_PRIO_BANDS 16
90#define TCQ_MIN_PRIO_BANDS 2
91struct tc_prio_qopt {
92  int bands;
93  __u8 priomap[TC_PRIO_MAX + 1];
94};
95struct tc_multiq_qopt {
96  __u16 bands;
97  __u16 max_bands;
98};
99#define TCQ_PLUG_BUFFER 0
100#define TCQ_PLUG_RELEASE_ONE 1
101#define TCQ_PLUG_RELEASE_INDEFINITE 2
102#define TCQ_PLUG_LIMIT 3
103struct tc_plug_qopt {
104  int action;
105  __u32 limit;
106};
107struct tc_tbf_qopt {
108  struct tc_ratespec rate;
109  struct tc_ratespec peakrate;
110  __u32 limit;
111  __u32 buffer;
112  __u32 mtu;
113};
114enum {
115  TCA_TBF_UNSPEC,
116  TCA_TBF_PARMS,
117  TCA_TBF_RTAB,
118  TCA_TBF_PTAB,
119  TCA_TBF_RATE64,
120  TCA_TBF_PRATE64,
121  TCA_TBF_BURST,
122  TCA_TBF_PBURST,
123  TCA_TBF_PAD,
124  __TCA_TBF_MAX,
125};
126#define TCA_TBF_MAX (__TCA_TBF_MAX - 1)
127struct tc_sfq_qopt {
128  unsigned quantum;
129  int perturb_period;
130  __u32 limit;
131  unsigned divisor;
132  unsigned flows;
133};
134struct tc_sfqred_stats {
135  __u32 prob_drop;
136  __u32 forced_drop;
137  __u32 prob_mark;
138  __u32 forced_mark;
139  __u32 prob_mark_head;
140  __u32 forced_mark_head;
141};
142struct tc_sfq_qopt_v1 {
143  struct tc_sfq_qopt v0;
144  unsigned int depth;
145  unsigned int headdrop;
146  __u32 limit;
147  __u32 qth_min;
148  __u32 qth_max;
149  unsigned char Wlog;
150  unsigned char Plog;
151  unsigned char Scell_log;
152  unsigned char flags;
153  __u32 max_P;
154  struct tc_sfqred_stats stats;
155};
156struct tc_sfq_xstats {
157  __s32 allot;
158};
159enum {
160  TCA_RED_UNSPEC,
161  TCA_RED_PARMS,
162  TCA_RED_STAB,
163  TCA_RED_MAX_P,
164  __TCA_RED_MAX,
165};
166#define TCA_RED_MAX (__TCA_RED_MAX - 1)
167struct tc_red_qopt {
168  __u32 limit;
169  __u32 qth_min;
170  __u32 qth_max;
171  unsigned char Wlog;
172  unsigned char Plog;
173  unsigned char Scell_log;
174  unsigned char flags;
175#define TC_RED_ECN 1
176#define TC_RED_HARDDROP 2
177#define TC_RED_ADAPTATIVE 4
178};
179struct tc_red_xstats {
180  __u32 early;
181  __u32 pdrop;
182  __u32 other;
183  __u32 marked;
184};
185#define MAX_DPs 16
186enum {
187  TCA_GRED_UNSPEC,
188  TCA_GRED_PARMS,
189  TCA_GRED_STAB,
190  TCA_GRED_DPS,
191  TCA_GRED_MAX_P,
192  TCA_GRED_LIMIT,
193  __TCA_GRED_MAX,
194};
195#define TCA_GRED_MAX (__TCA_GRED_MAX - 1)
196struct tc_gred_qopt {
197  __u32 limit;
198  __u32 qth_min;
199  __u32 qth_max;
200  __u32 DP;
201  __u32 backlog;
202  __u32 qave;
203  __u32 forced;
204  __u32 early;
205  __u32 other;
206  __u32 pdrop;
207  __u8 Wlog;
208  __u8 Plog;
209  __u8 Scell_log;
210  __u8 prio;
211  __u32 packets;
212  __u32 bytesin;
213};
214struct tc_gred_sopt {
215  __u32 DPs;
216  __u32 def_DP;
217  __u8 grio;
218  __u8 flags;
219  __u16 pad1;
220};
221enum {
222  TCA_CHOKE_UNSPEC,
223  TCA_CHOKE_PARMS,
224  TCA_CHOKE_STAB,
225  TCA_CHOKE_MAX_P,
226  __TCA_CHOKE_MAX,
227};
228#define TCA_CHOKE_MAX (__TCA_CHOKE_MAX - 1)
229struct tc_choke_qopt {
230  __u32 limit;
231  __u32 qth_min;
232  __u32 qth_max;
233  unsigned char Wlog;
234  unsigned char Plog;
235  unsigned char Scell_log;
236  unsigned char flags;
237};
238struct tc_choke_xstats {
239  __u32 early;
240  __u32 pdrop;
241  __u32 other;
242  __u32 marked;
243  __u32 matched;
244};
245#define TC_HTB_NUMPRIO 8
246#define TC_HTB_MAXDEPTH 8
247#define TC_HTB_PROTOVER 3
248struct tc_htb_opt {
249  struct tc_ratespec rate;
250  struct tc_ratespec ceil;
251  __u32 buffer;
252  __u32 cbuffer;
253  __u32 quantum;
254  __u32 level;
255  __u32 prio;
256};
257struct tc_htb_glob {
258  __u32 version;
259  __u32 rate2quantum;
260  __u32 defcls;
261  __u32 debug;
262  __u32 direct_pkts;
263};
264enum {
265  TCA_HTB_UNSPEC,
266  TCA_HTB_PARMS,
267  TCA_HTB_INIT,
268  TCA_HTB_CTAB,
269  TCA_HTB_RTAB,
270  TCA_HTB_DIRECT_QLEN,
271  TCA_HTB_RATE64,
272  TCA_HTB_CEIL64,
273  TCA_HTB_PAD,
274  __TCA_HTB_MAX,
275};
276#define TCA_HTB_MAX (__TCA_HTB_MAX - 1)
277struct tc_htb_xstats {
278  __u32 lends;
279  __u32 borrows;
280  __u32 giants;
281  __u32 tokens;
282  __u32 ctokens;
283};
284struct tc_hfsc_qopt {
285  __u16 defcls;
286};
287struct tc_service_curve {
288  __u32 m1;
289  __u32 d;
290  __u32 m2;
291};
292struct tc_hfsc_stats {
293  __u64 work;
294  __u64 rtwork;
295  __u32 period;
296  __u32 level;
297};
298enum {
299  TCA_HFSC_UNSPEC,
300  TCA_HFSC_RSC,
301  TCA_HFSC_FSC,
302  TCA_HFSC_USC,
303  __TCA_HFSC_MAX,
304};
305#define TCA_HFSC_MAX (__TCA_HFSC_MAX - 1)
306#define TC_CBQ_MAXPRIO 8
307#define TC_CBQ_MAXLEVEL 8
308#define TC_CBQ_DEF_EWMA 5
309struct tc_cbq_lssopt {
310  unsigned char change;
311  unsigned char flags;
312#define TCF_CBQ_LSS_BOUNDED 1
313#define TCF_CBQ_LSS_ISOLATED 2
314  unsigned char ewma_log;
315  unsigned char level;
316#define TCF_CBQ_LSS_FLAGS 1
317#define TCF_CBQ_LSS_EWMA 2
318#define TCF_CBQ_LSS_MAXIDLE 4
319#define TCF_CBQ_LSS_MINIDLE 8
320#define TCF_CBQ_LSS_OFFTIME 0x10
321#define TCF_CBQ_LSS_AVPKT 0x20
322  __u32 maxidle;
323  __u32 minidle;
324  __u32 offtime;
325  __u32 avpkt;
326};
327struct tc_cbq_wrropt {
328  unsigned char flags;
329  unsigned char priority;
330  unsigned char cpriority;
331  unsigned char __reserved;
332  __u32 allot;
333  __u32 weight;
334};
335struct tc_cbq_ovl {
336  unsigned char strategy;
337#define TC_CBQ_OVL_CLASSIC 0
338#define TC_CBQ_OVL_DELAY 1
339#define TC_CBQ_OVL_LOWPRIO 2
340#define TC_CBQ_OVL_DROP 3
341#define TC_CBQ_OVL_RCLASSIC 4
342  unsigned char priority2;
343  __u16 pad;
344  __u32 penalty;
345};
346struct tc_cbq_police {
347  unsigned char police;
348  unsigned char __res1;
349  unsigned short __res2;
350};
351struct tc_cbq_fopt {
352  __u32 split;
353  __u32 defmap;
354  __u32 defchange;
355};
356struct tc_cbq_xstats {
357  __u32 borrows;
358  __u32 overactions;
359  __s32 avgidle;
360  __s32 undertime;
361};
362enum {
363  TCA_CBQ_UNSPEC,
364  TCA_CBQ_LSSOPT,
365  TCA_CBQ_WRROPT,
366  TCA_CBQ_FOPT,
367  TCA_CBQ_OVL_STRATEGY,
368  TCA_CBQ_RATE,
369  TCA_CBQ_RTAB,
370  TCA_CBQ_POLICE,
371  __TCA_CBQ_MAX,
372};
373#define TCA_CBQ_MAX (__TCA_CBQ_MAX - 1)
374enum {
375  TCA_DSMARK_UNSPEC,
376  TCA_DSMARK_INDICES,
377  TCA_DSMARK_DEFAULT_INDEX,
378  TCA_DSMARK_SET_TC_INDEX,
379  TCA_DSMARK_MASK,
380  TCA_DSMARK_VALUE,
381  __TCA_DSMARK_MAX,
382};
383#define TCA_DSMARK_MAX (__TCA_DSMARK_MAX - 1)
384enum {
385  TCA_ATM_UNSPEC,
386  TCA_ATM_FD,
387  TCA_ATM_PTR,
388  TCA_ATM_HDR,
389  TCA_ATM_EXCESS,
390  TCA_ATM_ADDR,
391  TCA_ATM_STATE,
392  __TCA_ATM_MAX,
393};
394#define TCA_ATM_MAX (__TCA_ATM_MAX - 1)
395enum {
396  TCA_NETEM_UNSPEC,
397  TCA_NETEM_CORR,
398  TCA_NETEM_DELAY_DIST,
399  TCA_NETEM_REORDER,
400  TCA_NETEM_CORRUPT,
401  TCA_NETEM_LOSS,
402  TCA_NETEM_RATE,
403  TCA_NETEM_ECN,
404  TCA_NETEM_RATE64,
405  TCA_NETEM_PAD,
406  __TCA_NETEM_MAX,
407};
408#define TCA_NETEM_MAX (__TCA_NETEM_MAX - 1)
409struct tc_netem_qopt {
410  __u32 latency;
411  __u32 limit;
412  __u32 loss;
413  __u32 gap;
414  __u32 duplicate;
415  __u32 jitter;
416};
417struct tc_netem_corr {
418  __u32 delay_corr;
419  __u32 loss_corr;
420  __u32 dup_corr;
421};
422struct tc_netem_reorder {
423  __u32 probability;
424  __u32 correlation;
425};
426struct tc_netem_corrupt {
427  __u32 probability;
428  __u32 correlation;
429};
430struct tc_netem_rate {
431  __u32 rate;
432  __s32 packet_overhead;
433  __u32 cell_size;
434  __s32 cell_overhead;
435};
436enum {
437  NETEM_LOSS_UNSPEC,
438  NETEM_LOSS_GI,
439  NETEM_LOSS_GE,
440  __NETEM_LOSS_MAX
441};
442#define NETEM_LOSS_MAX (__NETEM_LOSS_MAX - 1)
443struct tc_netem_gimodel {
444  __u32 p13;
445  __u32 p31;
446  __u32 p32;
447  __u32 p14;
448  __u32 p23;
449};
450struct tc_netem_gemodel {
451  __u32 p;
452  __u32 r;
453  __u32 h;
454  __u32 k1;
455};
456#define NETEM_DIST_SCALE 8192
457#define NETEM_DIST_MAX 16384
458enum {
459  TCA_DRR_UNSPEC,
460  TCA_DRR_QUANTUM,
461  __TCA_DRR_MAX
462};
463#define TCA_DRR_MAX (__TCA_DRR_MAX - 1)
464struct tc_drr_stats {
465  __u32 deficit;
466};
467#define TC_QOPT_BITMASK 15
468#define TC_QOPT_MAX_QUEUE 16
469struct tc_mqprio_qopt {
470  __u8 num_tc;
471  __u8 prio_tc_map[TC_QOPT_BITMASK + 1];
472  __u8 hw;
473  __u16 count[TC_QOPT_MAX_QUEUE];
474  __u16 offset[TC_QOPT_MAX_QUEUE];
475};
476enum {
477  TCA_SFB_UNSPEC,
478  TCA_SFB_PARMS,
479  __TCA_SFB_MAX,
480};
481#define TCA_SFB_MAX (__TCA_SFB_MAX - 1)
482struct tc_sfb_qopt {
483  __u32 rehash_interval;
484  __u32 warmup_time;
485  __u32 max;
486  __u32 bin_size;
487  __u32 increment;
488  __u32 decrement;
489  __u32 limit;
490  __u32 penalty_rate;
491  __u32 penalty_burst;
492};
493struct tc_sfb_xstats {
494  __u32 earlydrop;
495  __u32 penaltydrop;
496  __u32 bucketdrop;
497  __u32 queuedrop;
498  __u32 childdrop;
499  __u32 marked;
500  __u32 maxqlen;
501  __u32 maxprob;
502  __u32 avgprob;
503};
504#define SFB_MAX_PROB 0xFFFF
505enum {
506  TCA_QFQ_UNSPEC,
507  TCA_QFQ_WEIGHT,
508  TCA_QFQ_LMAX,
509  __TCA_QFQ_MAX
510};
511#define TCA_QFQ_MAX (__TCA_QFQ_MAX - 1)
512struct tc_qfq_stats {
513  __u32 weight;
514  __u32 lmax;
515};
516enum {
517  TCA_CODEL_UNSPEC,
518  TCA_CODEL_TARGET,
519  TCA_CODEL_LIMIT,
520  TCA_CODEL_INTERVAL,
521  TCA_CODEL_ECN,
522  TCA_CODEL_CE_THRESHOLD,
523  __TCA_CODEL_MAX
524};
525#define TCA_CODEL_MAX (__TCA_CODEL_MAX - 1)
526struct tc_codel_xstats {
527  __u32 maxpacket;
528  __u32 count;
529  __u32 lastcount;
530  __u32 ldelay;
531  __s32 drop_next;
532  __u32 drop_overlimit;
533  __u32 ecn_mark;
534  __u32 dropping;
535  __u32 ce_mark;
536};
537enum {
538  TCA_FQ_CODEL_UNSPEC,
539  TCA_FQ_CODEL_TARGET,
540  TCA_FQ_CODEL_LIMIT,
541  TCA_FQ_CODEL_INTERVAL,
542  TCA_FQ_CODEL_ECN,
543  TCA_FQ_CODEL_FLOWS,
544  TCA_FQ_CODEL_QUANTUM,
545  TCA_FQ_CODEL_CE_THRESHOLD,
546  TCA_FQ_CODEL_DROP_BATCH_SIZE,
547  TCA_FQ_CODEL_MEMORY_LIMIT,
548  __TCA_FQ_CODEL_MAX
549};
550#define TCA_FQ_CODEL_MAX (__TCA_FQ_CODEL_MAX - 1)
551enum {
552  TCA_FQ_CODEL_XSTATS_QDISC,
553  TCA_FQ_CODEL_XSTATS_CLASS,
554};
555struct tc_fq_codel_qd_stats {
556  __u32 maxpacket;
557  __u32 drop_overlimit;
558  __u32 ecn_mark;
559  __u32 new_flow_count;
560  __u32 new_flows_len;
561  __u32 old_flows_len;
562  __u32 ce_mark;
563  __u32 memory_usage;
564  __u32 drop_overmemory;
565};
566struct tc_fq_codel_cl_stats {
567  __s32 deficit;
568  __u32 ldelay;
569  __u32 count;
570  __u32 lastcount;
571  __u32 dropping;
572  __s32 drop_next;
573};
574struct tc_fq_codel_xstats {
575  __u32 type;
576  union {
577    struct tc_fq_codel_qd_stats qdisc_stats;
578    struct tc_fq_codel_cl_stats class_stats;
579  };
580};
581enum {
582  TCA_FQ_UNSPEC,
583  TCA_FQ_PLIMIT,
584  TCA_FQ_FLOW_PLIMIT,
585  TCA_FQ_QUANTUM,
586  TCA_FQ_INITIAL_QUANTUM,
587  TCA_FQ_RATE_ENABLE,
588  TCA_FQ_FLOW_DEFAULT_RATE,
589  TCA_FQ_FLOW_MAX_RATE,
590  TCA_FQ_BUCKETS_LOG,
591  TCA_FQ_FLOW_REFILL_DELAY,
592  TCA_FQ_ORPHAN_MASK,
593  TCA_FQ_LOW_RATE_THRESHOLD,
594  __TCA_FQ_MAX
595};
596#define TCA_FQ_MAX (__TCA_FQ_MAX - 1)
597struct tc_fq_qd_stats {
598  __u64 gc_flows;
599  __u64 highprio_packets;
600  __u64 tcp_retrans;
601  __u64 throttled;
602  __u64 flows_plimit;
603  __u64 pkts_too_long;
604  __u64 allocation_errors;
605  __s64 time_next_delayed_flow;
606  __u32 flows;
607  __u32 inactive_flows;
608  __u32 throttled_flows;
609  __u32 unthrottle_latency_ns;
610};
611enum {
612  TCA_HHF_UNSPEC,
613  TCA_HHF_BACKLOG_LIMIT,
614  TCA_HHF_QUANTUM,
615  TCA_HHF_HH_FLOWS_LIMIT,
616  TCA_HHF_RESET_TIMEOUT,
617  TCA_HHF_ADMIT_BYTES,
618  TCA_HHF_EVICT_TIMEOUT,
619  TCA_HHF_NON_HH_WEIGHT,
620  __TCA_HHF_MAX
621};
622#define TCA_HHF_MAX (__TCA_HHF_MAX - 1)
623struct tc_hhf_xstats {
624  __u32 drop_overlimit;
625  __u32 hh_overlimit;
626  __u32 hh_tot_count;
627  __u32 hh_cur_count;
628};
629enum {
630  TCA_PIE_UNSPEC,
631  TCA_PIE_TARGET,
632  TCA_PIE_LIMIT,
633  TCA_PIE_TUPDATE,
634  TCA_PIE_ALPHA,
635  TCA_PIE_BETA,
636  TCA_PIE_ECN,
637  TCA_PIE_BYTEMODE,
638  __TCA_PIE_MAX
639};
640#define TCA_PIE_MAX (__TCA_PIE_MAX - 1)
641struct tc_pie_xstats {
642  __u32 prob;
643  __u32 delay;
644  __u32 avg_dq_rate;
645  __u32 packets_in;
646  __u32 dropped;
647  __u32 overlimit;
648  __u32 maxq;
649  __u32 ecn_mark;
650};
651#endif
652