$ oc get featuregate cluster -o yamlAs a cluster administrator, you can expose USB devices in a cluster, which makes the devices available for virtual machine (VM) owners to assign to VMs. Enabling this passthrough of USB devices allows a VM to connect to USB hardware that is attached to an OKD node, as if the hardware and the VM are physically connected.
To expose a USB device, first enable host passthrough and then configure the VM to use the USB device.
To attach a USB device to a virtual machine (VM), you must first enable USB host passthrough at the cluster level.
To do this, specify a resource name and USB device name for each device you want first to add and then assign to a VM. You can allocate more than one device, each of which is known as a selector in the HyperConverged custom resource (CR), to a single resource name. If you have multiple identical USB devices on the cluster, you can choose to allocate a VM to a specific device.
You have access to an OKD cluster as a user who has the cluster-admin role.
You have installed the OpenShift CLI (oc).
Ensure that the HostDevices feature gate is enabled:
$ oc get featuregate cluster -o yamlSuccessful output
  featureGates:
# ...
    enabled:
    - name: HostDevicesIdentify the USB device vendor and product:
$ lsusbExample output
Bus 003 Device 007: ID 1b1c:0a60 example_manufacturer example_product_nameIf you cannot use the lsusb command, inspect the USB device configurations in the host’s /sys/bus/usb/devices/ directory:
for dev in *; do
    if [[ -f "$dev/idVendor" && -f "$dev/idProduct" ]]; then
        echo "Device: $dev"
        echo -n "  Manufacturer : "; cat "$dev/manufacturer"
        echo -n "  Product: "; cat "$dev/product"
        echo -n "  Vendor ID : "; cat "$dev/idVendor"
        echo -n "  Product ID: "; cat "$dev/idProduct"
        echo
    fi
doneExample output
Device: 3-7
  Manufacturer : example_manufacturer
  Product: example_product_name
  Vendor ID : 1b1c
  Product ID: 0a60Add the required USB device to the permittedHostDevices stanza of the HyperConvered CR. The following example adds a device with vendor ID 045e and product ID 07a5:
oc patch hyperconverged kubevirt-hyperconverged \
  -n openshift-cnv \
  --type=merge \
  -p '{
    "metadata": {
      "annotations": {
        "kubevirt.kubevirt.io/jsonpatch": "[{\"op\": \"add\", \"path\": \"/spec/permittedHostDevices/usbHostDevices/-\", \"value\": {\"resourceName\": \"kubevirt.io/peripherals\", \"selectors\": [{\"vendor\": \"045e\", \"product\": \"07a5\"}]}}]"
      }
    }
  }'Ensure that the HCO CR contains the required USB devices:
$ oc get hyperconverged kubevirt-hyperconverged -n openshift-cnvExample output
apiVersion: hco.kubevirt.io/v1beta1
kind: HyperConverged
metadata:
   name: kubevirt-hyperconverged
   namespace: kubevirt-hyperconverged
spec:
    permittedHostDevices: (1)
      usbHostDevices: (2)
        - resourceName: kubevirt.io/peripherals (3)
          selectors:
            - vendor: "045e"
              product: "07a5"
            - vendor: "062a"
              product: "4102"
            - vendor: "072f"
              product: "b100"| 1 | Lists the host devices that have permission to be used in the cluster. | 
| 2 | Lists the available USB devices. | 
| 3 | Uses resourceName: deviceNamefor each device you want to add and assign to the VM. In this example, the resource is bound to three devices, each of which is identified byvendorandproductand is known as aselector. | 
You can configure virtual machine (VM) access to a USB device. This configuration enables the VM to connect to USB hardware that is attached to an OKD node, as if the hardware and the VM are physically connected.
You have installed the OpenShift CLI (oc).
You have attached the required USB device as a resource at the cluster level.
In the HyperConverged custom resource (CR), find the assigned resource name of the USB device:
$ oc get hyperconverged kubevirt-hyperconverged -n openshift-cnvExample output
# ...
  spec:
    permittedHostDevices:
      usbHostDevices:
        - resourceName: kubevirt.io/peripherals
          selectors:
            - vendor: "045e"
              product: "07a5"
            - vendor: "062a"
              product: "4102"
            - vendor: "072f"
              product: "b100"Open the VM instance CR:
$ oc edit vmi <vmi_usb>where:
Specifies the name of the VirtualMachineInstance CR.
Edit the CR by adding the USB device, as shown in the following example:
Example configuration
apiVersion: kubevirt.io/v1
kind: VirtualMachineInstance
metadata:
  labels:
    special: vmi-usb
  name: vmi-usb
spec:
  domain:
    devices:
      hostDevices:
      - deviceName: kubevirt.io/peripherals
        name: local-peripherals (1)
# ...| 1 | The name of the USB device. | 
Apply the modifications to the VM configurations:
$ oc apply -f <filename>.yamlwhere:
Specifies the name of the VirtualMachineInstance manifest YAML file.