summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStephen Hemminger <stephen.hemminger@vyatta.com>2009-07-31 21:59:46 -0700
committerStephen Hemminger <stephen.hemminger@vyatta.com>2009-08-04 16:20:30 -0700
commit67ffa12de0848703b3b86d9c3b578a2edc79bc3b (patch)
treef23ec2f73bc4b05affee18f457247176d08f9d3f
parent0d46a00541e0b13069e91df97d68bc2506615ffd (diff)
downloadvyatta-cfg-quagga-67ffa12de0848703b3b86d9c3b578a2edc79bc3b.tar.gz
vyatta-cfg-quagga-67ffa12de0848703b3b86d9c3b578a2edc79bc3b.zip
BONDING: handle change of bond-group
Use similar action to new bridge-group Bug 4768
-rwxr-xr-xscripts/vyatta-bonding.pl26
-rw-r--r--templates/interfaces/ethernet/node.tag/bond-group/node.def17
2 files changed, 31 insertions, 12 deletions
diff --git a/scripts/vyatta-bonding.pl b/scripts/vyatta-bonding.pl
index 66417f9f..b9ea0bcf 100755
--- a/scripts/vyatta-bonding.pl
+++ b/scripts/vyatta-bonding.pl
@@ -30,6 +30,7 @@
use lib "/opt/vyatta/share/perl5/";
use Vyatta::Interface;
+use Vyatta::Config;
use Getopt::Long;
use strict;
@@ -136,13 +137,9 @@ sub change_mode {
my @slaves = get_slaves($intf);
foreach my $slave (@slaves) {
- if_down($slave);
remove_slave( $intf, $slave ) unless ( $primary && $slave eq $primary );
}
- if ($primary) {
- if_down($primary);
- remove_slave( $intf, $primary );
- }
+ remove_slave( $intf, $primary ) if ($primary);
my $bond_up = $interface->up();
if_down($intf) if $bond_up;
@@ -154,6 +151,23 @@ sub change_mode {
}
}
+# bonding requires interface to be down before enslaving
+# but enslaving automatically brings interface up!
+sub add_port {
+ my ( $intf, $slave ) = @_;
+ my $slaveif = new Vyatta::Interface($slave);
+
+ if ($slaveif->up()) {
+ if_down($slave);
+ } else {
+ my $cfg = new Vyatta::Config;
+ $cfg->setLevel($slaveif->path());
+ die "Can not add disabled interface $slave to bond-group $intf\n"
+ if $cfg->exists('disable');
+ }
+ add_slave ($intf, $slave);
+}
+
sub usage {
print "Usage: $0 --dev=bondX --mode={mode}\n";
print " $0 --dev=bondX --add-port=ethX\n";
@@ -175,5 +189,5 @@ GetOptions(
die "$0: device not specified\n" unless $dev;
change_mode( $dev, $mode ) if $mode;
-add_slave( $dev, $add_port ) if $add_port;
+add_port( $dev, $add_port ) if $add_port;
remove_slave( $dev, $rem_port ) if $rem_port;
diff --git a/templates/interfaces/ethernet/node.tag/bond-group/node.def b/templates/interfaces/ethernet/node.tag/bond-group/node.def
index 4c5c38c3..d2a398a1 100644
--- a/templates/interfaces/ethernet/node.tag/bond-group/node.def
+++ b/templates/interfaces/ethernet/node.tag/bond-group/node.def
@@ -3,9 +3,14 @@ help: Add this interface to a bonding group
commit:expression: exec \
"/opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(@) --check=bonding"
allowed: /opt/vyatta/sbin/vyatta-interfaces.pl --show=bonding
-create: sudo sh -c "ip link set $VAR(../@) down 2>/dev/null";
- sudo sh -c "echo +$VAR(../@) > /sys/class/net/$VAR(@)/bonding/slaves";
- sudo sh -c "ip link set $VAR(../@) up 2>/dev/null"
-
-delete: sudo sh -c "echo -$VAR(../@) > /sys/class/net/$VAR(@)/bonding/slaves"
-
+end: ethif=$VAR(../@)
+ old=`/opt/vyatta/sbin/vyatta-cli-expand-var.pl \$\(/interfaces/ethernet/$ethif/bond-group/@\)`
+ new=$VAR(@)
+ if [ ${COMMIT_ACTION} = 'SET' ]; then
+ sudo ${vyatta_sbindir}/vyatta-bonding.pl --dev=$new --add=$ethif
+ elif [ ${COMMIT_ACTION} = 'DELETE' ]; then
+ sudo ${vyatta_sbindir}/vyatta-bonding.pl --dev=$new --remove=$ethif
+ elif [ "$old" != "$new" ]; then
+ sudo ${vyatta_sbindir}/vyatta-bonding.pl --dev=$old --remove=$ethif
+ sudo ${vyatta_sbindir}/vyatta-bonding.pl --dev=$new --add=$ethif
+ fi