The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/altq/altq_cbq.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*      $NetBSD: altq_cbq.h,v 1.8 2006/10/12 19:59:08 peter Exp $       */
    2 /*      $KAME: altq_cbq.h,v 1.12 2003/10/03 05:05:15 kjc Exp $  */
    3 
    4 /*
    5  * Copyright (c) Sun Microsystems, Inc. 1993-1998 All rights reserved.
    6  *
    7  * Redistribution and use in source and binary forms, with or without
    8  * modification, are permitted provided that the following conditions
    9  * are met:
   10  *
   11  * 1. Redistributions of source code must retain the above copyright
   12  *    notice, this list of conditions and the following disclaimer.
   13  *
   14  * 2. Redistributions in binary form must reproduce the above copyright
   15  *    notice, this list of conditions and the following disclaimer in the
   16  *    documentation and/or other materials provided with the distribution.
   17  *
   18  * 3. All advertising materials mentioning features or use of this software
   19  *    must display the following acknowledgement:
   20  *      This product includes software developed by the SMCC Technology
   21  *      Development Group at Sun Microsystems, Inc.
   22  *
   23  * 4. The name of the Sun Microsystems, Inc nor may not be used to endorse or
   24  *      promote products derived from this software without specific prior
   25  *      written permission.
   26  *
   27  * SUN MICROSYSTEMS DOES NOT CLAIM MERCHANTABILITY OF THIS SOFTWARE OR THE
   28  * SUITABILITY OF THIS SOFTWARE FOR ANY PARTICULAR PURPOSE.  The software is
   29  * provided "as is" without express or implied warranty of any kind.
   30  *
   31  * These notices must be retained in any copies of any part of this software.
   32  */
   33 
   34 #ifndef _ALTQ_ALTQ_CBQ_H_
   35 #define _ALTQ_ALTQ_CBQ_H_
   36 
   37 #include <altq/altq.h>
   38 #include <altq/altq_rmclass.h>
   39 #include <altq/altq_red.h>
   40 #include <altq/altq_rio.h>
   41 
   42 #ifdef __cplusplus
   43 extern "C" {
   44 #endif
   45 
   46 #define NULL_CLASS_HANDLE       0
   47 
   48 /* class flags should be same as class flags in rm_class.h */
   49 #define CBQCLF_RED              0x0001  /* use RED */
   50 #define CBQCLF_ECN              0x0002  /* use RED/ECN */
   51 #define CBQCLF_RIO              0x0004  /* use RIO */
   52 #define CBQCLF_FLOWVALVE        0x0008  /* use flowvalve (aka penalty-box) */
   53 #define CBQCLF_CLEARDSCP        0x0010  /* clear diffserv codepoint */
   54 #define CBQCLF_BORROW           0x0020  /* borrow from parent */
   55 
   56 /* class flags only for root class */
   57 #define CBQCLF_WRR              0x0100  /* weighted-round robin */
   58 #define CBQCLF_EFFICIENT        0x0200  /* work-conserving */
   59 
   60 /* class flags for special classes */
   61 #define CBQCLF_ROOTCLASS        0x1000  /* root class */
   62 #define CBQCLF_DEFCLASS         0x2000  /* default class */
   63 #ifdef ALTQ3_COMPAT
   64 #define CBQCLF_CTLCLASS         0x4000  /* control class */
   65 #endif
   66 #define CBQCLF_CLASSMASK        0xf000  /* class mask */
   67 
   68 #define CBQ_MAXQSIZE            200
   69 #define CBQ_MAXPRI              RM_MAXPRIO
   70 
   71 typedef struct _cbq_class_stats_ {
   72         u_int32_t       handle;
   73         u_int           depth;
   74 
   75         struct pktcntr  xmit_cnt;       /* packets sent in this class */
   76         struct pktcntr  drop_cnt;       /* dropped packets */
   77         u_int           over;           /* # times went over limit */
   78         u_int           borrows;        /* # times tried to borrow */
   79         u_int           overactions;    /* # times invoked overlimit action */
   80         u_int           delays;         /* # times invoked delay actions */
   81 
   82         /* other static class parameters useful for debugging */
   83         int             priority;
   84         int             maxidle;
   85         int             minidle;
   86         int             offtime;
   87         int             qmax;
   88         int             ns_per_byte;
   89         int             wrr_allot;
   90 
   91         int             qcnt;           /* # packets in queue */
   92         int             avgidle;
   93 
   94         /* red and rio related info */
   95         int             qtype;
   96         struct redstats red[3];
   97 } class_stats_t;
   98 
   99 #ifdef ALTQ3_COMPAT
  100 /*
  101  * Define structures associated with IOCTLS for cbq.
  102  */
  103 
  104 /*
  105  * Define the CBQ interface structure.  This must be included in all
  106  * IOCTL's such that the CBQ driver may find the appropriate CBQ module
  107  * associated with the network interface to be affected.
  108  */
  109 struct cbq_interface {
  110         char    cbq_ifacename[IFNAMSIZ];
  111 };
  112 
  113 typedef struct cbq_class_spec {
  114         u_int           priority;
  115         u_int           nano_sec_per_byte;
  116         u_int           maxq;
  117         u_int           maxidle;
  118         int             minidle;
  119         u_int           offtime;
  120         u_int32_t       parent_class_handle;
  121         u_int32_t       borrow_class_handle;
  122 
  123         u_int           pktsize;
  124         int             flags;
  125 } cbq_class_spec_t;
  126 
  127 struct cbq_add_class {
  128         struct cbq_interface    cbq_iface;
  129 
  130         cbq_class_spec_t        cbq_class;
  131         u_int32_t               cbq_class_handle;
  132 };
  133 
  134 struct cbq_delete_class {
  135         struct cbq_interface    cbq_iface;
  136         u_int32_t               cbq_class_handle;
  137 };
  138 
  139 struct cbq_modify_class {
  140         struct cbq_interface    cbq_iface;
  141 
  142         cbq_class_spec_t        cbq_class;
  143         u_int32_t               cbq_class_handle;
  144 };
  145 
  146 struct cbq_add_filter {
  147         struct cbq_interface            cbq_iface;
  148         u_int32_t               cbq_class_handle;
  149         struct flow_filter      cbq_filter;
  150 
  151         u_long                  cbq_filter_handle;
  152 };
  153 
  154 struct cbq_delete_filter {
  155         struct cbq_interface    cbq_iface;
  156         u_long                  cbq_filter_handle;
  157 };
  158 
  159 /* number of classes are returned in nclasses field */
  160 struct cbq_getstats {
  161         struct cbq_interface    iface;
  162         int                     nclasses;
  163         class_stats_t           *stats;
  164 };
  165 
  166 /*
  167  * Define IOCTLs for CBQ.
  168  */
  169 #define CBQ_IF_ATTACH           _IOW('Q', 1, struct cbq_interface)
  170 #define CBQ_IF_DETACH           _IOW('Q', 2, struct cbq_interface)
  171 #define CBQ_ENABLE              _IOW('Q', 3, struct cbq_interface)
  172 #define CBQ_DISABLE             _IOW('Q', 4, struct cbq_interface)
  173 #define CBQ_CLEAR_HIERARCHY     _IOW('Q', 5, struct cbq_interface)
  174 #define CBQ_ADD_CLASS           _IOWR('Q', 7, struct cbq_add_class)
  175 #define CBQ_DEL_CLASS           _IOW('Q', 8, struct cbq_delete_class)
  176 #define CBQ_MODIFY_CLASS        _IOWR('Q', 9, struct cbq_modify_class)
  177 #define CBQ_ADD_FILTER          _IOWR('Q', 10, struct cbq_add_filter)
  178 #define CBQ_DEL_FILTER          _IOW('Q', 11, struct cbq_delete_filter)
  179 #define CBQ_GETSTATS            _IOWR('Q', 12, struct cbq_getstats)
  180 #endif /* ALTQ3_COMPAT */
  181 
  182 #ifdef _KERNEL
  183 /*
  184  * Define macros only good for kernel drivers and modules.
  185  */
  186 #define CBQ_WATCHDOG            (hz / 20)
  187 #define CBQ_TIMEOUT             10
  188 #define CBQ_LS_TIMEOUT          (20 * hz / 1000)
  189 
  190 #define CBQ_MAX_CLASSES 256
  191 
  192 #ifdef ALTQ3_COMPAT
  193 #define CBQ_MAX_FILTERS 256
  194 
  195 #define DISABLE         0x00
  196 #define ENABLE          0x01
  197 #endif /* ALTQ3_COMPAT */
  198 
  199 /*
  200  * Define State structures.
  201  */
  202 typedef struct cbqstate {
  203 #ifdef ALTQ3_COMPAT
  204         struct cbqstate         *cbq_next;
  205 #endif
  206         int                      cbq_qlen;      /* # of packets in cbq */
  207         struct rm_class         *cbq_class_tbl[CBQ_MAX_CLASSES];
  208 
  209         struct rm_ifdat          ifnp;
  210         struct callout           cbq_callout;   /* for timeouts */
  211 #ifdef ALTQ3_CLFIER_COMPAT
  212         struct acc_classifier   cbq_classifier;
  213 #endif
  214 } cbq_state_t;
  215 
  216 #endif /* _KERNEL */
  217 
  218 #ifdef __cplusplus
  219 }
  220 #endif
  221 
  222 #endif /* !_ALTQ_ALTQ_CBQ_H_ */

Cache object: a611f64a6925e740092b58f19d3d33f4


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.