2004-10-07 12:10:25 +00:00
|
|
|
.\"
|
2005-01-14 10:46:08 +00:00
|
|
|
.\" Copyright (c) 2004 Max Laier <mlaier@FreeBSD.org>
|
2004-10-07 12:10:25 +00:00
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
2005-01-14 10:46:08 +00:00
|
|
|
.\" $FreeBSD$
|
2004-10-07 12:10:25 +00:00
|
|
|
.\"
|
2007-06-12 02:19:11 +00:00
|
|
|
.Dd June 12, 2007
|
2004-10-07 12:10:25 +00:00
|
|
|
.Dt ALTQ 4
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm ALTQ
|
2005-01-14 10:46:08 +00:00
|
|
|
.Nd "alternate queuing of network packets"
|
2005-02-07 11:46:36 +00:00
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Cd options ALTQ
|
|
|
|
.Pp
|
|
|
|
.Cd options ALTQ_CBQ
|
|
|
|
.Cd options ALTQ_RED
|
|
|
|
.Cd options ALTQ_RIO
|
|
|
|
.Cd options ALTQ_HFSC
|
|
|
|
.Cd options ALTQ_CDNR
|
|
|
|
.Cd options ALTQ_PRIQ
|
2004-10-07 12:10:25 +00:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
framework provides several disciplines for queuing outgoing network packets.
|
|
|
|
This is done by modifications to the interface packet queues.
|
|
|
|
See
|
|
|
|
.Xr altq 9
|
|
|
|
for details.
|
|
|
|
.Pp
|
|
|
|
The user interface for
|
|
|
|
.Nm
|
|
|
|
is implemented by the
|
|
|
|
.Xr pfctl 8
|
|
|
|
utility, so please refer to the
|
|
|
|
.Xr pfctl 8
|
|
|
|
and the
|
|
|
|
.Xr pf.conf 5
|
|
|
|
manpages for a complete description of the
|
|
|
|
.Nm
|
|
|
|
capabilities and how to use it.
|
|
|
|
.Ss Kernel Options
|
|
|
|
The following options in the kernel configuration file are related to
|
|
|
|
.Nm
|
|
|
|
operation:
|
|
|
|
.Pp
|
|
|
|
.Bl -tag -width ".Dv ALTQ_DEBUG" -compact
|
|
|
|
.It Dv ALTQ
|
2005-01-14 10:46:08 +00:00
|
|
|
Enable
|
|
|
|
.Nm .
|
2004-10-07 12:10:25 +00:00
|
|
|
.It Dv ALTQ_CBQ
|
2005-01-14 10:46:08 +00:00
|
|
|
Build the
|
2004-10-07 12:10:25 +00:00
|
|
|
.Dq "Class Based Queuing"
|
|
|
|
discipline.
|
|
|
|
.It Dv ALTQ_RED
|
2005-01-14 10:46:08 +00:00
|
|
|
Build the
|
2005-02-07 23:20:12 +00:00
|
|
|
.Dq "Random Early Detection"
|
2004-10-07 12:10:25 +00:00
|
|
|
extension.
|
|
|
|
.It Dv ALTQ_RIO
|
2005-01-14 10:46:08 +00:00
|
|
|
Build
|
2004-10-07 12:10:25 +00:00
|
|
|
.Dq "Random Early Drop"
|
|
|
|
for input and output.
|
|
|
|
.It Dv ALTQ_HFSC
|
2005-01-14 10:46:08 +00:00
|
|
|
Build the
|
2004-10-07 12:10:25 +00:00
|
|
|
.Dq "Hierarchical Packet Scheduler"
|
|
|
|
discipline.
|
|
|
|
.It Dv ALTQ_CDNR
|
2005-01-14 10:46:08 +00:00
|
|
|
Build the traffic conditioner.
|
2004-10-07 12:10:25 +00:00
|
|
|
This option is meaningless at the moment as the conditioner is not used by
|
2004-11-11 22:52:26 +00:00
|
|
|
any of the available disciplines or consumers.
|
2004-10-07 12:10:25 +00:00
|
|
|
.It Dv ALTQ_PRIQ
|
2005-01-14 10:46:08 +00:00
|
|
|
Build the
|
2004-10-07 12:10:25 +00:00
|
|
|
.Dq "Priority Queuing"
|
|
|
|
discipline.
|
|
|
|
.It Dv ALTQ_NOPCC
|
2006-03-02 19:45:59 +00:00
|
|
|
Required if the TSC is unusable.
|
2004-10-07 12:10:25 +00:00
|
|
|
.It Dv ALTQ_DEBUG
|
2005-01-14 10:46:08 +00:00
|
|
|
Enable additional debugging facilities.
|
2004-10-07 12:10:25 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
Note that
|
|
|
|
.Nm Ns -disciplines
|
2004-11-11 22:52:26 +00:00
|
|
|
cannot be loaded as kernel modules.
|
2004-10-07 12:10:25 +00:00
|
|
|
In order to use a certain discipline you have to build it into a custom
|
|
|
|
kernel.
|
|
|
|
The
|
|
|
|
.Xr pf 4
|
|
|
|
interface, that is required for the configuration process of
|
|
|
|
.Nm
|
|
|
|
can be loaded as a module.
|
|
|
|
.Sh SUPPORTED DEVICES
|
|
|
|
The driver modifications described in
|
|
|
|
.Xr altq 9
|
2004-11-11 22:52:26 +00:00
|
|
|
are required to use a certain network card with
|
|
|
|
.Nm .
|
|
|
|
They have been applied to the following hardware drivers:
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr an 4 ,
|
|
|
|
.Xr ath 4 ,
|
2007-02-03 13:53:22 +00:00
|
|
|
.Xr aue 4 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr awi 4 ,
|
2007-05-12 05:59:15 +00:00
|
|
|
.Xt axe 4 ,
|
2007-02-03 13:33:40 +00:00
|
|
|
.Xr bce 4 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr bfe 4 ,
|
2004-11-01 11:43:07 +00:00
|
|
|
.Xr bge 4 ,
|
2004-10-08 03:33:31 +00:00
|
|
|
.Xr dc 4 ,
|
2004-12-16 15:24:53 +00:00
|
|
|
.Xr de 4 ,
|
2004-11-21 02:42:09 +00:00
|
|
|
.Xr ed 4 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr em 4 ,
|
2006-12-01 20:29:55 +00:00
|
|
|
.Xr ep 4 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr fxp 4 ,
|
2007-06-04 06:01:57 +00:00
|
|
|
.Xr gem 4 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr hme 4 ,
|
2007-02-03 13:33:40 +00:00
|
|
|
.Xr ipw 4 ,
|
|
|
|
.Xr iwi 4 ,
|
2006-01-31 18:46:17 +00:00
|
|
|
.Xr le 4 ,
|
2006-12-13 02:40:06 +00:00
|
|
|
.Xr msk 4 ,
|
2006-12-13 08:55:20 +00:00
|
|
|
.Xr mxge 4 ,
|
2006-06-05 18:02:36 +00:00
|
|
|
.Xr my 4 ,
|
2007-06-12 02:19:11 +00:00
|
|
|
.Xr nfe 4 ,
|
2007-02-03 13:38:04 +00:00
|
|
|
.Xr npe 4 ,
|
2006-05-20 21:08:09 +00:00
|
|
|
.Xr nve 4 ,
|
2007-02-03 13:33:40 +00:00
|
|
|
.Xr ral 4 ,
|
2005-03-12 17:35:37 +00:00
|
|
|
.Xr re 4 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr rl 4 ,
|
2007-05-09 05:18:04 +00:00
|
|
|
.Xr rum 4 ,
|
2004-11-12 18:13:54 +00:00
|
|
|
.Xr sf 4 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr sis 4 ,
|
2004-12-24 14:13:38 +00:00
|
|
|
.Xr sk 4 ,
|
2005-07-08 13:05:59 +00:00
|
|
|
.Xr ste 4 ,
|
2006-07-25 00:58:00 +00:00
|
|
|
.Xr stge 4 ,
|
2007-02-03 13:33:40 +00:00
|
|
|
.Xr udav 4 ,
|
|
|
|
.Xr ural 4 ,
|
2007-02-21 10:00:09 +00:00
|
|
|
.Xr vge 4 ,
|
2004-12-24 14:13:38 +00:00
|
|
|
.Xr vr 4 ,
|
2004-12-16 15:24:53 +00:00
|
|
|
.Xr wi 4 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
and
|
|
|
|
.Xr xl 4 .
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Xr ndis 4
|
|
|
|
framework also has support for
|
|
|
|
.Nm
|
|
|
|
and thus all encapsulated drivers.
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Xr tun 4
|
2005-10-10 15:14:37 +00:00
|
|
|
and
|
|
|
|
.Xr ng_iface 4
|
|
|
|
pseudo drivers also do support
|
|
|
|
.Nm .
|
2004-10-07 12:10:25 +00:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr pf 4 ,
|
|
|
|
.Xr pf.conf 5 ,
|
2004-10-08 03:33:31 +00:00
|
|
|
.Xr ipfw 8 ,
|
2004-10-07 12:10:25 +00:00
|
|
|
.Xr pfctl 8 ,
|
2005-01-14 10:46:08 +00:00
|
|
|
.Xr altq 9
|