summaryrefslogtreecommitdiff
path: root/scripts/VyattaQosTrafficShaper.pm
diff options
context:
space:
mode:
authorStephen Hemminger <stephen.hemminger@vyatta.com>2008-06-06 15:12:12 -0700
committerStephen Hemminger <stephen.hemminger@vyatta.com>2008-06-06 15:12:12 -0700
commitb90702a4ce498172f7cfec2b45c875c959cc5081 (patch)
tree8e89d082f93a00e610fc2f74f13ff5d6fe7d7912 /scripts/VyattaQosTrafficShaper.pm
parent1c372300391087c05637ca4591d48a5f347d88f7 (diff)
downloadvyatta-cfg-qos-b90702a4ce498172f7cfec2b45c875c959cc5081.tar.gz
vyatta-cfg-qos-b90702a4ce498172f7cfec2b45c875c959cc5081.zip
Fix mixing of set-dscp and dscp match
Use tcindex to get original dsfield value. Fixes bug: 3033
Diffstat (limited to 'scripts/VyattaQosTrafficShaper.pm')
-rw-r--r--scripts/VyattaQosTrafficShaper.pm13
1 files changed, 5 insertions, 8 deletions
diff --git a/scripts/VyattaQosTrafficShaper.pm b/scripts/VyattaQosTrafficShaper.pm
index 02bfd31..8e7c1e3 100644
--- a/scripts/VyattaQosTrafficShaper.pm
+++ b/scripts/VyattaQosTrafficShaper.pm
@@ -350,15 +350,12 @@ sub commands {
}
print {$out} "qdisc add dev $dev handle 1:0 root dsmark"
- . " indices $indices default_index $default->{id}\n";
+ . " indices $indices default_index $default->{id} set_tc_index\n";
foreach my $class (@$classes) {
$class->dsmarkClass($out, 1, $dev);
-
- if ($class->{dsmark}) {
- foreach my $match ($class->matchRules()) {
- $match->filter($out, $dev, 1, $class->{id});
- }
+ foreach my $match ($class->matchRules()) {
+ $match->filter($out, $dev, 1, $class->{id});
}
}
@@ -375,8 +372,8 @@ sub commands {
$class->htbClass($out, $dev, $parent, $rate);
foreach my $match ($class->matchRules()) {
- $match->filter($out, $dev, 1, $class->{id});
- }
+ $match->filter($out, $dev, $parent, $class->{id}, $class->{dsmark});
+ }
}
}