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