Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
…riov-network-operator/pull/240/files#r808624002

Allow to use BF in connectX mode also for OCP platform.
This is needed until we support the systemd configuration

Signed-off-by: Sebastian Sch [email protected]
Signed-off-by: Sebastian Sch <[email protected]>
  • Loading branch information
SchSeba committed Sep 12, 2022
1 parent cbd2557 commit 374d929
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 13 deletions.
11 changes: 10 additions & 1 deletion pkg/plugins/generic/generic_plugin.go
Original file line number Diff line number Diff line change
Expand Up @@ -87,12 +87,21 @@ func (p *GenericPlugin) Apply() error {
return nil
}
}

// Create a map with all the PFs we will need to configure
// we need to create it here before we access the host file system using the chroot function
// because the skipConfigVf needs the mstconfig package that exist only inside the sriov-config-daemon file system
pfsToSkip, err := utils.GetPfsToSkip(p.DesireState)
if err != nil {
return err
}

exit, err := utils.Chroot("/host")
if err != nil {
return err
}
defer exit()
if err := utils.SyncNodeState(p.DesireState); err != nil {
if err := utils.SyncNodeState(p.DesireState, pfsToSkip); err != nil {
return err
}
p.LastState = &sriovnetworkv1.SriovNetworkNodeState{}
Expand Down
10 changes: 9 additions & 1 deletion pkg/utils/switchdev.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,15 +29,23 @@ func IsSwitchdevModeSpec(spec sriovnetworkv1.SriovNetworkNodeStateSpec) bool {
}

func WriteSwitchdevConfFile(newState *sriovnetworkv1.SriovNetworkNodeState) (update bool, err error) {
// Create a map with all the PFs we will need to SKIP for systemd configuration
pfsToSkip, err := GetPfsToSkip(newState)
if err != nil {
return false, err
}

cfg := config{}
for _, iface := range newState.Spec.Interfaces {
for _, ifaceStatus := range newState.Status.Interfaces {
if iface.PciAddress != ifaceStatus.PciAddress {
continue
}
if !SkipConfigVf(iface, ifaceStatus) {

if skip := pfsToSkip[iface.PciAddress]; !skip {
continue
}

i := sriovnetworkv1.Interface{}
if iface.NumVfs > 0 {
i = sriovnetworkv1.Interface{
Expand Down
60 changes: 49 additions & 11 deletions pkg/utils/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,7 @@ func DiscoverSriovDevices(withUnsupported bool) ([]sriovnetworkv1.InterfaceExt,

// SyncNodeState Attempt to update the node state to match the desired state
//
func SyncNodeState(newState *sriovnetworkv1.SriovNetworkNodeState) error {
func SyncNodeState(newState *sriovnetworkv1.SriovNetworkNodeState, pfsToConfig map[string]bool) error {
if IsKernelLockdownMode(true) && hasMellanoxInterfacesInSpec(newState) {
glog.Warningf("cannot use mellanox devices when in kernel lockdown mode")
return fmt.Errorf("cannot use mellanox devices when in kernel lockdown mode")
Expand All @@ -157,10 +157,11 @@ func SyncNodeState(newState *sriovnetworkv1.SriovNetworkNodeState) error {
for _, iface := range newState.Spec.Interfaces {
if iface.PciAddress == ifaceStatus.PciAddress {
configured = true
if SkipConfigVf(iface, ifaceStatus) {
glog.V(2).Infof("syncNodeState(): skip config VF in config daemon for %s, it shall be done by switchdev-configuration.service", iface.PciAddress)

if skip := pfsToConfig[iface.PciAddress]; skip {
break
}

if !needUpdate(&iface, &ifaceStatus) {
glog.V(2).Infof("syncNodeState(): no need update interface %s", iface.PciAddress)
break
Expand All @@ -175,7 +176,11 @@ func SyncNodeState(newState *sriovnetworkv1.SriovNetworkNodeState) error {
break
}
}
if !configured && ifaceStatus.NumVfs > 0 && !SkipConfigVf(sriovnetworkv1.Interface{}, ifaceStatus) {
if !configured && ifaceStatus.NumVfs > 0 {
if skip := pfsToConfig[ifaceStatus.PciAddress]; skip {
continue
}

if err = resetSriovDevice(ifaceStatus); err != nil {
return err
}
Expand All @@ -184,18 +189,51 @@ func SyncNodeState(newState *sriovnetworkv1.SriovNetworkNodeState) error {
return nil
}

// SkipConfigVf Use systemd service to configure switchdev mode or BF-2 NICs in OpenShift
func SkipConfigVf(ifSpec sriovnetworkv1.Interface, ifStatus sriovnetworkv1.InterfaceExt) bool {
// skipConfigVf Use systemd service to configure switchdev mode or BF-2 NICs in OpenShift
func skipConfigVf(ifSpec sriovnetworkv1.Interface, ifStatus sriovnetworkv1.InterfaceExt) (bool, error) {
if ifSpec.EswitchMode == sriovnetworkv1.ESwithModeSwitchDev {
glog.V(2).Infof("SkipConfigVf(): skip config VF for switchdev device")
return true
glog.V(2).Infof("skipConfigVf(): skip config VF for switchdev device")
return true, nil
}

// Nvidia_mlx5_MT42822_BlueField-2_integrated_ConnectX-6_Dx in OpenShift
if ClusterType == ClusterTypeOpenshift && ifStatus.Vendor == VendorMellanox && ifStatus.DeviceID == DeviceBF2 {
glog.V(2).Infof("SkipConfigVf(): skip config VF for BF2 device")
return true
// TODO: remove this when switch to the systemd configuration support.
mode, err := mellanoxBlueFieldMode(ifStatus.PciAddress)
if err != nil {
return false, fmt.Errorf("failed to read Mellanox Bluefield card mode for %s,%v", ifStatus.PciAddress, err)
}

if mode == bluefieldConnectXMode {
return false, nil
}

glog.V(2).Infof("skipConfigVf(): skip config VF for Bluefiled card on DPU mode")
return true, nil
}
return false

return false, nil
}

// GetPfsToSkip return a map of devices pci addresses to should be configured via systemd instead if the legacy mode
// we skip devices in switchdev mode and Bluefield card in ConnectX mode
func GetPfsToSkip(ns *sriovnetworkv1.SriovNetworkNodeState) (map[string]bool, error) {
vfsToSkip := map[string]bool{}
for _, ifaceStatus := range ns.Status.Interfaces {
for _, iface := range ns.Spec.Interfaces {
if iface.PciAddress == ifaceStatus.PciAddress {
skip, err := skipConfigVf(iface, ifaceStatus)
if err != nil {
glog.Errorf("GetPfsToSkip(): fail to check for skip VFs %s: %v.", iface.PciAddress, err)
return vfsToSkip, err
}
vfsToSkip[iface.PciAddress] = skip
break
}
}
}

return vfsToSkip, nil
}

func needUpdate(iface *sriovnetworkv1.Interface, ifaceStatus *sriovnetworkv1.InterfaceExt) bool {
Expand Down

0 comments on commit 374d929

Please sign in to comment.