Skip to content

Commit

Permalink
Merge pull request k8snetworkplumbingwg#252 from rollandf/unsupported…
Browse files Browse the repository at this point in the history
…-nic

Skip unsupported NICs in DiscoverSriovDevices
  • Loading branch information
adrianchiris authored Mar 28, 2022
2 parents ac60ddd + b62accf commit b876ce5
Show file tree
Hide file tree
Showing 11 changed files with 91 additions and 24 deletions.
2 changes: 2 additions & 0 deletions bindata/manifests/daemon/daemonset.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,8 @@ spec:
fieldPath: metadata.namespace
- name: CLUSTER_TYPE
value: "{{.ClusterType}}"
- name: DEV_MODE
value: "{{.DevMode}}"
resources:
requests:
cpu: 100m
Expand Down
2 changes: 2 additions & 0 deletions bindata/manifests/operator-webhook/server.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,8 @@ spec:
valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: DEV_MODE
value: "{{.DevMode}}"
resources:
requests:
cpu: 10m
Expand Down
10 changes: 9 additions & 1 deletion cmd/sriov-network-config-daemon/start.go
Original file line number Diff line number Diff line change
Expand Up @@ -130,8 +130,16 @@ func runStartCmd(cmd *cobra.Command, args []string) {

config.Timeout = 5 * time.Second
writerclient := snclientset.NewForConfigOrDie(config)

mode := os.Getenv("DEV_MODE")
devMode := false
if mode == "TRUE" {
devMode = true
glog.V(0).Info("dev mode enabled")
}

glog.V(0).Info("starting node writer")
nodeWriter := daemon.NewNodeStateStatusWriter(writerclient, startOpts.nodeName, closeAllConns)
nodeWriter := daemon.NewNodeStateStatusWriter(writerclient, startOpts.nodeName, closeAllConns, devMode)

destdir := os.Getenv("DEST_DIR")
if destdir == "" {
Expand Down
2 changes: 2 additions & 0 deletions controllers/sriovoperatorconfig_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,7 @@ func (r *SriovOperatorConfigReconciler) syncConfigDaemonSet(dc *sriovnetworkv1.S
data.Data["SRIOVInfiniBandCNIImage"] = os.Getenv("SRIOV_INFINIBAND_CNI_IMAGE")
data.Data["ReleaseVersion"] = os.Getenv("RELEASEVERSION")
data.Data["ClusterType"] = utils.ClusterType
data.Data["DevMode"] = os.Getenv("DEV_MODE")
envCniBinPath := os.Getenv("SRIOV_CNI_BIN_PATH")
if envCniBinPath == "" {
data.Data["CNIBinPath"] = "/var/lib/cni/bin"
Expand Down Expand Up @@ -231,6 +232,7 @@ func (r *SriovOperatorConfigReconciler) syncWebhookObjs(dc *sriovnetworkv1.Sriov
data.Data["ReleaseVersion"] = os.Getenv("RELEASEVERSION")
data.Data["ClusterType"] = utils.ClusterType
data.Data["CaBundle"] = os.Getenv("WEBHOOK_CA_BUNDLE")
data.Data["DevMode"] = os.Getenv("DEV_MODE")
objs, err := render.RenderDir(path, &data)
if err != nil {
logger.Error(err, "Fail to render webhook manifests")
Expand Down
2 changes: 2 additions & 0 deletions deploy/operator.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,8 @@ spec:
value: $RESOURCE_PREFIX
- name: ENABLE_ADMISSION_CONTROLLER
value: "$ENABLE_ADMISSION_CONTROLLER"
- name: DEV_MODE
value: "$DEV_MODE"
- name: NAMESPACE
valueFrom:
fieldRef:
Expand Down
11 changes: 11 additions & 0 deletions doc/hacking.md
Original file line number Diff line number Diff line change
Expand Up @@ -97,3 +97,14 @@ Before deploying the Operator, you want to export these variables to use that cu
```bash
export SRIOV_NETWORK_CONFIG_DAEMON_IMAGE=<path to custom image>
(...)

## Enable Unsupported NICs

By default, unsupported NICs are not reported in `SriovNetworkNodeState` and
are not allowed in `SriovNetworkNodePolicy` by the webhook.

If you want to allow unsupported NICs, set the `DEV_MODE` env var to `TRUE`.

```bash
export DEV_MODE=TRUE
```
1 change: 1 addition & 0 deletions hack/env.sh
Original file line number Diff line number Diff line change
Expand Up @@ -35,3 +35,4 @@ export ENABLE_ADMISSION_CONTROLLER=${ENABLE_ADMISSION_CONTROLLER:-"true"}
export CLUSTER_TYPE=${CLUSTER_TYPE:-openshift}
export NAMESPACE=${NAMESPACE:-"openshift-sriov-network-operator"}
export WEBHOOK_CA_BUNDLE=${WEBHOOK_CA_BUNDLE:-""}
export DEV_MODE=${DEV_MODE:-"FALSE"}
24 changes: 13 additions & 11 deletions pkg/daemon/writer.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,20 +23,22 @@ const (
)

type NodeStateStatusWriter struct {
client snclientset.Interface
node string
status sriovnetworkv1.SriovNetworkNodeStateStatus
OnHeartbeatFailure func()
metaData *utils.OSPMetaData
networkData *utils.OSPNetworkData
client snclientset.Interface
node string
status sriovnetworkv1.SriovNetworkNodeStateStatus
OnHeartbeatFailure func()
metaData *utils.OSPMetaData
networkData *utils.OSPNetworkData
withUnsupportedDevices bool
}

// NewNodeStateStatusWriter Create a new NodeStateStatusWriter
func NewNodeStateStatusWriter(c snclientset.Interface, n string, f func()) *NodeStateStatusWriter {
func NewNodeStateStatusWriter(c snclientset.Interface, n string, f func(), devMode bool) *NodeStateStatusWriter {
return &NodeStateStatusWriter{
client: c,
node: n,
OnHeartbeatFailure: f,
client: c,
node: n,
OnHeartbeatFailure: f,
withUnsupportedDevices: devMode,
}
}

Expand Down Expand Up @@ -96,7 +98,7 @@ func (writer *NodeStateStatusWriter) pollNicStatus(platformType utils.PlatformTy
if platformType == utils.VirtualOpenStack {
iface, err = utils.DiscoverSriovDevicesVirtual(platformType, writer.metaData, writer.networkData)
} else {
iface, err = utils.DiscoverSriovDevices()
iface, err = utils.DiscoverSriovDevices(writer.withUnsupportedDevices)
}
if err != nil {
return err
Expand Down
9 changes: 8 additions & 1 deletion pkg/utils/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ func init() {
ClusterType = os.Getenv("CLUSTER_TYPE")
}

func DiscoverSriovDevices() ([]sriovnetworkv1.InterfaceExt, error) {
func DiscoverSriovDevices(withUnsupported bool) ([]sriovnetworkv1.InterfaceExt, error) {
glog.V(2).Info("DiscoverSriovDevices")
pfList := []sriovnetworkv1.InterfaceExt{}

Expand Down Expand Up @@ -96,6 +96,13 @@ func DiscoverSriovDevices() ([]sriovnetworkv1.InterfaceExt, error) {
continue
}

if !withUnsupported {
if !sriovnetworkv1.IsSupportedModel(device.Vendor.ID, device.Product.ID) {
glog.Infof("DiscoverSriovDevices(): unsupported device %+v", device)
continue
}
}

iface := sriovnetworkv1.InterfaceExt{
PciAddress: device.Address,
Driver: driver,
Expand Down
30 changes: 19 additions & 11 deletions pkg/webhook/validate.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,18 +96,26 @@ func staticValidateSriovNetworkNodePolicy(cr *sriovnetworkv1.SriovNetworkNodePol
return false, fmt.Errorf("at least one of these parameters (vendor, deviceID, pfNames, rootDevices or netFilter) has to be defined in nicSelector in CR %s", cr.GetName())
}

if cr.Spec.NicSelector.Vendor != "" {
if !sriovnetworkv1.IsSupportedVendor(cr.Spec.NicSelector.Vendor) {
return false, fmt.Errorf("vendor %s is not supported", cr.Spec.NicSelector.Vendor)
}
if cr.Spec.NicSelector.DeviceID != "" {
if !sriovnetworkv1.IsSupportedModel(cr.Spec.NicSelector.Vendor, cr.Spec.NicSelector.DeviceID) {
return false, fmt.Errorf("vendor/device %s/%s is not supported", cr.Spec.NicSelector.Vendor, cr.Spec.NicSelector.DeviceID)
devMode := false
if os.Getenv("DEV_MODE") == "TRUE" {
devMode = true
glog.V(0).Info("dev mode enabled - Admitting not supported NICs")
}

if !devMode {
if cr.Spec.NicSelector.Vendor != "" {
if !sriovnetworkv1.IsSupportedVendor(cr.Spec.NicSelector.Vendor) {
return false, fmt.Errorf("vendor %s is not supported", cr.Spec.NicSelector.Vendor)
}
if cr.Spec.NicSelector.DeviceID != "" {
if !sriovnetworkv1.IsSupportedModel(cr.Spec.NicSelector.Vendor, cr.Spec.NicSelector.DeviceID) {
return false, fmt.Errorf("vendor/device %s/%s is not supported", cr.Spec.NicSelector.Vendor, cr.Spec.NicSelector.DeviceID)
}
}
} else if cr.Spec.NicSelector.DeviceID != "" {
if !sriovnetworkv1.IsSupportedDevice(cr.Spec.NicSelector.DeviceID) {
return false, fmt.Errorf("device %s is not supported", cr.Spec.NicSelector.DeviceID)
}
}
} else if cr.Spec.NicSelector.DeviceID != "" {
if !sriovnetworkv1.IsSupportedDevice(cr.Spec.NicSelector.DeviceID) {
return false, fmt.Errorf("device %s is not supported", cr.Spec.NicSelector.DeviceID)
}
}

Expand Down
22 changes: 22 additions & 0 deletions pkg/webhook/validate_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -339,6 +339,28 @@ func TestStaticValidateSriovNetworkNodePolicyWithInvalidVendor(t *testing.T) {
g.Expect(ok).To(Equal(false))
}

func TestStaticValidateSriovNetworkNodePolicyWithInvalidVendorDevMode(t *testing.T) {
t.Setenv("DEV_MODE", "TRUE")
policy := &SriovNetworkNodePolicy{
Spec: SriovNetworkNodePolicySpec{
DeviceType: "netdevice",
NicSelector: SriovNetworkNicSelector{
Vendor: "8087",
},
NodeSelector: map[string]string{
"feature.node.kubernetes.io/network-sriov.capable": "true",
},
NumVfs: 63,
Priority: 99,
ResourceName: "p0",
},
}
g := NewGomegaWithT(t)
ok, err := staticValidateSriovNetworkNodePolicy(policy)
g.Expect(err).NotTo(HaveOccurred())
g.Expect(ok).To(Equal(true))
}

func TestStaticValidateSriovNetworkNodePolicyWithInvalidDevice(t *testing.T) {
policy := &SriovNetworkNodePolicy{
Spec: SriovNetworkNodePolicySpec{
Expand Down

0 comments on commit b876ce5

Please sign in to comment.