summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/Vyatta/Qos/Match.pm102
1 files changed, 49 insertions, 53 deletions
diff --git a/lib/Vyatta/Qos/Match.pm b/lib/Vyatta/Qos/Match.pm
index 587704f..0c45958 100644
--- a/lib/Vyatta/Qos/Match.pm
+++ b/lib/Vyatta/Qos/Match.pm
@@ -20,83 +20,79 @@ use Vyatta::Qos::Util qw(getIfIndex getDsfield getProtocol);
use strict;
use warnings;
-my %fields = (
- _dev => undef,
- _vif => undef,
- _ip => undef,
-);
-
sub new {
my ( $that, $config ) = @_;
- my $self = {%fields};
+ my $self = { };
my $class = ref($that) || $that;
bless $self, $class;
- $self->_define($config);
-
- return $self;
-}
-
-sub _define {
- my ( $self, $config ) = @_;
- my $level = $config->setLevel();
$self->{_vif} = $config->returnValue("vif");
$self->{_dev} = getIfIndex($config->returnValue("interface"));
- if ($config->exists("ip")) {
- my %ip;
+ foreach my $ip (qw(ip ipv6)) {
+ next unless $config->exists($ip);
- $ip{dsfield} = getDsfield( $config->returnValue("ip dscp"));
- $ip{protocol} = getProtocol($config->returnValue("ip protocol"));
- $ip{src} = $config->returnValue("ip source address");
- $ip{dst} = $config->returnValue("ip destination address");
- $ip{sport} = $config->returnValue("ip source port");
- $ip{dport} = $config->returnValue("ip destination port");
- $self->{_ip} = \%ip;
+ # TODO make this data driven?
+ my %fields;
+ $fields{dsfield} = getDsfield( $config->returnValue("$ip dscp"));
+ $fields{protocol} = getProtocol($config->returnValue("$ip protocol"));
+ $fields{src} = $config->returnValue("$ip source address");
+ $fields{dst} = $config->returnValue("$ip destination address");
+ $fields{sport} = $config->returnValue("$ip source port");
+ $fields{dport} = $config->returnValue("$ip destination port");
+ $self->{$ip} = \%fields;
}
+
+ return $self;
}
sub filter {
my ( $self, $dev, $parent, $prio, $dsmark ) = @_;
- my $ip = $self->{_ip};
- my $indev = $self->{_dev};
- my $vif = $self->{_vif};
-
- # Catch empty match
- if (! (defined $ip || defined $indev || defined $vif)) {
- return;
- }
+
+ # empty match
+ return unless %{ $self };
# Special case for when dsmarking is used with ds matching
# original dscp is saved in tc_index
- if (defined $dsmark && defined $ip && defined $$ip{dsfield}) {
- printf "filter add dev %s parent %x: protocol ip prio 1",
- $dev, $parent;
- printf " handle %d tcindex", $$ip{dsfield};
+ if ($dsmark) {
+ foreach my $ipver (qw(ip ipv6)) {
+ my $ip = $self->{$ipver};
+ next unless $ip && $$ip{dsfield};
+
+ printf "filter add dev %s parent %x: protocol $ipver prio 1",
+ $dev, $parent;
+ printf " handle %d tcindex", $$ip{dsfield};
+ }
return;
}
- printf "filter add dev %s parent %x: prio %d", $dev, $parent, $prio;
- if (defined $ip) {
- print " protocol ip u32";
- print " match ip dsfield $$ip{dsfield} 0xff"
+ foreach my $ipver (qw(ip ipv6)) {
+ my $ip = $self->{$ipver};
+ next unless $ip;
+
+ printf "filter add dev %s parent %x: prio %d", $dev, $parent, $prio;
+ print " protocol $ipver u32";
+ print " match $ipver dsfield $$ip{dsfield} 0xff"
if defined $$ip{dsfield};
- print " match ip protocol $$ip{protocol} 0xff"
- if defined $$ip{protocol};
- print " match ip src $$ip{src}"
+ print " match $ipver protocol $$ip{protocol} 0xff"
+ if defined $$ip{protocol};
+ print " match $ipver src $$ip{src}"
if defined $$ip{src};
- print " match ip sport $$ip{sport} 0xffff"
+ print " match $ipver sport $$ip{sport} 0xffff"
if defined $$ip{sport};
- print " match ip dst $$ip{dst}"
- if defined $$ip{dst};
- print " match ip dport $$ip{dport} 0xffff"
- if defined $$ip{dport};
- } else {
+ print " match $ipver dst $$ip{dst}"
+ if defined $$ip{dst};
+ print " match $ipver dport $$ip{dport} 0xffff"
+ if defined $$ip{dport};
+ }
+
+ my $indev = $self->{indev};
+ my $vif = $self->{vif};
+ if ($vif || $indev) {
+ printf "filter add dev %s parent %x: prio %d", $dev, $parent, $prio;
print " protocol all basic";
- print " match meta\(rt_iif eq $indev\)"
- if (defined $indev);
- print " match meta\(vlan mask 0xfff eq $vif\)"
- if (defined $vif);
+ print " match meta\(rt_iif eq $indev\)" if $indev;
+ print " match meta\(vlan mask 0xfff eq $vif\)" if $vif;
}
}