]> git.proxmox.com Git - pve-network.git/commitdiff
vlan plugin: add support for no vlan-aware bridge
authorAlexandre Derumier <aderumier@odiso.com>
Fri, 8 May 2020 09:00:44 +0000 (11:00 +0200)
committerThomas Lamprecht <t.lamprecht@proxmox.com>
Fri, 8 May 2020 09:52:11 +0000 (11:52 +0200)
Some users could have problem with vlan-aware and some nics.

Signed-off-by: Alexandre Derumier <aderumier@odiso.com>
PVE/Network/SDN/Zones/Plugin.pm
PVE/Network/SDN/Zones/VlanPlugin.pm

index aa53cce5921f27e3fa6e0958279f543ba6959540..2335d9eb2066848ddd39b59ff552d0aca7b58545 100644 (file)
@@ -219,7 +219,8 @@ sub get_bridge_vlan {
 sub tap_create {
     my ($class, $plugin_config, $vnet, $iface, $vnetid) = @_;
 
-    my ($bridge, undef) = $class->get_bridge_vlan($plugin_config, $vnetid);
+    my $tag = $vnet->{tag};
+    my ($bridge, undef) = $class->get_bridge_vlan($plugin_config, $vnetid, $tag);
     die "unable to get bridge setting\n" if !$bridge;
 
     PVE::Network::tap_create($iface, $bridge);
@@ -228,7 +229,8 @@ sub tap_create {
 sub veth_create {
     my ($class, $plugin_config, $vnet, $veth, $vethpeer, $vnetid, $hwaddr) = @_;
 
-    my ($bridge, undef) = $class->get_bridge_vlan($plugin_config, $vnetid);
+    my $tag = $vnet->{tag};
+    my ($bridge, undef) = $class->get_bridge_vlan($plugin_config, $vnetid, $tag);
     die "unable to get bridge setting\n" if !$bridge;
 
     PVE::Network::veth_create($veth, $vethpeer, $bridge, $hwaddr);
index 28d6a00c035bcd08053df001d83745b993f0a425..b0d37845a83a905e76c4fee0f0d6ad32474d7e88 100644 (file)
@@ -32,13 +32,47 @@ sub options {
     return {
         nodes => { optional => 1},
        'bridge' => { optional => 0 },
+       mtu => { optional => 1 }
     };
 }
 
 # Plugin implementation
 sub generate_sdn_config {
     my ($class, $plugin_config, $zoneid, $vnetid, $vnet, $controller, $interfaces_config, $config) = @_;
-    return "";
+
+    my $bridge = $plugin_config->{bridge};
+    my $vlan_aware = PVE::Tools::file_read_firstline("/sys/class/net/$bridge/bridge/vlan_filtering");
+    my $is_ovs = 1 if !-d "/sys/class/net/$bridge/brif";
+    return if $vlan_aware || $is_ovs;
+
+    my $tag = $vnet->{tag};
+    my $alias = $vnet->{alias};
+    my $mtu = $plugin_config->{mtu} if $plugin_config->{mtu};
+    my $bridgevlan = $bridge."v".$tag;
+
+    my @bridge_ifaces = ();
+    my $dir = "/sys/class/net/$bridge/brif";
+    PVE::Tools::dir_glob_foreach($dir, '(((eth|bond)\d+|en[^.]+)(\.\d+)?)', sub {
+        push @bridge_ifaces, $_[0];
+    });
+
+    my $bridge_ports = "";
+    $bridge_ports = "none" if scalar(@bridge_ifaces) == 0;
+
+    foreach my $bridge_iface (@bridge_ifaces) {
+       $bridge_ports .= " $bridge_iface.$tag";
+    }
+
+    #vnet bridge (keep vmbrXvY for compatibility)
+    my @iface_config = ();
+    push @iface_config, "bridge_ports $bridge_ports";
+    push @iface_config, "bridge_stp off";
+    push @iface_config, "bridge_fd 0";
+    push @iface_config, "mtu $mtu" if $mtu;
+    push @iface_config, "alias $alias" if $alias;
+    push(@{$config->{$bridgevlan}}, @iface_config) if !$config->{$vnetid};
+
+    return $config;
 }
 
 sub status {
@@ -71,7 +105,8 @@ sub get_bridge_vlan {
     my $vlan_aware = PVE::Tools::file_read_firstline("/sys/class/net/$bridge/bridge/vlan_filtering");
     my $is_ovs = 1 if !-d "/sys/class/net/$bridge/brif";
 
-    die "bridge $bridge is not vlan aware" if !$is_ovs && !$vlan_aware;
+    
+    return ($bridge."v".$tag, undef) if !$is_ovs && !$vlan_aware;
 
     return ($bridge, $tag);
 }