1.\" 2.\" Copyright (c) 2004 Max Laier <mlaier@FreeBSD.org> 3.\" All rights reserved. 4.\" 5.\" Redistribution and use in source and binary forms, with or without 6.\" modification, are permitted provided that the following conditions 7.\" are met: 8.\" 1. Redistributions of source code must retain the above copyright 9.\" notice, this list of conditions and the following disclaimer. 10.\" 2. Redistributions in binary form must reproduce the above copyright 11.\" notice, this list of conditions and the following disclaimer in the 12.\" documentation and/or other materials provided with the distribution. 13.\" 14.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24.\" SUCH DAMAGE. 25.\" 26.\" $FreeBSD$ 27.\" 28.Dd February 3, 2007 29.Dt ALTQ 4 30.Os 31.Sh NAME 32.Nm ALTQ 33.Nd "alternate queuing of network packets" 34.Sh SYNOPSIS 35.Cd options ALTQ 36.Pp 37.Cd options ALTQ_CBQ 38.Cd options ALTQ_RED 39.Cd options ALTQ_RIO 40.Cd options ALTQ_HFSC 41.Cd options ALTQ_CDNR 42.Cd options ALTQ_PRIQ 43.Sh DESCRIPTION 44The 45.Nm 46framework provides several disciplines for queuing outgoing network packets. 47This is done by modifications to the interface packet queues. 48See 49.Xr altq 9 50for details. 51.Pp 52The user interface for 53.Nm 54is implemented by the 55.Xr pfctl 8 56utility, so please refer to the 57.Xr pfctl 8 58and the 59.Xr pf.conf 5 60manpages for a complete description of the 61.Nm 62capabilities and how to use it. 63.Ss Kernel Options 64The following options in the kernel configuration file are related to 65.Nm 66operation: 67.Pp 68.Bl -tag -width ".Dv ALTQ_DEBUG" -compact 69.It Dv ALTQ 70Enable 71.Nm . 72.It Dv ALTQ_CBQ 73Build the 74.Dq "Class Based Queuing" 75discipline. 76.It Dv ALTQ_RED 77Build the 78.Dq "Random Early Detection" 79extension. 80.It Dv ALTQ_RIO 81Build 82.Dq "Random Early Drop" 83for input and output. 84.It Dv ALTQ_HFSC 85Build the 86.Dq "Hierarchical Packet Scheduler" 87discipline. 88.It Dv ALTQ_CDNR 89Build the traffic conditioner. 90This option is meaningless at the moment as the conditioner is not used by 91any of the available disciplines or consumers. 92.It Dv ALTQ_PRIQ 93Build the 94.Dq "Priority Queuing" 95discipline. 96.It Dv ALTQ_NOPCC 97Required if the TSC is unusable. 98.It Dv ALTQ_DEBUG 99Enable additional debugging facilities. 100.El 101.Pp 102Note that 103.Nm Ns -disciplines 104cannot be loaded as kernel modules. 105In order to use a certain discipline you have to build it into a custom 106kernel. 107The 108.Xr pf 4 109interface, that is required for the configuration process of 110.Nm 111can be loaded as a module. 112.Sh SUPPORTED DEVICES 113The driver modifications described in 114.Xr altq 9 115are required to use a certain network card with 116.Nm . 117They have been applied to the following hardware drivers: 118.Xr an 4 , 119.Xr ath 4 , 120.Xr aue 4 , 121.Xr awi 4 , 122.Xr bce 4 , 123.Xr bfe 4 , 124.Xr bge 4 , 125.Xr dc 4 , 126.Xr de 4 , 127.Xr ed 4 , 128.Xr em 4 , 129.Xr ep 4 , 130.Xr fxp 4 , 131.Xr hme 4 , 132.Xr ipw 4 , 133.Xr iwi 4 , 134.Xr le 4 , 135.Xr msk 4 , 136.Xr mxge 4 , 137.Xr my 4 , 138.Xr npe 4 , 139.Xr nve 4 , 140.Xr ral 4 , 141.Xr re 4 , 142.Xr rl 4 , 143.Xr sf 4 , 144.Xr sis 4 , 145.Xr sk 4 , 146.Xr ste 4 , 147.Xr stge 4 , 148.Xr udav 4 , 149.Xr ural 4 , 150.Xr vr 4 , 151.Xr wi 4 , 152and 153.Xr xl 4 . 154.Pp 155The 156.Xr ndis 4 157framework also has support for 158.Nm 159and thus all encapsulated drivers. 160.Pp 161The 162.Xr tun 4 163and 164.Xr ng_iface 4 165pseudo drivers also do support 166.Nm . 167.Sh SEE ALSO 168.Xr pf 4 , 169.Xr pf.conf 5 , 170.Xr ipfw 8 , 171.Xr pfctl 8 , 172.Xr altq 9 173