From 216b27c681dfacba194c9f001eec6287008a750c Mon Sep 17 00:00:00 2001 From: Stephen Hemminger Date: Wed, 14 May 2008 11:40:18 -0700 Subject: new qos-policy type rate-limit Add new QoS policy type "rate-limit" which is a wrapper around the the Token Bucket Filter (TBF) qdisc. Rate limit provides a simple way to do basic bandwidth limitation without the complexity of the doing multiple classes in the traffic shaper policy. --- scripts/VyattaQosUtil.pm | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) (limited to 'scripts/VyattaQosUtil.pm') diff --git a/scripts/VyattaQosUtil.pm b/scripts/VyattaQosUtil.pm index 87e9519..a4fd3f2 100644 --- a/scripts/VyattaQosUtil.pm +++ b/scripts/VyattaQosUtil.pm @@ -84,6 +84,44 @@ sub getRate { } } +# Default time units for tc are usec. +my %timeunits = ( + 's' => 1000000, + 'sec' => 1000000, + 'secs' => 1000000, + 'ms' => 1000, + 'msec' => 1000, + 'msecs' => 1000, + 'us' => 1, + 'usec' => 1, + 'usecs' => 1, +); + +sub getTime { + my $time = shift; + my ($num, $suffix) = get_num($time); + + defined $num + or die "$time is not a valid time interval (not a number)\n"; + ($num >= 0) + or die "$time is not a valid time interval (negative value)\n"; + + if (defined $suffix) { + my $scale = $timeunits{lc $suffix}; + + if (defined $scale) { + return $num * $scale; + } + + die "$time is not a valid time interval (unknown suffix)\n"; + } else { + # No suffix implies ms + return $num * 1000; + } +} + + + my %scales = ( 'b' => 1, 'k' => 1024, -- cgit v1.2.3