xref: /openbmc/qemu/docs/system/devices/usb.rst (revision 7619129f)
1USB emulation
2-------------
3
4QEMU can emulate a PCI UHCI, OHCI, EHCI or XHCI USB controller. You can
5plug virtual USB devices or real host USB devices (only works with
6certain host operating systems). QEMU will automatically create and
7connect virtual USB hubs as necessary to connect multiple USB devices.
8
9USB controllers
10~~~~~~~~~~~~~~~
11
12XHCI controller support
13^^^^^^^^^^^^^^^^^^^^^^^
14
15QEMU has XHCI host adapter support.  The XHCI hardware design is much
16more virtualization-friendly when compared to EHCI and UHCI, thus XHCI
17emulation uses less resources (especially CPU).  So if your guest
18supports XHCI (which should be the case for any operating system
19released around 2010 or later) we recommend using it:
20
21    |qemu_system| -device qemu-xhci
22
23XHCI supports USB 1.1, USB 2.0 and USB 3.0 devices, so this is the
24only controller you need.  With only a single USB controller (and
25therefore only a single USB bus) present in the system there is no
26need to use the bus= parameter when adding USB devices.
27
28
29EHCI controller support
30^^^^^^^^^^^^^^^^^^^^^^^
31
32The QEMU EHCI Adapter supports USB 2.0 devices.  It can be used either
33standalone or with companion controllers (UHCI, OHCI) for USB 1.1
34devices.  The companion controller setup is more convenient to use
35because it provides a single USB bus supporting both USB 2.0 and USB
361.1 devices.  See next section for details.
37
38When running EHCI in standalone mode you can add UHCI or OHCI
39controllers for USB 1.1 devices too.  Each controller creates its own
40bus though, so there are two completely separate USB buses: One USB
411.1 bus driven by the UHCI controller and one USB 2.0 bus driven by
42the EHCI controller.  Devices must be attached to the correct
43controller manually.
44
45The easiest way to add a UHCI controller to a ``pc`` machine is the
46``-usb`` switch.  QEMU will create the UHCI controller as function of
47the PIIX3 chipset.  The USB 1.1 bus will carry the name ``usb-bus.0``.
48
49You can use the standard ``-device`` switch to add a EHCI controller to
50your virtual machine.  It is strongly recommended to specify an ID for
51the controller so the USB 2.0 bus gets an individual name, for example
52``-device usb-ehci,id=ehci``.  This will give you a USB 2.0 bus named
53``ehci.0``.
54
55When adding USB devices using the ``-device`` switch you can specify the
56bus they should be attached to.  Here is a complete example:
57
58.. parsed-literal::
59
60    |qemu_system| -M pc ${otheroptions}                        \\
61        -drive if=none,id=usbstick,format=raw,file=/path/to/image   \\
62        -usb                                                        \\
63        -device usb-ehci,id=ehci                                    \\
64        -device usb-tablet,bus=usb-bus.0                            \\
65        -device usb-storage,bus=ehci.0,drive=usbstick
66
67This attaches a USB tablet to the UHCI adapter and a USB mass storage
68device to the EHCI adapter.
69
70
71Companion controller support
72^^^^^^^^^^^^^^^^^^^^^^^^^^^^
73
74The UHCI and OHCI controllers can attach to a USB bus created by EHCI
75as companion controllers.  This is done by specifying the ``masterbus``
76and ``firstport`` properties.  ``masterbus`` specifies the bus name the
77controller should attach to.  ``firstport`` specifies the first port the
78controller should attach to, which is needed as usually one EHCI
79controller with six ports has three UHCI companion controllers with
80two ports each.
81
82There is a config file in docs which will do all this for
83you, which you can use like this:
84
85.. parsed-literal::
86
87   |qemu_system| -readconfig docs/config/ich9-ehci-uhci.cfg
88
89Then use ``bus=ehci.0`` to assign your USB devices to that bus.
90
91Using the ``-usb`` switch for ``q35`` machines will create a similar
92USB controller configuration.
93
94
95.. _Connecting USB devices:
96
97Connecting USB devices
98~~~~~~~~~~~~~~~~~~~~~~
99
100USB devices can be connected with the ``-device usb-...`` command line
101option or the ``device_add`` monitor command. Available devices are:
102
103``usb-mouse``
104   Virtual Mouse. This will override the PS/2 mouse emulation when
105   activated.
106
107``usb-tablet``
108   Pointer device that uses absolute coordinates (like a touchscreen).
109   This means QEMU is able to report the mouse position without having
110   to grab the mouse. Also overrides the PS/2 mouse emulation when
111   activated.
112
113``usb-storage,drive=drive_id``
114   Mass storage device backed by drive_id (see the :ref:`disk images`
115   chapter in the System Emulation Users Guide). This is the classic
116   bulk-only transport protocol used by 99% of USB sticks. This
117   example shows it connected to an XHCI USB controller and with
118   a drive backed by a raw format disk image:
119
120   .. parsed-literal::
121
122       |qemu_system| [...]                                   \\
123        -drive if=none,id=stick,format=raw,file=/path/to/file.img \\
124        -device nec-usb-xhci,id=xhci                              \\
125        -device usb-storage,bus=xhci.0,drive=stick
126
127``usb-uas``
128   USB attached SCSI device. This does not create a SCSI disk, so
129   you need to explicitly create a ``scsi-hd`` or ``scsi-cd`` device
130   on the command line, as well as using the ``-drive`` option to
131   specify what those disks are backed by. One ``usb-uas`` device can
132   handle multiple logical units (disks). This example creates three
133   logical units: two disks and one cdrom drive:
134
135   .. parsed-literal::
136
137      |qemu_system| [...]                                         \\
138       -drive if=none,id=uas-disk1,format=raw,file=/path/to/file1.img  \\
139       -drive if=none,id=uas-disk2,format=raw,file=/path/to/file2.img  \\
140       -drive if=none,id=uas-cdrom,media=cdrom,format=raw,file=/path/to/image.iso \\
141       -device nec-usb-xhci,id=xhci                                    \\
142       -device usb-uas,id=uas,bus=xhci.0                               \\
143       -device scsi-hd,bus=uas.0,scsi-id=0,lun=0,drive=uas-disk1       \\
144       -device scsi-hd,bus=uas.0,scsi-id=0,lun=1,drive=uas-disk2       \\
145       -device scsi-cd,bus=uas.0,scsi-id=0,lun=5,drive=uas-cdrom
146
147``usb-bot``
148   Bulk-only transport storage device. This presents the guest with the
149   same USB bulk-only transport protocol interface as ``usb-storage``, but
150   the QEMU command line option works like ``usb-uas`` and does not
151   automatically create SCSI disks for you. ``usb-bot`` supports up to
152   16 LUNs. Unlike ``usb-uas``, the LUN numbers must be continuous,
153   i.e. for three devices you must use 0+1+2. The 0+1+5 numbering from the
154   ``usb-uas`` example above won't work with ``usb-bot``.
155
156``usb-mtp,rootdir=dir``
157   Media transfer protocol device, using dir as root of the file tree
158   that is presented to the guest.
159
160``usb-host,hostbus=bus,hostaddr=addr``
161   Pass through the host device identified by bus and addr
162
163``usb-host,vendorid=vendor,productid=product``
164   Pass through the host device identified by vendor and product ID
165
166``usb-wacom-tablet``
167   Virtual Wacom PenPartner tablet. This device is similar to the
168   ``tablet`` above but it can be used with the tslib library because in
169   addition to touch coordinates it reports touch pressure.
170
171``usb-kbd``
172   Standard USB keyboard. Will override the PS/2 keyboard (if present).
173
174``usb-serial,chardev=id``
175   Serial converter. This emulates an FTDI FT232BM chip connected to
176   host character device id.
177
178``usb-braille,chardev=id``
179   Braille device. This emulates a Baum Braille device USB port. id has to
180   specify a character device defined with ``-chardev …,id=id``.  One will
181   normally use BrlAPI to display the braille output on a BRLTTY-supported
182   device with
183
184   .. parsed-literal::
185
186      |qemu_system| [...] -chardev braille,id=brl -device usb-braille,chardev=brl
187
188   or alternatively, use the following equivalent shortcut:
189
190   .. parsed-literal::
191
192      |qemu_system| [...] -usbdevice braille
193
194``usb-net[,netdev=id]``
195   Network adapter that supports CDC ethernet and RNDIS protocols. id
196   specifies a netdev defined with ``-netdev …,id=id``. For instance,
197   user-mode networking can be used with
198
199   .. parsed-literal::
200
201      |qemu_system| [...] -netdev user,id=net0 -device usb-net,netdev=net0
202
203``usb-ccid``
204   Smartcard reader device
205
206``usb-audio``
207   USB audio device
208
209``u2f-{emulated,passthru}``
210   :doc:`usb-u2f`
211
212``canokey``
213   An Open-source Secure Key implementing FIDO2, OpenPGP, PIV and more.
214   For more information, see :ref:`canokey`.
215
216Physical port addressing
217^^^^^^^^^^^^^^^^^^^^^^^^
218
219For all the above USB devices, by default QEMU will plug the device
220into the next available port on the specified USB bus, or onto
221some available USB bus if you didn't specify one explicitly.
222If you need to, you can also specify the physical port where
223the device will show up in the guest.  This can be done using the
224``port`` property.  UHCI has two root ports (1,2).  EHCI has six root
225ports (1-6), and the emulated (1.1) USB hub has eight ports.
226
227Plugging a tablet into UHCI port 1 works like this::
228
229        -device usb-tablet,bus=usb-bus.0,port=1
230
231Plugging a hub into UHCI port 2 works like this::
232
233        -device usb-hub,bus=usb-bus.0,port=2
234
235Plugging a virtual USB stick into port 4 of the hub just plugged works
236this way::
237
238        -device usb-storage,bus=usb-bus.0,port=2.4,drive=...
239
240In the monitor, the ``device_add` command also accepts a ``port``
241property specification. If you want to unplug devices too you should
242specify some unique id which you can use to refer to the device.
243You can then use ``device_del`` to unplug the device later.
244For example::
245
246        (qemu) device_add usb-tablet,bus=usb-bus.0,port=1,id=my-tablet
247        (qemu) device_del my-tablet
248
249Hotplugging USB storage
250~~~~~~~~~~~~~~~~~~~~~~~
251
252The ``usb-bot`` and ``usb-uas`` devices can be hotplugged.  In the hotplug
253case they are added with ``attached = false`` so the guest will not see
254the device until the ``attached`` property is explicitly set to true.
255That allows you to attach one or more scsi devices before making the
256device visible to the guest. The workflow looks like this:
257
258#. ``device-add usb-bot,id=foo``
259#. ``device-add scsi-{hd,cd},bus=foo.0,lun=0``
260#. optionally add more devices (luns 1 ... 15)
261#. ``scripts/qmp/qom-set foo.attached = true``
262
263.. _host_005fusb_005fdevices:
264
265Using host USB devices on a Linux host
266~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
267
268WARNING: this is an experimental feature. QEMU will slow down when using
269it. USB devices requiring real time streaming (i.e. USB Video Cameras)
270are not supported yet.
271
2721. If you use an early Linux 2.4 kernel, verify that no Linux driver is
273   actually using the USB device. A simple way to do that is simply to
274   disable the corresponding kernel module by renaming it from
275   ``mydriver.o`` to ``mydriver.o.disabled``.
276
2772. Verify that ``/proc/bus/usb`` is working (most Linux distributions
278   should enable it by default). You should see something like that:
279
280   ::
281
282      ls /proc/bus/usb
283      001  devices  drivers
284
2853. Since only root can access to the USB devices directly, you can
286   either launch QEMU as root or change the permissions of the USB
287   devices you want to use. For testing, the following suffices:
288
289   ::
290
291      chown -R myuid /proc/bus/usb
292
2934. Launch QEMU and do in the monitor:
294
295   ::
296
297      info usbhost
298        Device 1.2, speed 480 Mb/s
299          Class 00: USB device 1234:5678, USB DISK
300
301   You should see the list of the devices you can use (Never try to use
302   hubs, it won't work).
303
3045. Add the device in QEMU by using:
305
306   ::
307
308      device_add usb-host,vendorid=0x1234,productid=0x5678
309
310   Normally the guest OS should report that a new USB device is plugged.
311   You can use the option ``-device usb-host,...`` to do the same.
312
3136. Now you can try to use the host USB device in QEMU.
314
315When relaunching QEMU, you may have to unplug and plug again the USB
316device to make it work again (this is a bug).
317
318``usb-host`` properties for specifying the host device
319^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
320
321The example above uses the ``vendorid`` and ``productid`` to
322specify which host device to pass through, but this is not
323the only way to specify the host device. ``usb-host`` supports
324the following properties:
325
326``hostbus=<nr>``
327  Specifies the bus number the device must be attached to
328``hostaddr=<nr>``
329  Specifies the device address the device got assigned by the guest os
330``hostport=<str>``
331  Specifies the physical port the device is attached to
332``vendorid=<hexnr>``
333  Specifies the vendor ID of the device
334``productid=<hexnr>``
335  Specifies the product ID of the device.
336
337In theory you can combine all these properties as you like.  In
338practice only a few combinations are useful:
339
340- ``vendorid`` and ``productid`` -- match for a specific device, pass it to
341  the guest when it shows up somewhere in the host.
342
343- ``hostbus`` and ``hostport`` -- match for a specific physical port in the
344  host, any device which is plugged in there gets passed to the
345  guest.
346
347- ``hostbus`` and ``hostaddr`` -- most useful for ad-hoc pass through as the
348  hostaddr isn't stable. The next time you plug the device into the host it
349  will get a new hostaddr.
350
351Note that on the host USB 1.1 devices are handled by UHCI/OHCI and USB
3522.0 by EHCI.  That means different USB devices plugged into the very
353same physical port on the host may show up on different host buses
354depending on the speed. Supposing that devices plugged into a given
355physical port appear as bus 1 + port 1 for 2.0 devices and bus 3 + port 1
356for 1.1 devices, you can pass through any device plugged into that port
357and also assign it to the correct USB bus in QEMU like this:
358
359.. parsed-literal::
360
361   |qemu_system| -M pc [...]                            \\
362        -usb                                                 \\
363        -device usb-ehci,id=ehci                             \\
364        -device usb-host,bus=usb-bus.0,hostbus=3,hostport=1  \\
365        -device usb-host,bus=ehci.0,hostbus=1,hostport=1
366
367``usb-host`` properties for reset behavior
368^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
369
370The ``guest-reset`` and ``guest-reset-all`` properties control
371whenever the guest is allowed to reset the physical usb device on the
372host.  There are three cases:
373
374``guest-reset=false``
375  The guest is not allowed to reset the (physical) usb device.
376
377``guest-reset=true,guest-resets-all=false``
378  The guest is allowed to reset the device when it is not yet
379  initialized (aka no usb bus address assigned).  Usually this results
380  in one guest reset being allowed.  This is the default behavior.
381
382``guest-reset=true,guest-resets-all=true``
383  The guest is allowed to reset the device as it pleases.
384
385The reason for this existing are broken usb devices.  In theory one
386should be able to reset (and re-initialize) usb devices at any time.
387In practice that may result in shitty usb device firmware crashing and
388the device not responding any more until you power-cycle (aka un-plug
389and re-plug) it.
390
391What works best pretty much depends on the behavior of the specific
392usb device at hand, so it's a trial-and-error game.  If the default
393doesn't work, try another option and see whenever the situation
394improves.
395
396record usb transfers
397^^^^^^^^^^^^^^^^^^^^
398
399All usb devices have support for recording the usb traffic.  This can
400be enabled using the ``pcap=<file>`` property, for example:
401
402``-device usb-mouse,pcap=mouse.pcap``
403
404The pcap files are compatible with the linux kernels usbmon.  Many
405tools, including ``wireshark``, can decode and inspect these trace
406files.
407