altq_cbq.h revision 1.8       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_ */
    223