summaryrefslogtreecommitdiff
path: root/scripts/VyattaQosTrafficShaper.pm
diff options
context:
space:
mode:
authorStephen Hemminger <stephen.hemminger@vyatta.com>2008-03-07 13:06:02 -0800
committerStephen Hemminger <stephen.hemminger@vyatta.com>2008-03-07 13:06:02 -0800
commitfd9ffb944c35ea269bc1be337221dd0438b5f0be (patch)
tree32018ddbef20d5421f05877f74beeec4fde6d92b /scripts/VyattaQosTrafficShaper.pm
parent3422a4ab9ca22d5f43efae457fc2c5f0a1478e98 (diff)
downloadvyatta-cfg-qos-fd9ffb944c35ea269bc1be337221dd0438b5f0be.tar.gz
vyatta-cfg-qos-fd9ffb944c35ea269bc1be337221dd0438b5f0be.zip
fix filtering rules when using set-dscp
The generated filtering rules were using wrong id's when set-dscp was being used. Need to put dsmark rules on root, and htb rules on start of that tree, and the id needs to be printed in hex not decimal. Bugfix: 2947
Diffstat (limited to 'scripts/VyattaQosTrafficShaper.pm')
-rw-r--r--scripts/VyattaQosTrafficShaper.pm29
1 files changed, 22 insertions, 7 deletions
diff --git a/scripts/VyattaQosTrafficShaper.pm b/scripts/VyattaQosTrafficShaper.pm
index cedebb9..201cd8d 100644
--- a/scripts/VyattaQosTrafficShaper.pm
+++ b/scripts/VyattaQosTrafficShaper.pm
@@ -48,7 +48,8 @@
$self->{_limit} = $config->returnValue("queue-limit");
$self->{_qdisc} = $config->returnValue("queue-type");
- $self->{dsmark} = VyattaQosUtil::getDsfield($config->returnValue("set-dscp"));
+ $self->{dsmark} =
+ VyattaQosUtil::getDsfield($config->returnValue("set-dscp"));
foreach my $match ($config->listNodes("match")) {
$config->setLevel("$level match $match");
@@ -57,6 +58,12 @@
$self->{_match} = \@matches;
}
+ sub matchRules {
+ my ($self) = @_;
+ my $matches = $self->{_match};
+ return @$matches;
+ }
+
sub _getPercentRate {
my ($rate, $speed) = @_;
@@ -187,11 +194,6 @@
} else {
die "Unknown queue type $self->{_qdisc}\n";
}
-
- my $matches = $self->{_match};
- foreach my $match (@$matches) {
- $match->filter( $out, $dev, $parent, $self->{id} );
- }
}
sub dsmarkClass {
@@ -199,6 +201,7 @@
printf ${out} "class change dev %s classid %x:%x dsmark",
$dev, $parent, $self->{id};
+
if ($self->{dsmark}) {
print ${out} " mask 0 value $self->{dsmark}\n";
} else {
@@ -342,8 +345,15 @@ sub commands {
. " indices $indices default_index $default->{id}\n";
foreach my $class (@$classes) {
- $class->dsmarkClass($out, "1", $dev);
+ $class->dsmarkClass($out, 1, $dev);
+
+ if ($class->{dsmark}) {
+ foreach my $match ($class->matchRules()) {
+ $match->filter($out, $dev, 1, $class->{id});
+ }
+ }
}
+
$parent = $indices + 1;
$root = "parent 1:1"
}
@@ -355,6 +365,11 @@ sub commands {
foreach my $class (@$classes) {
$class->htbClass($out, $dev, $parent, $rate);
+
+ foreach my $match ($class->matchRules()) {
+ $match->filter($out, $dev, $parent, $class->{id});
+ }
+
}
}