diff options
5 files changed, 32 insertions, 54 deletions
diff --git a/scripts/vyatta-interfaces.pl b/scripts/vyatta-interfaces.pl index c91cc22c..f3792f74 100755 --- a/scripts/vyatta-interfaces.pl +++ b/scripts/vyatta-interfaces.pl @@ -50,7 +50,7 @@ my ($dev, $mac, $mac_update); my %skip_interface; my ($check_name, $show_names, $vif_name, $warn_name); my ($check_up, $dhcp_command, $allowed_speed); -my (@speed_duplex, @addr_commit, @check_speed, @offload_settings); +my (@speed_duplex, @addr_commit, @check_speed, @offload_option); sub usage { print <<EOF; @@ -62,7 +62,7 @@ Usage: $0 --dev=<interface> --check=<type> $0 --dev=<interface> --check-speed=speed,duplex $0 --dev=<interface> --allowed-speed $0 --dev=<interface> --isup - $0 --dev=<interface> --offload-settings=tcp,udp,segmentation,recieve + $0 --dev=<interface> --offload-settings={tcp,udp,segmentation,receive}={value} $0 --show=<type> EOF exit 1; @@ -82,7 +82,7 @@ GetOptions("valid-addr-commit=s{,}" => \@addr_commit, "speed-duplex=s{2}" => \@speed_duplex, "check-speed=s{2}" => \@check_speed, "allowed-speed" => \$allowed_speed, - "offload-settings=s{4}" => \@offload_settings, + "offload-settings=s{2}" => \@offload_option, ) or usage(); is_valid_addr_commit($dev, @addr_commit) if (@addr_commit); @@ -96,7 +96,7 @@ is_up($dev) if ($check_up); set_speed_duplex($dev, @speed_duplex) if (@speed_duplex); check_speed_duplex($dev, @check_speed) if (@check_speed); allowed_speed($dev) if ($allowed_speed); -set_offload_settings($dev) if (@offload_settings); +set_offload_setting($dev, @offload_option) if (@offload_option); exit 0; sub is_ip_configured { @@ -575,48 +575,43 @@ sub allowed_speed { print 'auto ', join(' ', sort keys %speeds), "\n"; } -sub get_offload_settings { - my $dev = shift; +sub get_offload_setting { + my ($dev, $option) = @_; + my ($val); open( my $ethtool, '-|', "$ETHTOOL -k $dev 2>&1" ) or die "ethtool failed: $!\n"; - - my ($tcp, $udp, $segmen, $receive); - while (<$ethtool>) { + next if ($_ !~ m/$option:/); chomp; - my $val = (split(/: /, $_))[1]; - - if ( /^tcp-segmentation-offload:/ ) { - $tcp = $val; - } elsif ( /^udp-fragmentation-offload:/ ) { - $udp = $val; - } elsif ( /^generic-segmentation-offload:/ ) { - $segmen = $val; - } elsif ( /^generic-receive-offload:/ ) { - $receive = $val; - } + $val = (split(/: /, $_))[1]; } - close $ethtool; - - return ($tcp, $udp, $segmen, $receive); + return ($val); } -sub set_offload_settings { - my ($intf, $ntcp, $nudp, $nsegmen, $nreceive) = @_; +sub set_offload_setting { + my ($intf, $option, $nvalue) = @_; die "Missing --dev argument\n" unless $intf; - ($tcp, $udp, $segmen, $receive) = get_offload_settings($intf); + my $ovalue = get_offload_setting($intf, $option); + my $args = ''; - my $args; + my %ethtool_opts = ( 'generic-receive-offload' => 'gro', + 'generic-segmentation-offload' => 'gso', + 'tcp-segmentation-offload' => 'tso', + 'udp-segmentation-offload' => 'ufo', + ); - $args .= " tso $ntcp" if (defined($ntcp) && $ntcp ne $otcp); - $args .= " ufo $nudp" if (defined($nudp) && $nudp ne $oudp); - $args .= " gso $nsegmen" if (defined($nsegmen) && $nsegmen ne $osegmen); - $args .= " gro $nreceive" if (defined($nreceive) && $nreceive ne $oreceive); + $args = "$ethtool_opts{$option} $nvalue" if (defined($nvalue) && $nvalue ne $ovalue); - exec "$ETHTOOL -K $intf $args" if (defined($args)); - die "exec of $ETHTOOL failed: $!"; + if ($args ne '') { + my $cmd = "$ETHTOOL -K $intf $args"; + system($cmd); + + if ($? >> 8) { + die "exec of $ETHTOOL failed: '$cmd'"; + } + } } diff --git a/templates/interfaces/ethernet/node.tag/offload/generic-receive-offload/node.def b/templates/interfaces/ethernet/node.tag/offload/generic-receive-offload/node.def index 411565ab..4970f2de 100644 --- a/templates/interfaces/ethernet/node.tag/offload/generic-receive-offload/node.def +++ b/templates/interfaces/ethernet/node.tag/offload/generic-receive-offload/node.def @@ -12,10 +12,6 @@ val_help: off; Disable generic-receive-offload syntax:expression: $VAR(@) == "on" || $VAR(@) == "off" ; "$type must be either 'on' or 'off'" -update: sudo /opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(../../@) \ - --offload-settings $VAR(../tcp-segmentation-offload/@) \ - $VAR(../udp-segmentation-offload/@) \ - $VAR(../generic-segmentation-offload/@) \ - $VAR(@) +update: sudo /opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(../../@) --offload-settings generic-receive-offload $VAR(@) diff --git a/templates/interfaces/ethernet/node.tag/offload/generic-segmentation-offload/node.def b/templates/interfaces/ethernet/node.tag/offload/generic-segmentation-offload/node.def index 91b1ecf9..727d91ff 100644 --- a/templates/interfaces/ethernet/node.tag/offload/generic-segmentation-offload/node.def +++ b/templates/interfaces/ethernet/node.tag/offload/generic-segmentation-offload/node.def @@ -12,10 +12,6 @@ val_help: off; Disable generic-segmentation-offload syntax:expression: $VAR(@) == "on" || $VAR(@) == "off" ; "$type must be either 'on' or 'off'" -update: sudo /opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(../../@) \ - --offload-settings $VAR(../tcp-segmentation-offload/@) \ - $VAR(../udp-segmentation-offload/@) \ - $VAR(@) \ - $VAR(../generic-receive-offload/@) +update: sudo /opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(../../@) --offload-settings generic-segmentation-offload $VAR(@) diff --git a/templates/interfaces/ethernet/node.tag/offload/tcp-segmentation-offload/node.def b/templates/interfaces/ethernet/node.tag/offload/tcp-segmentation-offload/node.def index 641c2c8b..4046139c 100644 --- a/templates/interfaces/ethernet/node.tag/offload/tcp-segmentation-offload/node.def +++ b/templates/interfaces/ethernet/node.tag/offload/tcp-segmentation-offload/node.def @@ -12,10 +12,5 @@ val_help: off; Disable tcp-segmentation-offload syntax:expression: $VAR(@) == "on" || $VAR(@) == "off" ; "$type must be either 'on' or 'off'" -update: sudo /opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(../../@) \ - --offload-settings $VAR(@) \ - $VAR(../udp-segmentation-offload/@) \ - $VAR(../generic-segmentation-offload/@) \ - $VAR(../generic-receive-offload/@) - +update: sudo /opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(../../@) --offload-settings tcp-segmentation-offload $VAR(@) diff --git a/templates/interfaces/ethernet/node.tag/offload/udp-segmentation-offload/node.def b/templates/interfaces/ethernet/node.tag/offload/udp-segmentation-offload/node.def index d96b4be5..86a7abe1 100644 --- a/templates/interfaces/ethernet/node.tag/offload/udp-segmentation-offload/node.def +++ b/templates/interfaces/ethernet/node.tag/offload/udp-segmentation-offload/node.def @@ -12,10 +12,6 @@ val_help: off; Disable udp-segmentation-offload syntax:expression: $VAR(@) == "on" || $VAR(@) == "off" ; "$type must be either 'on' or 'off'" -update: sudo /opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(../../@) \ - --offload-settings $VAR(../tcp-segmentation-offload/@) \ - $VAR(@) \ - $VAR(../generic-segmentation-offload/@) \ - $VAR(../generic-receive-offload/@) +update: sudo /opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(../../@) --offload-settings udp-segmentation-offload $VAR(@) |