1db5bc679SAlexander Motin.\" Copyright (c) 2005 Nuno Antunes <nuno.antunes@gmail.com> 2db5bc679SAlexander Motin.\" Copyright (c) 2007 Alexander Motin <mav@freebsd.org> 3db5bc679SAlexander Motin.\" All rights reserved. 4db5bc679SAlexander Motin.\" 5db5bc679SAlexander Motin.\" Redistribution and use in source and binary forms, with or without 6db5bc679SAlexander Motin.\" modification, are permitted provided that the following conditions 7db5bc679SAlexander Motin.\" are met: 8db5bc679SAlexander Motin.\" 1. Redistributions of source code must retain the above copyright 9db5bc679SAlexander Motin.\" notice, this list of conditions and the following disclaimer. 10db5bc679SAlexander Motin.\" 2. Redistributions in binary form must reproduce the above copyright 11db5bc679SAlexander Motin.\" notice, this list of conditions and the following disclaimer in the 12db5bc679SAlexander Motin.\" documentation and/or other materials provided with the distribution. 13db5bc679SAlexander Motin.\" 14db5bc679SAlexander Motin.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15db5bc679SAlexander Motin.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16db5bc679SAlexander Motin.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17db5bc679SAlexander Motin.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18db5bc679SAlexander Motin.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19db5bc679SAlexander Motin.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20db5bc679SAlexander Motin.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21db5bc679SAlexander Motin.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22db5bc679SAlexander Motin.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23db5bc679SAlexander Motin.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24db5bc679SAlexander Motin.\" SUCH DAMAGE. 25db5bc679SAlexander Motin.\" 26db5bc679SAlexander Motin.\" $FreeBSD$ 27db5bc679SAlexander Motin.\" 28db5bc679SAlexander Motin.Dd March 11, 2007 29db5bc679SAlexander Motin.Dt NG_CAR 4 30db5bc679SAlexander Motin.Os 31db5bc679SAlexander Motin.Sh NAME 32db5bc679SAlexander Motin.Nm ng_car 33db5bc679SAlexander Motin.Nd Commited Access Rate netgraph node type 34db5bc679SAlexander Motin.Sh SYNOPSIS 35db5bc679SAlexander Motin.In netgraph/ng_car.h 36db5bc679SAlexander Motin.Sh DESCRIPTION 37db5bc679SAlexander MotinThe 38db5bc679SAlexander Motin.Nm car 39db5bc679SAlexander Motinnode type limits traffic flowing through it using: 40db5bc679SAlexander Motin.Pp 41db5bc679SAlexander Motin.Bl -bullet -compact 42db5bc679SAlexander Motin.It 43d4261539SChristian BruefferSingle rate three color marker as described in RFC 2697, 44db5bc679SAlexander Motin.It 45d4261539SChristian BruefferTwo rate three color marker as described in RFC 2698, 46db5bc679SAlexander Motin.It 47db5bc679SAlexander MotinRED-like rate limit algorithm used by Cisco, 48db5bc679SAlexander Motin.It 49db5bc679SAlexander MotinTraffic shaping with RED. 50db5bc679SAlexander Motin.El 51db5bc679SAlexander Motin.Sh HOOKS 52db5bc679SAlexander MotinThis node type supports the following hooks: 53db5bc679SAlexander Motin.Bl -tag -width indent 54db5bc679SAlexander Motin.It Va upper 55db5bc679SAlexander MotinHook leading to upper layer protocols. 56db5bc679SAlexander Motin.It Va lower 57db5bc679SAlexander MotinHook leading to lower layer protocols. 58db5bc679SAlexander Motin.El 59db5bc679SAlexander Motin.Pp 60db5bc679SAlexander MotinTraffic flowing from 61db5bc679SAlexander Motin.Va upper 62db5bc679SAlexander Motinto 63db5bc679SAlexander Motin.Va lower 64db5bc679SAlexander Motinis considered 65db5bc679SAlexander Motin.Sy downstream 66db5bc679SAlexander Motintraffic. 67db5bc679SAlexander MotinTraffic flowing from 68db5bc679SAlexander Motin.Va lower 69db5bc679SAlexander Motinto 70db5bc679SAlexander Motin.Va upper 71db5bc679SAlexander Motinis considered 72db5bc679SAlexander Motin.Sy upstream 73db5bc679SAlexander Motintraffic. 74db5bc679SAlexander Motin.Sh MODES OF OPERATION 75cd27e26cSAlexander MotinEach hook can operate in one of the following modes: 76db5bc679SAlexander Motin.Bl -tag -width indent 77db5bc679SAlexander Motin.It Dv NG_CAR_SINGLE_RATE 78d4261539SChristian BruefferSingle rate three color marker as described in RFC 2697. 79cd27e26cSAlexander MotinCommitted burst packets are counted as green, extended burst packets are 80cd27e26cSAlexander Motincounted as yellow and exceeding packets are counted as red. 81cd27e26cSAlexander MotinCommitted burst getting refilled with CIR (Committed Information Rate) speed. 82db5bc679SAlexander MotinWhen it is full, exceeded burst getting refilled. 83db5bc679SAlexander Motin.It Dv NG_CAR_DOUBLE_RATE 84db5bc679SAlexander MotinTwo rate three color marker as described on RFC 2698. 85cd27e26cSAlexander MotinCommitted burst packets are counted as green, peak burst packets are counted 86cd27e26cSAlexander Motinas yellow and exceeding packets are counted as red. 87cd27e26cSAlexander MotinCommitted burst getting refilled with CIR speed. 88cd27e26cSAlexander MotinPeak burst getting refilled with PIR (Peak Information Rate) speed at the 89cd27e26cSAlexander Motinsame time. 90db5bc679SAlexander Motin.It Dv NG_CAR_RED 91cd27e26cSAlexander MotinSimilar to 92cd27e26cSAlexander Motin.Dv NG_CAR_SINGLE_RATE , 93cd27e26cSAlexander Motinbut with different understanding of extended burst. 94cd27e26cSAlexander MotinWhen normal burst exceeded and extended burst is used, packets are counted 95cd27e26cSAlexander Motinred with probability equal to part of extended burst consumed. 96cd27e26cSAlexander MotinExtended burst getting refilled first. 97cd27e26cSAlexander MotinWhen it is full, committed burst getting refilled. 98cd27e26cSAlexander MotinThis behavior is similar to RED active queue management algorithm. 99db5bc679SAlexander Motin.Pp 100db5bc679SAlexander MotinThis algorithm is more polite to the TCP traffic then NG_CAR_SINGLE_RATE. 101db5bc679SAlexander Motin.It Dv NG_CAR_SHAPE 102db5bc679SAlexander MotinCommitted burst packets are counted as green, exceeding packets are delayed 103cd27e26cSAlexander Motinby queue with RED management and counted as yellow. 104cd27e26cSAlexander MotinPackets dropped by queue counted as red. 105db5bc679SAlexander MotinQueue parameters are hardcoded: length 99 packets, min_th 8 packets, max_p 100%. 106db5bc679SAlexander Motin.Pp 107cd27e26cSAlexander MotinTraffic shaping is much more polite to the TCP traffic then rate limit on 108cd27e26cSAlexander Motinlinks with bandwidth * delay product less then 6-8 TCP segments, but it 109cd27e26cSAlexander Motinconsumes additional system resources for queue processing. 110db5bc679SAlexander Motin.El 111db5bc679SAlexander Motin.Sh CONTROL MESSAGES 112db5bc679SAlexander MotinThis node type supports the generic control messages and the following 113db5bc679SAlexander Motinspecific messages. 114db5bc679SAlexander Motin.Bl -tag -width indent 115db5bc679SAlexander Motin.It Dv NGM_CAR_SET_CONF Pq Li setconf 116db5bc679SAlexander MotinSet node configuration to the specified at 117db5bc679SAlexander Motin.Vt "struct ng_car_bulkconf" 118db5bc679SAlexander Motin.It Dv NGM_CAR_GET_CONF Pq Li getconf 119db5bc679SAlexander MotinReturn current node configuration as 120db5bc679SAlexander Motin.Vt "struct ng_car_bulkconf" 121cd27e26cSAlexander Motin.Bd -literal 122db5bc679SAlexander Motinstruct ng_car_hookconf { 123db5bc679SAlexander Motin u_int64_t cbs; /* Committed burst size (bytes) */ 124db5bc679SAlexander Motin u_int64_t ebs; /* Exceeded/Peak burst size (bytes) */ 125db5bc679SAlexander Motin u_int64_t cir; /* Committed information rate (bytes/s) */ 126db5bc679SAlexander Motin u_int64_t pir; /* Peak information rate (bits/s) */ 127db5bc679SAlexander Motin u_int8_t green_action; /* Action for green packets */ 128db5bc679SAlexander Motin u_int8_t yellow_action; /* Action for yellow packets */ 129db5bc679SAlexander Motin u_int8_t red_action; /* Action for red packets */ 130db5bc679SAlexander Motin u_int8_t mode; /* single/double rate, ... */ 131db5bc679SAlexander Motin u_int8_t opt; /* color-aware or color-blind */ 132db5bc679SAlexander Motin}; 133db5bc679SAlexander Motin 134db5bc679SAlexander Motinstruct ng_car_bulkconf { 135db5bc679SAlexander Motin struct ng_car_hookconf upstream; 136db5bc679SAlexander Motin struct ng_car_hookconf downstream; 137db5bc679SAlexander Motin}; 138db5bc679SAlexander Motin.Ed 139db5bc679SAlexander Motin.It Dv NGM_CAR_GET_STATS Pq Li getstats 140db5bc679SAlexander MotinReturn node statistics as 141db5bc679SAlexander Motin.Vt "struct ng_car_bulkstats" 142cd27e26cSAlexander Motin.Bd -literal 143db5bc679SAlexander Motinstruct ng_car_hookstats { 144db5bc679SAlexander Motin u_int64_t passed_pkts; 145db5bc679SAlexander Motin u_int64_t droped_pkts; 146db5bc679SAlexander Motin u_int64_t green_pkts; 147db5bc679SAlexander Motin u_int64_t yellow_pkts; 148db5bc679SAlexander Motin u_int64_t red_pkts; 149db5bc679SAlexander Motin u_int64_t errors; 150db5bc679SAlexander Motin}; 151db5bc679SAlexander Motin 152db5bc679SAlexander Motinstruct ng_car_bulkstats { 153db5bc679SAlexander Motin struct ng_car_hookstats upstream; 154db5bc679SAlexander Motin struct ng_car_hookstats downstream; 155db5bc679SAlexander Motin}; 156db5bc679SAlexander Motin.Ed 157db5bc679SAlexander Motin.It Dv NGM_CAR_CLR_STATS Pq Li clrstats 158db5bc679SAlexander MotinClear node statistics. 159db5bc679SAlexander Motin.It Dv NGM_CAR_GETCLR_STATS Pq Li getclrstats 160d4261539SChristian BruefferAtomically return and clear node statistics. 161db5bc679SAlexander Motin.El 162db5bc679SAlexander Motin.Sh SHUTDOWN 163db5bc679SAlexander MotinThis node shuts down upon receipt of a 164db5bc679SAlexander Motin.Dv NGM_SHUTDOWN 165db5bc679SAlexander Motincontrol message, or when all hooks have been disconnected. 166db5bc679SAlexander Motin.Sh SEE ALSO 167db5bc679SAlexander Motin.Xr netgraph 4 , 168db5bc679SAlexander Motin.Xr ngctl 8 169db5bc679SAlexander Motin.Rs 170db5bc679SAlexander Motin.%A J. Heinanen 171db5bc679SAlexander Motin.%T "A Single Rate Three Color Marker" 172db5bc679SAlexander Motin.%O RFC 2697 173db5bc679SAlexander Motin.Re 174db5bc679SAlexander Motin.Rs 175db5bc679SAlexander Motin.%A J. Heinanen 176db5bc679SAlexander Motin.%T "A Two Rate Three Color Marker" 177db5bc679SAlexander Motin.%O RFC 2698 178db5bc679SAlexander Motin.Re 179db5bc679SAlexander Motin.Sh AUTHORS 180db5bc679SAlexander Motin.An Nuno Antunes Aq nuno.antunes@gmail.com 181db5bc679SAlexander Motin.An Alexander Motin Aq mav@alkar.net 182db5bc679SAlexander Motin.Sh BUGS 183cd27e26cSAlexander MotinAt this moment only DROP and FORWARD actions are implemented. 184