Commit 5699275b authored by Stephen Hemminger's avatar Stephen Hemminger

man8: scrub trailing whitespace

Remove extraneous whitespace
parent ac0817ef
...@@ -91,7 +91,7 @@ bridge \- show / manipulate bridge addresses and devices ...@@ -91,7 +91,7 @@ bridge \- show / manipulate bridge addresses and devices
.BR "bridge vlan" " { " add " | " del " } " .BR "bridge vlan" " { " add " | " del " } "
.B dev .B dev
.IR DEV .IR DEV
.B vid .B vid
.IR VID " [ " .IR VID " [ "
.BR pvid " ] [ " untagged " ] [ " .BR pvid " ] [ " untagged " ] [ "
.BR self " ] [ " master " ] " .BR self " ] [ " master " ] "
...@@ -159,7 +159,7 @@ return code will be non zero. ...@@ -159,7 +159,7 @@ return code will be non zero.
- Bridge port. - Bridge port.
.TP .TP
.B fdb .B fdb
- Forwarding Database entry. - Forwarding Database entry.
.TP .TP
...@@ -384,7 +384,7 @@ If omitted the default value is used. ...@@ -384,7 +384,7 @@ If omitted the default value is used.
.BI via " DEVICE" .BI via " DEVICE"
device name of the outgoing interface for the device name of the outgoing interface for the
VXLAN device driver to reach the VXLAN device driver to reach the
remote VXLAN tunnel endpoint. remote VXLAN tunnel endpoint.
.SS bridge fdb append - append a forwarding database entry .SS bridge fdb append - append a forwarding database entry
This command adds a new fdb entry with an already known This command adds a new fdb entry with an already known
......
...@@ -7,8 +7,8 @@ ip-addrlabel \- protocol address label management ...@@ -7,8 +7,8 @@ ip-addrlabel \- protocol address label management
.in +8 .in +8
.ti -8 .ti -8
.B ip .B ip
.RI "[ " OPTIONS " ]" .RI "[ " OPTIONS " ]"
.B addrlabel .B addrlabel
.RI " { " COMMAND " | " .RI " { " COMMAND " | "
.BR help " }" .BR help " }"
.sp .sp
...@@ -66,4 +66,3 @@ flush all address labels in the kernel. This does not restore any default settin ...@@ -66,4 +66,3 @@ flush all address labels in the kernel. This does not restore any default settin
.SH AUTHOR .SH AUTHOR
Manpage by Yoshifuji Hideaki / 吉藤英明 Manpage by Yoshifuji Hideaki / 吉藤英明
...@@ -33,9 +33,9 @@ ip-neighbour \- neighbour/arp tables management. ...@@ -33,9 +33,9 @@ ip-neighbour \- neighbour/arp tables management.
.SH DESCRIPTION .SH DESCRIPTION
The The
.B ip neigh .B ip neigh
command manipulates command manipulates
.I neighbour .I neighbour
objects that establish bindings between protocol addresses and objects that establish bindings between protocol addresses and
link layer addresses for hosts sharing the same link. link layer addresses for hosts sharing the same link.
......
...@@ -55,7 +55,7 @@ ip-ntable - neighbour table configuration ...@@ -55,7 +55,7 @@ ip-ntable - neighbour table configuration
.SH DESCRIPTION .SH DESCRIPTION
.I ip ntable .I ip ntable
controls the parameters for the neighbour tables. controls the parameters for the neighbour tables.
.SS ip ntable show - list the ip neighbour tables .SS ip ntable show - list the ip neighbour tables
...@@ -98,4 +98,4 @@ default value (3) to 8 packets. ...@@ -98,4 +98,4 @@ default value (3) to 8 packets.
.BR ip (8) .BR ip (8)
.SH AUTHOR .SH AUTHOR
Manpage by Stephen Hemminger Manpage by Stephen Hemminger
...@@ -62,7 +62,7 @@ ip-rule \- routing policy database management ...@@ -62,7 +62,7 @@ ip-rule \- routing policy database management
.SH DESCRIPTION .SH DESCRIPTION
.I ip rule .I ip rule
manipulates rules manipulates rules
in the routing policy database control the route selection algorithm. in the routing policy database control the route selection algorithm.
.P .P
......
...@@ -121,7 +121,7 @@ ip-xfrm \- transform configuration ...@@ -121,7 +121,7 @@ ip-xfrm \- transform configuration
.ti -8 .ti -8
.IR ALGO " :=" .IR ALGO " :="
.RB "{ " enc " | " auth " } " .RB "{ " enc " | " auth " } "
.IR ALGO-NAME " " ALGO-KEYMAT " |" .IR ALGO-NAME " " ALGO-KEYMAT " |"
.br .br
.B auth-trunc .B auth-trunc
......
...@@ -12,7 +12,7 @@ ip \- show / manipulate routing, devices, policy routing and tunnels ...@@ -12,7 +12,7 @@ ip \- show / manipulate routing, devices, policy routing and tunnels
.sp .sp
.ti -8 .ti -8
.B ip .B ip
.RB "[ " -force " ] " .RB "[ " -force " ] "
.BI "-batch " filename .BI "-batch " filename
.sp .sp
......
.TH "ROUTEL" "8" "3 Jan, 2008" "iproute2" "Linux" .TH "ROUTEL" "8" "3 Jan, 2008" "iproute2" "Linux"
.SH "NAME" .SH "NAME"
.LP .LP
routel \- list routes with pretty output format routel \- list routes with pretty output format
.br .br
routef \- flush routes routef \- flush routes
.SH "SYNTAX" .SH "SYNTAX"
.LP .LP
routel [\fItablenr\fP [\fIraw ip args...\fP]] routel [\fItablenr\fP [\fIraw ip args...\fP]]
.br .br
routef routef
.SH "DESCRIPTION" .SH "DESCRIPTION"
.LP .LP
These programs are a set of helper scripts you can use instead of raw iproute2 commands. These programs are a set of helper scripts you can use instead of raw iproute2 commands.
.br .br
The routel script will list routes in a format that some might consider easier to interpret then the ip route list equivalent. The routel script will list routes in a format that some might consider easier to interpret then the ip route list equivalent.
...@@ -18,15 +18,15 @@ The routel script will list routes in a format that some might consider easier t ...@@ -18,15 +18,15 @@ The routel script will list routes in a format that some might consider easier t
The routef script does not take any arguments and will simply flush the routing table down the drain. Beware! This means deleting all routes which will make your network unusable! The routef script does not take any arguments and will simply flush the routing table down the drain. Beware! This means deleting all routes which will make your network unusable!
.SH "FILES" .SH "FILES"
.LP .LP
\fI/usr/bin/routef\fP \fI/usr/bin/routef\fP
.br .br
\fI/usr/bin/routel\fP \fI/usr/bin/routel\fP
.SH "AUTHORS" .SH "AUTHORS"
.LP .LP
The routel script was written by Stephen R. van den Berg <srb@cuci.nl>, 1999/04/18 and donated to the public domain. The routel script was written by Stephen R. van den Berg <srb@cuci.nl>, 1999/04/18 and donated to the public domain.
.br .br
This manual page was written by Andreas Henriksson <andreas@fatal.se>, for the Debian GNU/Linux system. This manual page was written by Andreas Henriksson <andreas@fatal.se>, for the Debian GNU/Linux system.
.SH "SEE ALSO" .SH "SEE ALSO"
.LP .LP
ip(8) ip(8)
...@@ -47,4 +47,3 @@ Time interval to average rates. Default value is 60 seconds. ...@@ -47,4 +47,3 @@ Time interval to average rates. Default value is 60 seconds.
.SH SEE ALSO .SH SEE ALSO
lnstat(8) lnstat(8)
...@@ -10,11 +10,11 @@ This manual page documents briefly the ...@@ -10,11 +10,11 @@ This manual page documents briefly the
command. command.
.PP .PP
.B rtmon .B rtmon
listens on listens on
.I netlink .I netlink
socket and monitors routing table changes. socket and monitors routing table changes.
.I rtmon .I rtmon
can be started before the first network configuration command is issued. can be started before the first network configuration command is issued.
For example if you insert: For example if you insert:
...@@ -61,7 +61,7 @@ to display logged output from file. ...@@ -61,7 +61,7 @@ to display logged output from file.
.SH SEE ALSO .SH SEE ALSO
.BR ip (8) .BR ip (8)
.SH AUTHOR .SH AUTHOR
.B rtmon .B rtmon
was written by Alexey Kuznetsov <kuznet@ms2.inr.ac.ru>. was written by Alexey Kuznetsov <kuznet@ms2.inr.ac.ru>.
.PP .PP
This manual page was written by Michael Prokop <mika@grml.org>, This manual page was written by Michael Prokop <mika@grml.org>,
......
...@@ -12,7 +12,7 @@ to ...@@ -12,7 +12,7 @@ to
It can display more TCP and state informations than other tools. It can display more TCP and state informations than other tools.
.SH OPTIONS .SH OPTIONS
When no option is used ss displays a list of When no option is used ss displays a list of
open non-listening sockets (e.g. TCP/UNIX/UDP) that have established connection. open non-listening sockets (e.g. TCP/UNIX/UDP) that have established connection.
.TP .TP
.B \-h, \-\-help .B \-h, \-\-help
...@@ -189,10 +189,10 @@ List all the tcp sockets in state FIN-WAIT-1 for our apache to network 193.233.7 ...@@ -189,10 +189,10 @@ List all the tcp sockets in state FIN-WAIT-1 for our apache to network 193.233.7
.BR /usr/share/doc/iproute-doc/ss.html " (package iproute­doc)", .BR /usr/share/doc/iproute-doc/ss.html " (package iproute­doc)",
.br .br
.BR RFC " 793 " .BR RFC " 793 "
- https://tools.ietf.org/rfc/rfc793.txt (TCP states) - https://tools.ietf.org/rfc/rfc793.txt (TCP states)
.SH AUTHOR .SH AUTHOR
.I ss .I ss
was written by Alexey Kuznetsov, <kuznet@ms2.inr.ac.ru>. was written by Alexey Kuznetsov, <kuznet@ms2.inr.ac.ru>.
.PP .PP
This manual page was written by Michael Prokop <mika@grml.org> This manual page was written by Michael Prokop <mika@grml.org>
......
...@@ -6,37 +6,37 @@ bfifo \- Byte limited First In, First Out queue ...@@ -6,37 +6,37 @@ bfifo \- Byte limited First In, First Out queue
.SH SYNOPSIS .SH SYNOPSIS
.B tc qdisc ... add pfifo .B tc qdisc ... add pfifo
.B [ limit .B [ limit
packets packets
.B ] .B ]
.P .P
.B tc qdisc ... add bfifo .B tc qdisc ... add bfifo
.B [ limit .B [ limit
bytes bytes
.B ] .B ]
.SH DESCRIPTION .SH DESCRIPTION
The pfifo and bfifo qdiscs are unadorned First In, First Out queues. They are the The pfifo and bfifo qdiscs are unadorned First In, First Out queues. They are the
simplest queues possible and therefore have no overhead. simplest queues possible and therefore have no overhead.
.B pfifo .B pfifo
constrains the queue size as measured in packets. constrains the queue size as measured in packets.
.B bfifo .B bfifo
does so as measured in bytes. does so as measured in bytes.
Like all non-default qdiscs, they maintain statistics. This might be a reason to prefer Like all non-default qdiscs, they maintain statistics. This might be a reason to prefer
pfifo or bfifo over the default. pfifo or bfifo over the default.
.SH ALGORITHM .SH ALGORITHM
A list of packets is maintained, when a packet is enqueued it gets inserted at the tail of A list of packets is maintained, when a packet is enqueued it gets inserted at the tail of
a list. When a packet needs to be sent out to the network, it is taken from the head of the list. a list. When a packet needs to be sent out to the network, it is taken from the head of the list.
If the list is too long, no further packets are allowed on. This is called 'tail drop'. If the list is too long, no further packets are allowed on. This is called 'tail drop'.
.SH PARAMETERS .SH PARAMETERS
.TP .TP
limit limit
Maximum queue size. Specified in bytes for bfifo, in packets for pfifo. For pfifo, defaults Maximum queue size. Specified in bytes for bfifo, in packets for pfifo. For pfifo, defaults
to the interface txqueuelen, as specified with to the interface txqueuelen, as specified with
.BR ifconfig (8) .BR ifconfig (8)
or or
.BR ip (8). .BR ip (8).
...@@ -48,20 +48,20 @@ The range for this parameter is [0, UINT32_MAX] bytes. ...@@ -48,20 +48,20 @@ The range for this parameter is [0, UINT32_MAX] bytes.
Note: The link layer header was considered when counting packets length. Note: The link layer header was considered when counting packets length.
.SH OUTPUT .SH OUTPUT
The output of The output of
.B tc -s qdisc ls .B tc -s qdisc ls
contains the limit, either in packets or in bytes, and the number of bytes contains the limit, either in packets or in bytes, and the number of bytes
and packets actually sent. An unsent and dropped packet only appears between braces and packets actually sent. An unsent and dropped packet only appears between braces
and is not counted as 'Sent'. and is not counted as 'Sent'.
In this example, the queue length is 100 packets, 45894 bytes were sent over 681 packets. In this example, the queue length is 100 packets, 45894 bytes were sent over 681 packets.
No packets were dropped, and as the pfifo queue does not slow down packets, there were also no No packets were dropped, and as the pfifo queue does not slow down packets, there were also no
overlimits: overlimits:
.P .P
.nf .nf
# tc -s qdisc ls dev eth0 # tc -s qdisc ls dev eth0
qdisc pfifo 8001: dev eth0 limit 100p qdisc pfifo 8001: dev eth0 limit 100p
Sent 45894 bytes 681 pkts (dropped 0, overlimits 0) Sent 45894 bytes 681 pkts (dropped 0, overlimits 0)
.fi .fi
If a backlog occurs, this is displayed as well. If a backlog occurs, this is displayed as well.
...@@ -72,5 +72,3 @@ If a backlog occurs, this is displayed as well. ...@@ -72,5 +72,3 @@ If a backlog occurs, this is displayed as well.
Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru> Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>
This manpage maintained by bert hubert <ahu@ds9a.nl> This manpage maintained by bert hubert <ahu@ds9a.nl>
This diff is collapsed.
This diff is collapsed.
...@@ -92,4 +92,3 @@ as limits are handled by the individual child qdiscs. ...@@ -92,4 +92,3 @@ as limits are handled by the individual child qdiscs.
.SH AUTHOR .SH AUTHOR
sched_drr was written by Patrick McHardy. sched_drr was written by Patrick McHardy.
...@@ -5,30 +5,30 @@ HTB \- Hierarchy Token Bucket ...@@ -5,30 +5,30 @@ HTB \- Hierarchy Token Bucket
.B tc qdisc ... dev .B tc qdisc ... dev
dev dev
.B ( parent .B ( parent
classid classid
.B | root) [ handle .B | root) [ handle
major: major:
.B ] htb [ default .B ] htb [ default
minor-id minor-id
.B ] .B ]
.B tc class ... dev .B tc class ... dev
dev dev
.B parent .B parent
major:[minor] major:[minor]
.B [ classid .B [ classid
major:minor major:minor
.B ] htb rate .B ] htb rate
rate rate
.B [ ceil .B [ ceil
rate rate
.B ] burst .B ] burst
bytes bytes
.B [ cburst .B [ cburst
bytes bytes
.B ] [ prio .B ] [ prio
priority priority
.B ] .B ]
.SH DESCRIPTION .SH DESCRIPTION
HTB is meant as a more understandable and intuitive replacement for HTB is meant as a more understandable and intuitive replacement for
...@@ -37,9 +37,9 @@ of the outbound bandwidth on a given link. Both allow you to use one ...@@ -37,9 +37,9 @@ of the outbound bandwidth on a given link. Both allow you to use one
physical link to simulate several slower links and to send different physical link to simulate several slower links and to send different
kinds of traffic on different simulated links. In both cases, you have kinds of traffic on different simulated links. In both cases, you have
to specify how to divide the physical link into simulated links and to specify how to divide the physical link into simulated links and
how to decide which simulated link to use for a given packet to be sent. how to decide which simulated link to use for a given packet to be sent.
Unlike CBQ, HTB shapes traffic based on the Token Bucket Filter algorithm Unlike CBQ, HTB shapes traffic based on the Token Bucket Filter algorithm
which does not depend on interface characteristics and so does not need to which does not depend on interface characteristics and so does not need to
know the underlying bandwidth of the outgoing interface. know the underlying bandwidth of the outgoing interface.
...@@ -49,30 +49,30 @@ Shaping works as documented in ...@@ -49,30 +49,30 @@ Shaping works as documented in
.SH CLASSIFICATION .SH CLASSIFICATION
Within the one HTB instance many classes may exist. Each of these classes Within the one HTB instance many classes may exist. Each of these classes
contains another qdisc, by default contains another qdisc, by default
.BR tc-pfifo (8). .BR tc-pfifo (8).
When enqueueing a packet, HTB starts at the root and uses various methods to When enqueueing a packet, HTB starts at the root and uses various methods to
determine which class should receive the data. determine which class should receive the data.
In the absence of uncommon configuration options, the process is rather easy. In the absence of uncommon configuration options, the process is rather easy.
At each node we look for an instruction, and then go to the class the At each node we look for an instruction, and then go to the class the
instruction refers us to. If the class found is a barren leaf-node (without instruction refers us to. If the class found is a barren leaf-node (without
children), we enqueue the packet there. If it is not yet a leaf node, we do children), we enqueue the packet there. If it is not yet a leaf node, we do
the whole thing over again starting from that node. the whole thing over again starting from that node.
The following actions are performed, in order at each node we visit, until one The following actions are performed, in order at each node we visit, until one
sends us to another node, or terminates the process. sends us to another node, or terminates the process.
.TP .TP
(i) (i)
Consult filters attached to the class. If sent to a leafnode, we are done. Consult filters attached to the class. If sent to a leafnode, we are done.
Otherwise, restart. Otherwise, restart.
.TP .TP
(ii) (ii)
If none of the above returned with an instruction, enqueue at this node. If none of the above returned with an instruction, enqueue at this node.
.P .P
This algorithm makes sure that a packet always ends up somewhere, even while This algorithm makes sure that a packet always ends up somewhere, even while
you are busy building your configuration. you are busy building your configuration.
.SH LINK SHARING ALGORITHM .SH LINK SHARING ALGORITHM
FIXME FIXME
...@@ -80,7 +80,7 @@ FIXME ...@@ -80,7 +80,7 @@ FIXME
.SH QDISC .SH QDISC
The root of a HTB qdisc class tree has the following parameters: The root of a HTB qdisc class tree has the following parameters:
.TP .TP
parent major:minor | root parent major:minor | root
This mandatory parameter determines the place of the HTB instance, either at the This mandatory parameter determines the place of the HTB instance, either at the
.B root .B root
...@@ -90,54 +90,54 @@ handle major: ...@@ -90,54 +90,54 @@ handle major:
Like all other qdiscs, the HTB can be assigned a handle. Should consist only Like all other qdiscs, the HTB can be assigned a handle. Should consist only
of a major number, followed by a colon. Optional, but very useful if classes of a major number, followed by a colon. Optional, but very useful if classes
will be generated within this qdisc. will be generated within this qdisc.
.TP .TP
default minor-id default minor-id
Unclassified traffic gets sent to the class with this minor-id. Unclassified traffic gets sent to the class with this minor-id.
.SH CLASSES .SH CLASSES
Classes have a host of parameters to configure their operation. Classes have a host of parameters to configure their operation.
.TP .TP
parent major:minor parent major:minor
Place of this class within the hierarchy. If attached directly to a qdisc Place of this class within the hierarchy. If attached directly to a qdisc
and not to another class, minor can be omitted. Mandatory. and not to another class, minor can be omitted. Mandatory.
.TP .TP
classid major:minor classid major:minor
Like qdiscs, classes can be named. The major number must be equal to the Like qdiscs, classes can be named. The major number must be equal to the
major number of the qdisc to which it belongs. Optional, but needed if this major number of the qdisc to which it belongs. Optional, but needed if this
class is going to have children. class is going to have children.
.TP .TP
prio priority prio priority
In the round-robin process, classes with the lowest priority field are tried In the round-robin process, classes with the lowest priority field are tried
for packets first. Mandatory. for packets first. Mandatory.
.TP .TP
rate rate rate rate
Maximum rate this class and all its children are guaranteed. Mandatory. Maximum rate this class and all its children are guaranteed. Mandatory.
.TP .TP
ceil rate ceil rate
Maximum rate at which a class can send, if its parent has bandwidth to spare. Maximum rate at which a class can send, if its parent has bandwidth to spare.
Defaults to the configured rate, which implies no borrowing Defaults to the configured rate, which implies no borrowing
.TP .TP
burst bytes burst bytes
Amount of bytes that can be burst at Amount of bytes that can be burst at
.B ceil .B ceil
speed, in excess of the configured speed, in excess of the configured
.B rate. .B rate.
Should be at least as high as the highest burst of all children. Should be at least as high as the highest burst of all children.
.TP .TP
cburst bytes cburst bytes
Amount of bytes that can be burst at 'infinite' speed, in other words, as fast Amount of bytes that can be burst at 'infinite' speed, in other words, as fast
as the interface can transmit them. For perfect evening out, should be equal to at most one average as the interface can transmit them. For perfect evening out, should be equal to at most one average
packet. Should be at least as high as the highest cburst of all children. packet. Should be at least as high as the highest cburst of all children.
.SH NOTES .SH NOTES
Due to Unix timing constraints, the maximum ceil rate is not infinite and may in fact be quite low. On Intel, Due to Unix timing constraints, the maximum ceil rate is not infinite and may in fact be quite low. On Intel,
there are 100 timer events per second, the maximum rate is that rate at which 'burst' bytes are sent each timer tick. there are 100 timer events per second, the maximum rate is that rate at which 'burst' bytes are sent each timer tick.
From this, the minimum burst size for a specified rate can be calculated. For i386, a 10mbit rate requires a 12 kilobyte From this, the minimum burst size for a specified rate can be calculated. For i386, a 10mbit rate requires a 12 kilobyte
burst as 100*12kb*8 equals 10mbit. burst as 100*12kb*8 equals 10mbit.
.SH SEE ALSO .SH SEE ALSO
...@@ -146,5 +146,3 @@ burst as 100*12kb*8 equals 10mbit. ...@@ -146,5 +146,3 @@ burst as 100*12kb*8 equals 10mbit.
HTB website: http://luxik.cdi.cz/~devik/qos/htb/ HTB website: http://luxik.cdi.cz/~devik/qos/htb/
.SH AUTHOR .SH AUTHOR
Martin Devera <devik@cdi.cz>. This manpage maintained by bert hubert <ahu@ds9a.nl> Martin Devera <devik@cdi.cz>. This manpage maintained by bert hubert <ahu@ds9a.nl>
...@@ -2,9 +2,9 @@ ...@@ -2,9 +2,9 @@
.SH NAME .SH NAME
NetEm \- Network Emulator NetEm \- Network Emulator
.SH SYNOPSIS .SH SYNOPSIS
.B "tc qdisc ... dev" .B "tc qdisc ... dev"
.IR DEVICE " ] " .IR DEVICE " ] "
.BR "add netem" .BR "add netem"
.I OPTIONS .I OPTIONS
.IR OPTIONS " := [ " LIMIT " ] [ " DELAY " ] [ " LOSS \ .IR OPTIONS " := [ " LIMIT " ] [ " DELAY " ] [ " LOSS \
...@@ -15,15 +15,15 @@ NetEm \- Network Emulator ...@@ -15,15 +15,15 @@ NetEm \- Network Emulator
.I packets .I packets
.IR DELAY " := " .IR DELAY " := "
.BI delay .BI delay
.IR TIME " [ " JITTER " [ " CORRELATION " ]]]" .IR TIME " [ " JITTER " [ " CORRELATION " ]]]"
.br .br
[ [
.BR distribution " { "uniform " | " normal " | " pareto " | " paretonormal " } ]" .BR distribution " { "uniform " | " normal " | " pareto " | " paretonormal " } ]"
.IR LOSS " := " .IR LOSS " := "
.BR loss " { " .BR loss " { "
.BI random .BI random
.IR PERCENT " [ " CORRELATION " ] |" .IR PERCENT " [ " CORRELATION " ] |"
.br .br
.RB " " state .RB " " state
...@@ -44,13 +44,13 @@ NetEm \- Network Emulator ...@@ -44,13 +44,13 @@ NetEm \- Network Emulator
.IR REORDERING " := " .IR REORDERING " := "
.B reorder .B reorder
.IR PERCENT " [ " CORRELATION " ] [ " .IR PERCENT " [ " CORRELATION " ] [ "
.B gap .B gap
.IR DISTANCE " ]" .IR DISTANCE " ]"
.IR RATE " := " .IR RATE " := "
.B rate .B rate
.IR RATE " [ " PACKETOVERHEAD " [ " CELLSIZE " [ " CELLOVERHEAD " ]]]]" .IR RATE " [ " PACKETOVERHEAD " [ " CELLSIZE " [ " CELLOVERHEAD " ]]]]"
.SH DESCRIPTION .SH DESCRIPTION
NetEm is an enhancement of the Linux traffic control facilities NetEm is an enhancement of the Linux traffic control facilities
...@@ -139,11 +139,11 @@ in this second example 25% of packets are sent immediately (with correlation of ...@@ -139,11 +139,11 @@ in this second example 25% of packets are sent immediately (with correlation of
50%) while the others are delayed by 10 ms. 50%) while the others are delayed by 10 ms.
.SS rate .SS rate
delay packets based on packet size and is a replacement for delay packets based on packet size and is a replacement for
.IR TBF . .IR TBF .
Rate can be Rate can be
specified in common units (e.g. 100kbit). Optional specified in common units (e.g. 100kbit). Optional
.I PACKETOVERHEAD .I PACKETOVERHEAD
(in bytes) specify an per packet overhead and can be negative. A positive value can be (in bytes) specify an per packet overhead and can be negative. A positive value can be
used to simulate additional link layer headers. A negative value can be used to used to simulate additional link layer headers. A negative value can be used to
artificial strip the Ethernet header (e.g. -14) and/or simulate a link layer artificial strip the Ethernet header (e.g. -14) and/or simulate a link layer
...@@ -152,7 +152,7 @@ the cellsize. Cellsize can be used to simulate link layer schemes. ATM for ...@@ -152,7 +152,7 @@ the cellsize. Cellsize can be used to simulate link layer schemes. ATM for
example has an payload cellsize of 48 bytes and 5 byte per cell header. If a example has an payload cellsize of 48 bytes and 5 byte per cell header. If a
packet is 50 byte then ATM must use two cells: 2 * 48 bytes payload including 2 packet is 50 byte then ATM must use two cells: 2 * 48 bytes payload including 2
* 5 byte header, thus consume 106 byte on the wire. The last optional value * 5 byte header, thus consume 106 byte on the wire. The last optional value
.I CELLOVERHEAD .I CELLOVERHEAD
can be used to specify per cell overhead - for our ATM example 5. can be used to specify per cell overhead - for our ATM example 5.
.I CELLOVERHEAD .I CELLOVERHEAD
can be negative, but use negative values with caution. can be negative, but use negative values with caution.
......
...@@ -13,14 +13,14 @@ is detached. ...@@ -13,14 +13,14 @@ is detached.
In this sense this qdisc is magic, and unlike other qdiscs. In this sense this qdisc is magic, and unlike other qdiscs.
.SH ALGORITHM .SH ALGORITHM
The algorithm is very similar to that of the classful The algorithm is very similar to that of the classful
.BR tc-prio (8) .BR tc-prio (8)
qdisc. qdisc.
.B pfifo_fast .B pfifo_fast
is like three is like three
.BR tc-pfifo (8) .BR tc-pfifo (8)
queues side by side, where packets can be enqueued in any of the three bands queues side by side, where packets can be enqueued in any of the three bands
based on their Type of Service bits or assigned priority. based on their Type of Service bits or assigned priority.
Not all three bands are dequeued simultaneously - as long as lower bands Not all three bands are dequeued simultaneously - as long as lower bands
have traffic, higher bands are never dequeued. This can be used to have traffic, higher bands are never dequeued. This can be used to
...@@ -28,7 +28,7 @@ prioritize interactive traffic or penalize 'lowest cost' traffic. ...@@ -28,7 +28,7 @@ prioritize interactive traffic or penalize 'lowest cost' traffic.
Each band can be txqueuelen packets long, as configured with Each band can be txqueuelen packets long, as configured with
.BR ifconfig (8) .BR ifconfig (8)
or or
.BR ip (8). .BR ip (8).
Additional packets coming in are not enqueued but are instead dropped. Additional packets coming in are not enqueued but are instead dropped.
...@@ -36,7 +36,7 @@ See ...@@ -36,7 +36,7 @@ See
.BR tc-prio (8) .BR tc-prio (8)
for complete details on how TOS bits are translated into bands. for complete details on how TOS bits are translated into bands.
.SH PARAMETERS .SH PARAMETERS
.TP .TP
txqueuelen txqueuelen
The length of the three bands depends on the interface txqueuelen, as The length of the three bands depends on the interface txqueuelen, as
specified with specified with
...@@ -46,7 +46,7 @@ or ...@@ -46,7 +46,7 @@ or
.SH BUGS .SH BUGS
Does not maintain statistics and does not show up in tc qdisc ls. This is because Does not maintain statistics and does not show up in tc qdisc ls. This is because
it is the automatic default in the absence of a configured qdisc. it is the automatic default in the absence of a configured qdisc.
.SH SEE ALSO .SH SEE ALSO
.BR tc (8) .BR tc (8)
...@@ -55,5 +55,3 @@ it is the automatic default in the absence of a configured qdisc. ...@@ -55,5 +55,3 @@ it is the automatic default in the absence of a configured qdisc.
Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru> Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>
This manpage maintained by bert hubert <ahu@ds9a.nl> This manpage maintained by bert hubert <ahu@ds9a.nl>
...@@ -5,21 +5,21 @@ PRIO \- Priority qdisc ...@@ -5,21 +5,21 @@ PRIO \- Priority qdisc
.B tc qdisc ... dev .B tc qdisc ... dev
dev dev
.B ( parent .B ( parent
classid classid
.B | root) [ handle .B | root) [ handle
major: major:
.B ] prio [ bands .B ] prio [ bands
bands bands
.B ] [ priomap .B ] [ priomap
band band band... band band band...
.B ] [ estimator .B ] [ estimator
interval timeconstant interval timeconstant
.B ] .B ]
.SH DESCRIPTION .SH DESCRIPTION
The PRIO qdisc is a simple classful queueing discipline that contains The PRIO qdisc is a simple classful queueing discipline that contains
an arbitrary number of classes of differing priority. The classes are an arbitrary number of classes of differing priority. The classes are
dequeued in numerical descending order of priority. PRIO is a scheduler dequeued in numerical descending order of priority. PRIO is a scheduler
and never delays packets - it is a work-conserving qdisc, though the qdiscs and never delays packets - it is a work-conserving qdisc, though the qdiscs
contained in the classes may not be. contained in the classes may not be.
...@@ -51,22 +51,22 @@ From userspace ...@@ -51,22 +51,22 @@ From userspace
A process with sufficient privileges can encode the destination class A process with sufficient privileges can encode the destination class
directly with SO_PRIORITY, see directly with SO_PRIORITY, see
.BR socket(7). .BR socket(7).
.TP .TP
with a tc filter with a tc filter
A tc filter attached to the root qdisc can point traffic directly to a class A tc filter attached to the root qdisc can point traffic directly to a class
.TP .TP
with the priomap with the priomap
Based on the packet priority, which in turn is derived from the Type of Based on the packet priority, which in turn is derived from the Type of
Service assigned to the packet. Service assigned to the packet.
.P .P
Only the priomap is specific to this qdisc. Only the priomap is specific to this qdisc.
.SH QDISC PARAMETERS .SH QDISC PARAMETERS
.TP .TP
bands bands
Number of bands. If changed from the default of 3, Number of bands. If changed from the default of 3,
.B priomap .B priomap
must be updated as well. must be updated as well.
.TP .TP
priomap priomap
The priomap maps the priority of The priomap maps the priority of
a packet to a class. The priority can either be set directly from userspace, a packet to a class. The priority can either be set directly from userspace,
...@@ -126,7 +126,7 @@ TOS Bits Means Linux Priority Band ...@@ -126,7 +126,7 @@ TOS Bits Means Linux Priority Band
The second column contains the value of the relevant The second column contains the value of the relevant
four TOS bits, followed by their translated meaning. For example, 15 stands four TOS bits, followed by their translated meaning. For example, 15 stands
for a packet wanting Minimal Monetary Cost, Maximum Reliability, Maximum for a packet wanting Minimal Monetary Cost, Maximum Reliability, Maximum
Throughput AND Minimum Delay. Throughput AND Minimum Delay.
The fourth column lists the way the Linux kernel interprets the TOS bits, by The fourth column lists the way the Linux kernel interprets the TOS bits, by
showing to which Priority they are mapped. showing to which Priority they are mapped.
...@@ -151,7 +151,7 @@ FTP ...@@ -151,7 +151,7 @@ FTP
TFTP 1000 (minimize delay) TFTP 1000 (minimize delay)
SMTP SMTP
Command phase 1000 (minimize delay) Command phase 1000 (minimize delay)
DATA phase 0100 (maximize throughput) DATA phase 0100 (maximize throughput)
...@@ -176,12 +176,10 @@ further qdisc. ...@@ -176,12 +176,10 @@ further qdisc.
.SH BUGS .SH BUGS
Large amounts of traffic in the lower bands can cause starvation of higher Large amounts of traffic in the lower bands can cause starvation of higher
bands. Can be prevented by attaching a shaper (for example, bands. Can be prevented by attaching a shaper (for example,
.BR tc-tbf(8) .BR tc-tbf(8)
to these bands to make sure they cannot dominate the link. to these bands to make sure they cannot dominate the link.
.SH AUTHORS .SH AUTHORS
Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>, J Hadi Salim Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>, J Hadi Salim
<hadi@cyberus.ca>. This manpage maintained by bert hubert <ahu@ds9a.nl> <hadi@cyberus.ca>. This manpage maintained by bert hubert <ahu@ds9a.nl>
.TH RED 8 "13 December 2001" "iproute2" "Linux" .TH RED 8 "13 December 2001" "iproute2" "Linux"
.SH NAME .SH NAME
red \- Random Early Detection red \- Random Early Detection
.SH SYNOPSIS .SH SYNOPSIS
.B tc qdisc ... red .B tc qdisc ... red
.B limit .B limit
bytes
.B [ min
bytes
.B ] [ max
bytes bytes
.B [ min
bytes
.B ] [ max
bytes
.B ] avpkt .B ] avpkt
bytes bytes
.B [ burst .B [ burst
packets packets
.B ] [ ecn ] [ harddrop] [ bandwidth .B ] [ ecn ] [ harddrop] [ bandwidth
rate rate
...@@ -46,51 +46,51 @@ The average queue size is used for determining the marking ...@@ -46,51 +46,51 @@ The average queue size is used for determining the marking
probability. This is calculated using an Exponential Weighted Moving probability. This is calculated using an Exponential Weighted Moving
Average, which can be more or less sensitive to bursts. Average, which can be more or less sensitive to bursts.
When the average queue size is below When the average queue size is below
.B min .B min
bytes, no packet will ever be marked. When it exceeds bytes, no packet will ever be marked. When it exceeds
.B min, .B min,
the probability of doing so climbs linearly up the probability of doing so climbs linearly up
to to
.B probability, .B probability,
until the average queue size hits until the average queue size hits
.B max .B max
bytes. Because bytes. Because
.B probability .B probability
is normally not set to 100%, the queue size might is normally not set to 100%, the queue size might
conceivably rise above conceivably rise above
.B max .B max
bytes, so the bytes, so the
.B limit .B limit
parameter is provided to set a hard maximum for the size of the queue. parameter is provided to set a hard maximum for the size of the queue.
.SH PARAMETERS .SH PARAMETERS
.TP .TP
min min
Average queue size at which marking becomes a possibility. Defaults to Average queue size at which marking becomes a possibility. Defaults to
.B max .B max
/3 /3
.TP .TP
max max
At this average queue size, the marking probability is maximal. Should be at At this average queue size, the marking probability is maximal. Should be at
least twice least twice
.B min .B min
to prevent synchronous retransmits, higher for low to prevent synchronous retransmits, higher for low
.B min. .B min.
Default to Default to
.B limit .B limit
/4 /4
.TP .TP
probability probability
Maximum probability for marking, specified as a floating point Maximum probability for marking, specified as a floating point
number from 0.0 to 1.0. Suggested values are 0.01 or 0.02 (1 or 2%, number from 0.0 to 1.0. Suggested values are 0.01 or 0.02 (1 or 2%,
respectively). Default : 0.02 respectively). Default : 0.02
.TP .TP
limit limit
Hard limit on the real (not average) queue size in bytes. Further packets Hard limit on the real (not average) queue size in bytes. Further packets
are dropped. Should be set higher than max+burst. It is advised to set this are dropped. Should be set higher than max+burst. It is advised to set this
a few times higher than a few times higher than
.B max. .B max.
.TP .TP
burst burst
...@@ -98,7 +98,7 @@ Used for determining how fast the average queue size is influenced by the ...@@ -98,7 +98,7 @@ Used for determining how fast the average queue size is influenced by the
real queue size. Larger values make the calculation more sluggish, allowing real queue size. Larger values make the calculation more sluggish, allowing
longer bursts of traffic before marking starts. Real life experiments longer bursts of traffic before marking starts. Real life experiments
support the following guideline: (min+min+max)/(3*avpkt). support the following guideline: (min+min+max)/(3*avpkt).
.TP .TP
avpkt avpkt
Specified in bytes. Used with burst to determine the time constant for Specified in bytes. Used with burst to determine the time constant for
average queue size calculations. 1000 is a good value. average queue size calculations. 1000 is a good value.
...@@ -126,15 +126,15 @@ bytes, this parameter forces a drop instead of ecn marking. ...@@ -126,15 +126,15 @@ bytes, this parameter forces a drop instead of ecn marking.
adaptive adaptive
(Added in linux-3.3) Sets RED in adaptive mode as described in http://icir.org/floyd/papers/adaptiveRed.pdf (Added in linux-3.3) Sets RED in adaptive mode as described in http://icir.org/floyd/papers/adaptiveRed.pdf
.nf .nf
Goal of Adaptive RED is to make 'probability' dynamic value between 1% and 50% to reach the target average queue : Goal of Adaptive RED is to make 'probability' dynamic value between 1% and 50% to reach the target average queue :
.B (max - min) / 2 .B (max - min) / 2
.fi .fi
.SH EXAMPLE .SH EXAMPLE
.P .P
# tc qdisc add dev eth0 parent 1:1 handle 10: red # tc qdisc add dev eth0 parent 1:1 handle 10: red
limit 400000 min 30000 max 90000 avpkt 1000 limit 400000 min 30000 max 90000 avpkt 1000
burst 55 ecn adaptive bandwidth 10Mbit burst 55 ecn adaptive bandwidth 10Mbit
.SH SEE ALSO .SH SEE ALSO
...@@ -142,11 +142,11 @@ Goal of Adaptive RED is to make 'probability' dynamic value between 1% and 50% t ...@@ -142,11 +142,11 @@ Goal of Adaptive RED is to make 'probability' dynamic value between 1% and 50% t
.BR tc-choke (8) .BR tc-choke (8)
.SH SOURCES .SH SOURCES
.TP .TP
o o
Floyd, S., and Jacobson, V., Random Early Detection gateways for Floyd, S., and Jacobson, V., Random Early Detection gateways for
Congestion Avoidance. http://www.aciri.org/floyd/papers/red/red.html Congestion Avoidance. http://www.aciri.org/floyd/papers/red/red.html
.TP .TP
o o
Some changes to the algorithm by Alexey N. Kuznetsov. Some changes to the algorithm by Alexey N. Kuznetsov.
.TP .TP
...@@ -156,7 +156,5 @@ Adaptive RED : http://icir.org/floyd/papers/adaptiveRed.pdf ...@@ -156,7 +156,5 @@ Adaptive RED : http://icir.org/floyd/papers/adaptiveRed.pdf
.SH AUTHORS .SH AUTHORS
Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>, Alexey Makarenko Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>, Alexey Makarenko
<makar@phoenix.kharkov.ua>, J Hadi Salim <hadi@nortelnetworks.com>, <makar@phoenix.kharkov.ua>, J Hadi Salim <hadi@nortelnetworks.com>,
Eric Dumazet <eric.dumazet@gmail.com>. Eric Dumazet <eric.dumazet@gmail.com>.
This manpage maintained by bert hubert <ahu@ds9a.nl> This manpage maintained by bert hubert <ahu@ds9a.nl>
...@@ -33,11 +33,11 @@ P ...@@ -33,11 +33,11 @@ P
.SH DESCRIPTION .SH DESCRIPTION
Stochastic Fairness Queueing is a classless queueing discipline available for Stochastic Fairness Queueing is a classless queueing discipline available for
traffic control with the traffic control with the
.BR tc (8) .BR tc (8)
command. command.
SFQ does not shape traffic but only schedules the transmission of packets, based on 'flows'. SFQ does not shape traffic but only schedules the transmission of packets, based on 'flows'.
The goal is to ensure fairness so that each flow is able to send data in turn, thus preventing The goal is to ensure fairness so that each flow is able to send data in turn, thus preventing
any single flow from drowning out the rest. any single flow from drowning out the rest.
...@@ -62,13 +62,13 @@ Destination address ...@@ -62,13 +62,13 @@ Destination address
(iii) (iii)
Source and Destination port Source and Destination port
.P .P
If these are available. SFQ knows about ipv4 and ipv6 and also UDP, TCP and ESP. If these are available. SFQ knows about ipv4 and ipv6 and also UDP, TCP and ESP.
Packets with other protocols are hashed based on the 32bits representation of their Packets with other protocols are hashed based on the 32bits representation of their
destination and source. A flow corresponds mostly to a TCP/IP connection. destination and source. A flow corresponds mostly to a TCP/IP connection.
Each of these buckets should represent a unique flow. Because multiple flows may Each of these buckets should represent a unique flow. Because multiple flows may
get hashed to the same bucket, sfqs internal hashing algorithm may be perturbed at configurable get hashed to the same bucket, sfqs internal hashing algorithm may be perturbed at configurable
intervals so that the unfairness lasts only for a short while. Perturbation may intervals so that the unfairness lasts only for a short while. Perturbation may
however cause some inadvertent packet reordering to occur. After linux-3.3, there is however cause some inadvertent packet reordering to occur. After linux-3.3, there is
no packet reordering problem, but possible packet drops if rehashing hits one limit no packet reordering problem, but possible packet drops if rehashing hits one limit
(number of flows or packets per flow) (number of flows or packets per flow)
...@@ -88,7 +88,7 @@ divisor ...@@ -88,7 +88,7 @@ divisor
Can be used to set a different hash table size, available from kernel 2.6.39 onwards. Can be used to set a different hash table size, available from kernel 2.6.39 onwards.
The specified divisor must be a power of two and cannot be larger than 65536. The specified divisor must be a power of two and cannot be larger than 65536.
Default value: 1024. Default value: 1024.
.TP .TP
limit limit
Upper limit of the SFQ. Can be used to reduce the default length of 127 packets. Upper limit of the SFQ. Can be used to reduce the default length of 127 packets.
After linux-3.3, it can be raised. After linux-3.3, it can be raised.
...@@ -97,12 +97,12 @@ depth ...@@ -97,12 +97,12 @@ depth
Limit of packets per flow (after linux-3.3). Default to 127 and can be lowered. Limit of packets per flow (after linux-3.3). Default to 127 and can be lowered.
.TP .TP
perturb perturb
Interval in seconds for queue algorithm perturbation. Defaults to 0, which means that Interval in seconds for queue algorithm perturbation. Defaults to 0, which means that
no perturbation occurs. Do not set too low for each perturbation may cause some packet no perturbation occurs. Do not set too low for each perturbation may cause some packet
reordering or losses. Advised value: 60 reordering or losses. Advised value: 60
This value has no effect when external flow classification is used. This value has no effect when external flow classification is used.
Its better to increase divisor value to lower risk of hash collisions. Its better to increase divisor value to lower risk of hash collisions.
.TP .TP
quantum quantum
Amount of bytes a flow is allowed to dequeue during a round of the round robin process. Amount of bytes a flow is allowed to dequeue during a round of the round robin process.
Defaults to the MTU of the interface which is also the advised value and the minimum value. Defaults to the MTU of the interface which is also the advised value and the minimum value.
...@@ -142,7 +142,7 @@ Specified in bytes. Used with burst to determine the time constant for average q ...@@ -142,7 +142,7 @@ Specified in bytes. Used with burst to determine the time constant for average q
burst burst
Used for determining how fast the average queue size is influenced by the real queue size. Used for determining how fast the average queue size is influenced by the real queue size.
.nf .nf
Default value is : Default value is :
.B (2 * min + max) / (3 * avpkt) .B (2 * min + max) / (3 * avpkt)
.fi .fi
.TP .TP
...@@ -166,16 +166,16 @@ To attach to device ppp0: ...@@ -166,16 +166,16 @@ To attach to device ppp0:
.P .P
# tc qdisc add dev ppp0 root sfq # tc qdisc add dev ppp0 root sfq
.P .P
Please note that SFQ, like all non-shaping (work-conserving) qdiscs, is only useful Please note that SFQ, like all non-shaping (work-conserving) qdiscs, is only useful
if it owns the queue. if it owns the queue.
This is the case when the link speed equals the actually available bandwidth. This holds This is the case when the link speed equals the actually available bandwidth. This holds
for regular phone modems, ISDN connections and direct non-switched ethernet links. for regular phone modems, ISDN connections and direct non-switched ethernet links.
.P .P
Most often, cable modems and DSL devices do not fall into this category. The same holds Most often, cable modems and DSL devices do not fall into this category. The same holds
for when connected to a switch and trying to send data to a congested segment also for when connected to a switch and trying to send data to a congested segment also
connected to the switch. connected to the switch.
.P .P
In this case, the effective queue does not reside within Linux and is therefore not In this case, the effective queue does not reside within Linux and is therefore not
available for scheduling. available for scheduling.
.P .P
Embed SFQ in a classful qdisc to make sure it owns the queue. Embed SFQ in a classful qdisc to make sure it owns the queue.
...@@ -191,11 +191,11 @@ changed the sfq default of 1024, use the same value for the flow hash filter, to ...@@ -191,11 +191,11 @@ changed the sfq default of 1024, use the same value for the flow hash filter, to
.P .P
Example of sfq with optional RED mode : Example of sfq with optional RED mode :
.P .P
# tc qdisc add dev eth0 parent 1:1 handle 10: sfq limit 3000 flows 512 divisor 16384 # tc qdisc add dev eth0 parent 1:1 handle 10: sfq limit 3000 flows 512 divisor 16384
redflowlimit 100000 min 8000 max 60000 probability 0.20 ecn headdrop redflowlimit 100000 min 8000 max 60000 probability 0.20 ecn headdrop
.SH SOURCE .SH SOURCE
.TP .TP
o o
Paul E. McKenney "Stochastic Fairness Queuing", Paul E. McKenney "Stochastic Fairness Queuing",
IEEE INFOCOMM'90 Proceedings, San Francisco, 1990. IEEE INFOCOMM'90 Proceedings, San Francisco, 1990.
...@@ -205,7 +205,7 @@ o ...@@ -205,7 +205,7 @@ o
Paul E. McKenney "Stochastic Fairness Queuing", Paul E. McKenney "Stochastic Fairness Queuing",
"Interworking: Research and Experience", v.2, 1991, p.113-131. "Interworking: Research and Experience", v.2, 1991, p.113-131.
.TP .TP
o o
See also: See also:
M. Shreedhar and George Varghese "Efficient Fair M. Shreedhar and George Varghese "Efficient Fair
...@@ -220,5 +220,3 @@ Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>, ...@@ -220,5 +220,3 @@ Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>,
Eric Dumazet <eric.dumazet@gmail.com>. Eric Dumazet <eric.dumazet@gmail.com>.
.P .P
This manpage maintained by bert hubert <ahu@ds9a.nl> This manpage maintained by bert hubert <ahu@ds9a.nl>
...@@ -6,11 +6,11 @@ tbf \- Token Bucket Filter ...@@ -6,11 +6,11 @@ tbf \- Token Bucket Filter
rate rate
.B burst .B burst
bytes/cell bytes/cell
.B ( latency .B ( latency
ms ms
.B | limit .B | limit
bytes bytes
.B ) [ mpu .B ) [ mpu
bytes bytes
.B [ peakrate .B [ peakrate
rate rate
...@@ -22,46 +22,46 @@ burst is also known as buffer and maxburst. mtu is also known as minburst. ...@@ -22,46 +22,46 @@ burst is also known as buffer and maxburst. mtu is also known as minburst.
.SH DESCRIPTION .SH DESCRIPTION
The Token Bucket Filter is a classful queueing discipline available for The Token Bucket Filter is a classful queueing discipline available for
traffic control with the traffic control with the
.BR tc (8) .BR tc (8)
command. command.
TBF is a pure shaper and never schedules traffic. It is non-work-conserving and may throttle TBF is a pure shaper and never schedules traffic. It is non-work-conserving and may throttle
itself, although packets are available, to ensure that the configured rate is not exceeded. itself, although packets are available, to ensure that the configured rate is not exceeded.
It is able to shape up to 1mbit/s of normal traffic with ideal minimal burstiness, It is able to shape up to 1mbit/s of normal traffic with ideal minimal burstiness,
sending out data exactly at the configured rates. sending out data exactly at the configured rates.
Much higher rates are possible but at the cost of losing the minimal burstiness. In that Much higher rates are possible but at the cost of losing the minimal burstiness. In that
case, data is on average dequeued at the configured rate but may be sent much faster at millisecond case, data is on average dequeued at the configured rate but may be sent much faster at millisecond
timescales. Because of further queues living in network adaptors, this is often not a problem. timescales. Because of further queues living in network adaptors, this is often not a problem.
.SH ALGORITHM .SH ALGORITHM
As the name implies, traffic is filtered based on the expenditure of As the name implies, traffic is filtered based on the expenditure of
.B tokens. .B tokens.
Tokens roughly correspond to bytes, with the additional constraint Tokens roughly correspond to bytes, with the additional constraint
that each packet consumes some tokens, no matter how small it is. This that each packet consumes some tokens, no matter how small it is. This
reflects the fact that even a zero-sized packet occupies the link for reflects the fact that even a zero-sized packet occupies the link for
some time. some time.
On creation, the TBF is stocked with tokens which correspond to the amount of traffic that can be burst On creation, the TBF is stocked with tokens which correspond to the amount of traffic that can be burst
in one go. Tokens arrive at a steady rate, until the bucket is full. in one go. Tokens arrive at a steady rate, until the bucket is full.
If no tokens are available, packets are queued, up to a configured limit. The TBF now If no tokens are available, packets are queued, up to a configured limit. The TBF now
calculates the token deficit, and throttles until the first packet in the queue can be sent. calculates the token deficit, and throttles until the first packet in the queue can be sent.
If it is not acceptable to burst out packets at maximum speed, a peakrate can be configured If it is not acceptable to burst out packets at maximum speed, a peakrate can be configured
to limit the speed at which the bucket empties. This peakrate is implemented as a second TBF to limit the speed at which the bucket empties. This peakrate is implemented as a second TBF
with a very small bucket, so that it doesn't burst. with a very small bucket, so that it doesn't burst.
To achieve perfection, the second bucket may contain only a single packet, which leads to To achieve perfection, the second bucket may contain only a single packet, which leads to
the earlier mentioned 1mbit/s limit. the earlier mentioned 1mbit/s limit.
This limit is caused by the fact that the kernel can only throttle for at minimum 1 'jiffy', which depends This limit is caused by the fact that the kernel can only throttle for at minimum 1 'jiffy', which depends
on HZ as 1/HZ. For perfect shaping, only a single packet can get sent per jiffy - for HZ=100, this means 100 on HZ as 1/HZ. For perfect shaping, only a single packet can get sent per jiffy - for HZ=100, this means 100
packets of on average 1000 bytes each, which roughly corresponds to 1mbit/s. packets of on average 1000 bytes each, which roughly corresponds to 1mbit/s.
.SH PARAMETERS .SH PARAMETERS
See See
.BR tc (8) .BR tc (8)
for how to specify the units of these values. for how to specify the units of these values.
.TP .TP
...@@ -71,30 +71,30 @@ available. You can also specify this the other way around by setting the ...@@ -71,30 +71,30 @@ available. You can also specify this the other way around by setting the
latency parameter, which specifies the maximum amount of time a packet can latency parameter, which specifies the maximum amount of time a packet can
sit in the TBF. The latter calculation takes into account the size of the sit in the TBF. The latter calculation takes into account the size of the
bucket, the rate and possibly the peakrate (if set). These two parameters bucket, the rate and possibly the peakrate (if set). These two parameters
are mutually exclusive. are mutually exclusive.
.TP .TP
burst burst
Also known as buffer or maxburst. Also known as buffer or maxburst.
Size of the bucket, in bytes. This is the maximum amount of bytes that tokens can be available for instantaneously. Size of the bucket, in bytes. This is the maximum amount of bytes that tokens can be available for instantaneously.
In general, larger shaping rates require a larger buffer. For 10mbit/s on Intel, you need at least 10kbyte buffer In general, larger shaping rates require a larger buffer. For 10mbit/s on Intel, you need at least 10kbyte buffer
if you want to reach your configured rate! if you want to reach your configured rate!
If your buffer is too small, packets may be dropped because more tokens arrive per timer tick than fit in your bucket. If your buffer is too small, packets may be dropped because more tokens arrive per timer tick than fit in your bucket.
The minimum buffer size can be calculated by dividing the rate by HZ. The minimum buffer size can be calculated by dividing the rate by HZ.
Token usage calculations are performed using a table which by default has a resolution of 8 packets. Token usage calculations are performed using a table which by default has a resolution of 8 packets.
This resolution can be changed by specifying the This resolution can be changed by specifying the
.B cell .B cell
size with the burst. For example, to specify a 6000 byte buffer with a 16 size with the burst. For example, to specify a 6000 byte buffer with a 16
byte cell size, set a burst of 6000/16. You will probably never have to set byte cell size, set a burst of 6000/16. You will probably never have to set
this. Must be an integral power of 2. this. Must be an integral power of 2.
.TP .TP
mpu mpu
A zero-sized packet does not use zero bandwidth. For ethernet, no packet uses less than 64 bytes. The Minimum Packet Unit A zero-sized packet does not use zero bandwidth. For ethernet, no packet uses less than 64 bytes. The Minimum Packet Unit
determines the minimal token usage (specified in bytes) for a packet. Defaults to zero. determines the minimal token usage (specified in bytes) for a packet. Defaults to zero.
.TP .TP
rate rate
The speed knob. See remarks above about limits! See The speed knob. See remarks above about limits! See
.BR tc (8) .BR tc (8)
for units. for units.
.PP .PP
...@@ -112,7 +112,7 @@ Specifies the size of the peakrate bucket. For perfect accuracy, should be set t ...@@ -112,7 +112,7 @@ Specifies the size of the peakrate bucket. For perfect accuracy, should be set t
If a peakrate is needed, but some burstiness is acceptable, this size can be raised. A 3000 byte minburst If a peakrate is needed, but some burstiness is acceptable, this size can be raised. A 3000 byte minburst
allows around 3mbit/s of peakrate, given 1000 byte packets. allows around 3mbit/s of peakrate, given 1000 byte packets.
Like the regular burstsize you can also specify a Like the regular burstsize you can also specify a
.B cell .B cell
size. size.
.SH EXAMPLE & USAGE .SH EXAMPLE & USAGE
...@@ -139,5 +139,3 @@ the limit/latency is not effective anymore. ...@@ -139,5 +139,3 @@ the limit/latency is not effective anymore.
.SH AUTHOR .SH AUTHOR
Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>. This manpage maintained by Alexey N. Kuznetsov, <kuznet@ms2.inr.ac.ru>. This manpage maintained by
bert hubert <ahu@ds9a.nl> bert hubert <ahu@ds9a.nl>
...@@ -732,4 +732,3 @@ was written by Alexey N. Kuznetsov and added in Linux 2.2. ...@@ -732,4 +732,3 @@ was written by Alexey N. Kuznetsov and added in Linux 2.2.
.SH AUTHOR .SH AUTHOR
Manpage maintained by bert hubert (ahu@ds9a.nl) Manpage maintained by bert hubert (ahu@ds9a.nl)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment