From 84d0a6d3e00fd79c0b8e76b72507a5b3b5ad1439 Mon Sep 17 00:00:00 2001 From: Fred Rolland Date: Sun, 12 Jan 2025 14:36:23 +0200 Subject: [PATCH] ovs: add internal interface When creating a bridge with ovs-vsctl, an internal interface is added by default. The same behavior is added in this commit ovs-vsctl code ref: https://github.com/openvswitch/ovs/blob/main/utilities/ovs-vsctl.c#L1597 Signed-off-by: Fred Rolland --- pkg/host/internal/bridge/ovs/ovs.go | 9 ++++++++ pkg/host/internal/bridge/ovs/ovs_test.go | 29 +++++++++++++++++++----- 2 files changed, 32 insertions(+), 6 deletions(-) diff --git a/pkg/host/internal/bridge/ovs/ovs.go b/pkg/host/internal/bridge/ovs/ovs.go index e4bae9f81..2e7cf7015 100644 --- a/pkg/host/internal/bridge/ovs/ovs.go +++ b/pkg/host/internal/bridge/ovs/ovs.go @@ -148,6 +148,15 @@ func (o *ovs) CreateOVSBridge(ctx context.Context, conf *sriovnetworkv1.OVSConfi funcLog.Error(err, "CreateOVSBridge(): failed to get bridge after creation") return err } + funcLog.V(2).Info("CreateOVSBridge(): add internal interface to the bridge") + if err := o.addInterface(ctx, dbClient, bridge, &InterfaceEntry{ + Name: bridge.Name, + UUID: uuid.NewString(), + Type: "internal", + }); err != nil { + funcLog.Error(err, "CreateOVSBridge(): failed to add internal interface to the bridge") + return err + } funcLog.V(2).Info("CreateOVSBridge(): add uplink interface to the bridge") if err := o.addInterface(ctx, dbClient, bridge, &InterfaceEntry{ Name: conf.Uplinks[0].Name, diff --git a/pkg/host/internal/bridge/ovs/ovs_test.go b/pkg/host/internal/bridge/ovs/ovs_test.go index 66be5e8ed..290994307 100644 --- a/pkg/host/internal/bridge/ovs/ovs_test.go +++ b/pkg/host/internal/bridge/ovs/ovs_test.go @@ -141,26 +141,43 @@ func createInitialDBContent(ctx context.Context, c client.Client, expectedState func validateDBConfig(dbContent *testDBEntries, conf *sriovnetworkv1.OVSConfigExt) { Expect(dbContent.OpenVSwitch).To(HaveLen(1)) Expect(dbContent.Bridge).To(HaveLen(1)) - Expect(dbContent.Interface).To(HaveLen(1)) - Expect(dbContent.Port).To(HaveLen(1)) + Expect(dbContent.Interface).To(HaveLen(2)) + Expect(dbContent.Port).To(HaveLen(2)) ovs := dbContent.OpenVSwitch[0] br := dbContent.Bridge[0] - port := dbContent.Port[0] - iface := dbContent.Interface[0] + ports := make(map[string]*PortEntry, 0) + interfaces := make(map[string]*InterfaceEntry, 0) + for _, p := range dbContent.Port { + ports[p.Name] = p + } + for _, ifc := range dbContent.Interface { + interfaces[ifc.Name] = ifc + } Expect(ovs.Bridges).To(ContainElement(br.UUID)) Expect(br.Name).To(Equal(conf.Name)) Expect(br.DatapathType).To(Equal(conf.Bridge.DatapathType)) Expect(br.OtherConfig).To(Equal(conf.Bridge.OtherConfig)) Expect(br.ExternalIDs).To(Equal(conf.Bridge.ExternalIDs)) + port, ok := ports[conf.Uplinks[0].Name] + Expect(ok).To(BeTrue()) Expect(br.Ports).To(ContainElement(port.UUID)) - Expect(port.Name).To(Equal(conf.Uplinks[0].Name)) + iface, ok := interfaces[conf.Uplinks[0].Name] + Expect(ok).To(BeTrue()) Expect(port.Interfaces).To(ContainElement(iface.UUID)) - Expect(iface.Name).To(Equal(conf.Uplinks[0].Name)) Expect(iface.Options).To(Equal(conf.Uplinks[0].Interface.Options)) Expect(iface.Type).To(Equal(conf.Uplinks[0].Interface.Type)) Expect(iface.OtherConfig).To(Equal(conf.Uplinks[0].Interface.OtherConfig)) Expect(iface.ExternalIDs).To(Equal(conf.Uplinks[0].Interface.ExternalIDs)) Expect(iface.MTURequest).To(Equal(conf.Uplinks[0].Interface.MTURequest)) + internalPort, ok := ports[conf.Name] + Expect(ok).To(BeTrue()) + internalIface, ok := interfaces[conf.Name] + Expect(ok).To(BeTrue()) + Expect(internalPort.Interfaces).To(ContainElement(internalIface.UUID)) + Expect(internalIface.Options).To(BeNil()) + Expect(internalIface.Type).To(Equal("internal")) + Expect(internalIface.OtherConfig).To(BeNil()) + Expect(internalIface.ExternalIDs).To(BeNil()) } var _ = Describe("OVS", func() {