| 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 | |