summaryrefslogtreecommitdiff
path: root/scripts/vyatta-interfaces.pl
diff options
context:
space:
mode:
authorStephen Hemminger <stephen.hemminger@vyatta.com>2008-10-30 16:46:01 -0700
committerStephen Hemminger <stephen.hemminger@vyatta.com>2008-10-30 16:46:01 -0700
commit3d48065f09241a6878dc31a8d0223d673b5d553f (patch)
treeb816baecc0b4576c4f5788f92aea8e5201a17b90 /scripts/vyatta-interfaces.pl
parenta7e7e6ca9e8fc48326d28de2c9f1395002126326 (diff)
downloadvyatta-cfg-3d48065f09241a6878dc31a8d0223d673b5d553f.tar.gz
vyatta-cfg-3d48065f09241a6878dc31a8d0223d673b5d553f.zip
Allow dhcp on bonding
Fix some assumptions in the vyatta-interfaces script that prevent using dhcp on bonded devices Bugfix 3835
Diffstat (limited to 'scripts/vyatta-interfaces.pl')
-rw-r--r--scripts/vyatta-interfaces.pl35
1 files changed, 21 insertions, 14 deletions
diff --git a/scripts/vyatta-interfaces.pl b/scripts/vyatta-interfaces.pl
index 760cd4f..d382922 100644
--- a/scripts/vyatta-interfaces.pl
+++ b/scripts/vyatta-interfaces.pl
@@ -150,12 +150,16 @@ sub is_address_enabled {
my $config = new VyattaConfig;
+ ## FIXME this is name based madness find a better way
+ ## so we don't have to redo with each interface type!
if ($intf =~ m/^eth/) {
if ($intf =~ m/(\w+)\.(\d+)/) {
$config->setLevel("interfaces ethernet $1 vif $2");
} else {
$config->setLevel("interfaces ethernet $intf");
}
+ } elsif ($intf =~ m/^bond/) {
+ $config->setLevel("interfaces bonding $intf");
} elsif ($intf =~ m/^br/) {
$config->setLevel("interfaces bridge $intf");
} else {
@@ -174,25 +178,20 @@ sub is_address_enabled {
sub get_hostname {
my $config = new VyattaConfig;
$config->setLevel("system");
- my $hostname = $config->returnValue("host-name");
- return $hostname;
+ return $config->returnValue("host-name");
}
sub is_domain_name_set {
my $config = new VyattaConfig;
$config->setLevel("system");
- my $domainname = undef;
- $domainname = $config->returnValue("domain-name");
- return $domainname;
+ return $config->returnValue("domain-name");
}
-sub is_ethernet_mtu_set {
+sub get_mtu {
my $intf = shift;
my $config = new VyattaConfig;
- $config->setLevel("interfaces ethernet $intf");
- my $interface_mtu = undef;
- $interface_mtu = $config->returnValue("mtu");
- return $interface_mtu;
+ $config->setLevel("interfaces $intf");
+ return $config->returnValue("mtu");
}
sub dhcp_update_config {
@@ -210,12 +209,20 @@ sub dhcp_update_config {
if (!defined($domainname)) {
$output .= ", domain-name";
}
+
+ ## FIXME more code depending on name
+ my $mtu;
if ($intf =~ m/^eth[0-9]+$/) {
- my $interface_mtu = is_ethernet_mtu_set($intf);
- if (!defined($interface_mtu)) {
- $output .= ", interface-mtu";
- }
+ ## XXX what about vif?
+ $mtu = get_mtu("ethernet $intf");
+ } elsif ($intf =~ m/^bond[0-9]+$/) {
+ $mtu = get_mtu("bonding $intf");
+ } elsif ($intf =~ m/^br[0-9]+$/) {
+ ## bridge doesn't have mtu yet
+ $mtu = get_mtu("bridge $intf");
}
+
+ $mtu or $output .= ", interface-mtu";
$output .= ";\n";
$output .= "}\n\n";