How to Use USB Devices with a VMware vSphere Virtual Machine

The main function of a hypervisor is to emulate devices used by VMs at the software level. Devices are created in a VM, whether virtual controllers, disks, DVD-ROM, video cards, network cards, input devices, etc. But what if you want to connect a printer, scanner, USB flash drive, USB hard disk drive, USB smart card reader, security dongles, USB license keys, etc.?

For external physical devices with a USB interface, you can attach them to a VM running on VMware Workstation or an ESXi server by using the USB passthrough feature. This blog post covers using this feature in VMware vSphere on ESXi hosts, including requirements and the steps for connecting USB devices.

NAKIVO for VMware vSphere Backup

NAKIVO for VMware vSphere Backup

Complete data protection for VMware vSphere VMs and instant recovery options. Secure backup targets onsite, offsite and in the cloud. Anti-ransomware features.

What Is USB Passthrough?

VMware USB device passthrough is a feature that allows you to connect a physical USB device attached to a USB port of a physical ESXi server to a virtual machine as if the USB device was connected to a virtual machine directly. VMware passthrough is a feature available starting with ESXi 4.1.

Reasons vary for using passthrough for a USB device from the ESXi server to a guest operating system (OS) of a virtual machine. For example, you have an old scanner or printer that doesn’t have drivers for the latest Windows OS versions. You can install the old Windows version supported by the USB device and connect this device to a virtual machine. Another use case of this feature is when you need to copy files from/to a USB hard disk drive to/from a virtual machine directly with high speed. It may happen that users need to use software that is protected by hardware USB license keys on virtual machines.

How USB Passthrough Works

There are three main components required for USB passthrough functioning: the arbitrator, USB controller, and physical USB device.

The arbitrator is a dedicated service on an ESXi server. The arbitrator scans physical USB devices attached to the physical server and is responsible for USB device traffic routing between a physical host and a virtual machine. Only one VM can access the USB device at a time. Access to the USB device connected to one VM is blocked for other VMs. The USB arbitrator supports up to 15 USB controllers (vSphere 7.0). The Arbitrator service is enabled on ESXi by default.

A USB controller used on a physical ESXi server is the controller to which physical USB ports are connected. The physical USB controller works with physical USB devices inserted into the physical USB ports of the server. USB controllers can be onboard (they are also called integrated and are built-in on a chip in a motherboard) or external (implemented as PCI or PCIe cards that are inserted into the appropriate slots on a motherboard of a server). The onboard USB controller acts as a bridge between a USB bus and a PCIe (or PCI) bus. The onboard USB controller is physically connected by the appropriate number of PCIe lanes to a chipset on a motherboard.

A virtual USB controller is an emulated device created especially for a virtual machine running on a hypervisor. A virtual USB controller interacts with a physical USB controller when you passthrough a physical USB device from a physical ESXi server to a guest OS on the VM. Presence of a virtual USB controller in VM configuration is required to use the USB passthrough feature on the VM. A maximum of eight virtual USB controllers can be connected to a VM on an ESXi host. If you need to remove a virtual USB controller from a VM configuration, you have to remove all USB devices connected to that controller first. VMware USB driver is installed in a guest OS after adding a virtual USB controller to VM configuration.

A physical USB device is any USB device that has a USB interface and USB port for being connected to a computer. Maximum 20 USB devices can be connected to a single VM or ESXi host.

USB standards and controller modes are:

  • USB 2.0 and USB 1.1 (EHCI+UHCI)
  • USB 3.0 (xHCI) VM hardware version 8 or higher

After connecting a physical USB device to a virtual machine by using the VMware USB passthrough feature, you may need to install drivers for the connected USB device in a guest operating system.

Requirements for USB 3.0

USB 3.0 is available for ESXi servers starting from VMware vSphere 5.5 patch 3. The xHCI USB controller is required in VM configuration for this purpose. OS requirements to use USB 3.0 passthrough are: Windows 8.1 or higher, Windows Server 2012 R2 or higher, or Linux with Linux kernel 2.6.35 or higher. USB 3.1 devices are supported on their maximum speed since VMware vSphere 7.0

Limitations for USB Passthrough

There are some limitations you should know about before starting to use the USB passthrough feature:

  • A USB drive cannot be used as a boot drive for a VM.
  • If a USB drive is used to boot ESXi, this USB drive cannot be attached to a VM.
  • Virtual hardware version 7 or higher is required for a VM.

Some USB devices can be not supported by VMware:

  • USB hubs
  • Audio devices and video cameras that use asynchronous data transfer
  • Some USB keyboards and mice (you can find details in the VMware 1021345 article)
  • Some smart cards using CCID may need additional tuning for connection to a VM

vMotion is possible for VMs with connected USB passthrough devices. After proper VM configuration and enabling vMotion, USB devices remain connected to the VM after migration to another ESXi host.

There are vMotion limitations for VMs that use USB passthrough disks:

  • Distributed Power Management (DPM) is not supported because an ESXi host cannot be shut down for power saving without disconnecting a USB device from a VM (a USB device is disconnected if the host is powered off by DPM). DPM should be disabled on this host.
  • Fault Tolerance is not supported.
  • A VM cannot be suspended or powered off (otherwise USB devices are disconnected from a VM and they can be reconnected only after migration of the VM to the initial ESXi server to which USB devices are physically connected). The VM must be manually migrated to the ESXi host with the attached USB device when you need to power on this VM. Linux guests that were resumed can mount USB devices to different mount points after reconnection.
  • ESXi hosts that have VMs with USB passthrough devices must be accessible via the VM kernel interface vmk0 (for the management network) and TCP port 902.

Disconnect USB devices from a VM before using the hot-add feature and adding CPU, memory, or PCI devices. Otherwise USB devices are disconnected automatically, and when you use the hot-add feature, some data can be lost. If you suspend a VM and then resume the VM, USB devices are disconnected and then reconnected to the VM again.

As for creating a VMware virtual USB drive or virtual flash drive for attaching to a virtual machine running on ESXi or VMware Workstation, just like you would mount a virtual floppy disk or CD/DVD disc, currently this option is not possible.

How to Connect a USB Device to a VM

Now that we have familiarized with the theory, we can go to the practical part and look at configuration in VMware vSphere.

  1. Insert a USB device into a USB port of your ESXi server. In my case, I’m going to insert a USB flash drive.
  2. You can check whether the USB device is connected to ESXi after that in the ESXi command line interface:
    lsusb
  3. As you can see on the screenshot below, my flash drive is now connected to the ESXi server.VMware USB devices configuration
  4. The USB arbitrator service must be running. You can check the service status with the command:
    chkconfig usbarbitrator –list
  5. If the USB arbitrator is stopped, you can start the USB arbitrator with the command:
    /etc/init.d/usbarbitrator start

    Note: Read more about ESXiCLI in the blog post.

    The VM is residing on the ESXi host that is managed by vCenter Server in my example. Windows is installed as a guest OS on my VM. Open VMware vSphere Client, go to Hosts and Clusters. In the Navigator pane select a virtual machine to which you want to connect the USB device by using the passthrough feature. The VM should be in the powered-off state. You should install VMware Tools in the guest OS.

  6. Once the VM is selected, click Actions > Edit settings.Editing VM settings to connect USB drive to VMware virtual machine
  7. In the Edit Settings window, check whether a USB controller is present in the VM configuration. If the USB controller is missing, click Add New Device > USB Controller, and select the USB controller type (USB 2.0 or USB 3.0).
  8. If the USB controller is present, you should add the USB device that is attached to the ESXi server to your VM. Click Add New Device > Host USB Device.Adding a VMware USB device to a virtual machine
  9. A new string is added to the VM configuration. In the New USB Host device string, select one USB device that you want to connect to the VM. Now I have two USB flash drives attached to my physical ESXi server, and I’m connecting the Verbatim Flash drive to my VM (Verbatim product 0x0302).

    If you need to enable vMotion support, expand New Host USB device, and select the “Support vMotion while device is connected” checkbox. Keep in mind vMotion requirements and limitations. Hit OK to save the configuration and close this window.VM USB configuration – selecting a USB device that should be connected to a VM

  10. Start a virtual machine. Once the guest OS is loaded, wait until the USB flash drive is initialized and installed. Then open Windows Device Manager. Right click My Computer and, in the context menu, click Manage. In the Computer Management Window, click Device Manager and expand the Disk drives section (as we connect a USB flash drive, this device should be displayed in this category of devices). We can see Verbatim USB device, which is the name of my USB flash drive connected to the VM with the VMware USB Passthrough feature.
  11. Open Disk Management in the Computer Management window, and make sure that a disk drive is assigned to the USB flash drive. In my case, everything is correct, and I can now copy data from the USB flash drive to the virtual disk of a VM in guest Windows and vice versa.ESXi USB passthrough is working and a USB drive is connected to a VM

VMware PCI Passthrough

If the USB device that you want to connect to a VM by using the VMware USB passthrough feature is not supported by VMware, you can try using the PCI passthrough feature and connecting the entire physical USB controller that has the PCI interface to a VM.

If your ESXi server has a USB controller inserted into a PCI slot, you can passthrough this PCI device to a virtual machine. VMware PCI passthrough is also called VMDirectPass. This method is less convenient than using USB passthrough but can help you get the task done.

Requirements

Intel Directed I/O or AMD I/O Virtualization Technology (AMD IOMMU) must be supported by server hardware and enabled in UEFI/BIOS. If you have only one USB controller in your server, you should attach an additional USB controller to avoid losing connections to USB devices used by your physical ESXi server.

Restrictions and limitations:

  • A VM cannot be suspended.
  • A VM cannot be migrated to other ESXi hosts with vMotion.
  • VM snapshots are not supported.

Let’s look at the workflow of connecting a USB device to a VM by using PCI passthrough and connecting the entire USB controller to which a USB device is connected to a VM.

  1. In order to identify the USB device and USB controller to which your USB device is connected (if there are multiple USB controllers installed on your server) use this command:
    lsusb -v | grep -e Bus -e iSerial
  2. Find the string with the name of your USB device connected to the USB controller and identify the id of the controller (for example, bus002).
  3. You can check the VMkernel log when connecting a USB device to an ESXi server:
    tail -f /var/log/vmkernel.log | grep -i USB
  4. Open VMware vSphere Client, and go to Hosts and Clusters.
  5. Select the ESXi host on which your VM (to which you need to connect a USB device) is residing.
  6. Go to the Configure tab, then select PCI Devices in the Hardware section.
  7. Find and select the needed USB controller in the list of PCI devices by using the ID you have detected before.
  8. The status of the selected controller should now change to Available.
  9. Hit OK to save settings.
  10. Reboot the ESXi host for changes to take effect.
  11. Make sure that your VM is powered off. Go to VM settings, click Add New Device > PCI device > Add. Select your USB controller in the dropdown menu by using the correct ID.
  12. Power On the VM. Check devices in the guest OS. If Windows is installed on the VM, open Device Manager, then check controllers and storage devices.

Connecting USB Smart Cards

Some USB devices that have the appropriate class of CCID may not be supported by default for connection to VMs. The error message “Cannot connect ‘path:0/1/6/1’ to this virtual machine. The device was not found” is displayed. In logs, you can see the message:

(vmx-vcpu-0) did not claim interface 0 before use

PCSCD is the ESXi daemon that controls smart card readers. Access to USB smart cards is disabled for virtual machines to avoid conflicts because a smart card is needed by an ESXi server. As a result, you cannot use USB passthrough with default configuration for USB smart cards. You need to edit the configuration of the ESXi host to enable USB passthrough for USB smart cards.

  1. Stop the virtual machine. Open virtual machine settings, select the VM Options tab, and click Edit Configuration.Editing VM options for VM USB smart card connection
  2. In the Configuration Parameters window, click Add Configuration Params.Editing VM USB configuration for a USB smart card reader
    As an alternative, you can edit the VMX configuration file of the virtual machine in the command line interface by connecting to ESXi console with an SSH client.
  3. Edit or add this line to the VM configuration if the parameter is not present:

    usb.generic.allowCCID = “TRUE”
  4. Save VM configuration.
  5. Stop the PCSCD service by using this command in the ESXi command line:

    sudo /etc/init.d/pcscd stop
  6. Make sure that the PCSCD service is not running:

    ps | grep pcscd
  7. Power on the VM, and check devices to verify that the USB smart card reader is now connected to the VM.

Conclusion

You can connect diverse devices attached to USB ports of physical ESXi servers to virtual machines directly and use them in guest operating systems of VMs just like you use these USB devices on regular physical computers. You can even migrate virtual machines using external USB devices connected to the parent ESXi host with vMotion to another host. Despite some limitations, the VMware USB passthrough feature adds more capabilities and flexibility in different situations.

VMware VM backup is important for those who use VMware vSphere. Download NAKIVO Backup & Replication and try this universal data protection solution to protect your VMware vSphere VMs and other data in your environment.

1 Year of Free Data Protection: NAKIVO Backup & Replication

1 Year of Free Data Protection: NAKIVO Backup & Replication

Deploy in 2 minutes and protect virtual, cloud, physical and SaaS data. Backup, replication, instant recovery options.

People also read