core-admin/doc
Wojtek Porczyk 9eafa57539 Merge remote-tracking branch 'marmarek/master' into core3-devel
The following list is bollocks. There were many, many more.

Conflicts:
    core-modules/003QubesTemplateVm.py
    core-modules/005QubesNetVm.py
    core/qubes.py
    core/storage/__init__.py
    core/storage/xen.py
    doc/qvm-tools/qvm-pci.rst
    doc/qvm-tools/qvm-prefs.rst
    qubes/tools/qmemmand.py
    qvm-tools/qvm-create
    qvm-tools/qvm-prefs
    qvm-tools/qvm-start
    tests/__init__.py
    vm-config/xen-vm-template-hvm.xml

This commit took 2 days (26-27.01.2016) and put our friendship to test.
    --Wojtek and Marek
2016-03-03 01:13:51 +01:00
..
_static doc: Fix docutils table column width 2015-06-29 17:39:25 +02:00
_templates doc: Fix docutils table column width 2015-06-29 17:39:25 +02:00
manpages Merge remote-tracking branch 'marmarek/master' into core3-devel 2016-03-03 01:13:51 +01:00
qubes-tools qubes: Documentation for qubes.tools 2015-06-29 17:39:28 +02:00
qubes-vm qubes: port netvm 2016-03-03 00:46:05 +01:00
.gitignore doc: Add autogenerated qubes.xml documentation 2015-06-29 17:39:25 +02:00
conf.py core3: Add documentation to qubes.exc 2015-10-17 00:20:44 +02:00
example.xml doc: Add autogenerated qubes.xml documentation 2015-06-29 17:39:25 +02:00
index.rst core3: Add documentation to qubes.exc 2015-10-17 00:20:44 +02:00
Makefile doc: Add autogenerated qubes.xml documentation 2015-06-29 17:39:25 +02:00
qubes-dochelpers.rst
qubes-events.rst doc: Tutorial for qubes.events and fix 2015-06-29 17:39:25 +02:00
qubes-exc.rst core3: Add documentation to qubes.exc 2015-10-17 00:20:44 +02:00
qubes-ext.rst qubes: documentation and licence fixes 2015-06-29 17:39:27 +02:00
qubes-log.rst
qubes-plugins.rst
qubes-tests.rst qubes/doc: Test's documentation improvement 2015-06-29 17:39:24 +02:00
qubes.rst qubes: more documentation and doc fixes 2015-06-29 17:39:28 +02:00
README.pvusb
skel-manpage.py qubes: Documentation for qubes.tools 2015-06-29 17:39:28 +02:00

Dedicated usbvm (optional)
~~~~~~~~~~~~~~~~~~~~~~~~~~

In dom0, once:
 qvm-create -l red usbvm

 # FIXME: use your own PCI device IDs
 qvm-pci -a usbvm 00:1d.0
 qvm-pci -a usbvm 00:1d.1
 qvm-pci -a usbvm 00:1d.2
 qvm-pci -a usbvm 00:1d.7

After each dom0 reboot:
 qvm-start usbvm

List
~~~~

In dom0:
 qvm-usb -l

Example output:
 dom0:7-4        0718:061a TDKMedia_Trans-It_Drive_070326AE8AF92D95 (attached to qdvp:0-1)
 dom0:7-5        0b05:1706 ASUS_802.11g_WLAN_Drive (attached to sys-net:0-1)
 dom0:1-1        045e:0084 Microsoft_Basic_Optical_Mouse
 usbvm:4-6       05e3:0723 Generic_USB_Storage (attached to qdvp:1-1)

Attach
~~~~~~

In dom0:
 qvm-usb -a [--no-auto-detach] <vm-name> <device-vm-name>:<backend-controller>-<backend-port>

Example:
 qvm-usb -a sys-net usbvm:4-1

Detach
~~~~~~

In dom0:
 qvm-usb -d <vm-name>:<vusb-controller>-<vusb-port>

Example:
 qvm-usb -d sys-net:0-1

Known issues
~~~~~~~~~~~~

List/attach/detach operations seem to work ok, devices are recognized by the target VM etc.
But actual usage of the attached devices is unstable at best. In fact the only working device
I saw was one USB stick (and this only after it took a minute to time out and reset the bus
couple times). Kernel crashes are normal as well. I have not investigated these issues yet,
I had similar experience with Marek's scripts.

* System keyboard / mouse are listed and can be detached away
* Virtual USB devices (ones created by PVUSB frontend) may be listed
* The installation/configuration is not persistent, not retained between reboots
* No debugging / logging / audit trail
* When an attached device is physically unplugged, USB port remains mapped but not displayed
in the list. If device is plugged back it continues to work. Unlisted device cannot be detached.
* We are not attaching actual devices, but USB ports (different behavior from VMWare, might be confusing)
* After device is detached from the frontend and returned back to the backend it is not alwayws usable there
* Code changing configuration of pvusb fe/be and vusb bind/unbind helper are located
misc/xl-qvm-usb-attach.py misc/xl-qvm-usb-detach.py misc/vusb-ctl.py. These helpers are
deployed into the backend domain. The initialization code is qubesutils.py in usb_setup(),
should probably also be moved into an external helper. Perhaps the functionality of these
external helpers should be merged into libxl? The is one catch is invokation of vusb helper
in the backend domain -- now it relies on qubes-specific API.
* After reboot attached USB devices are not listed by 'qvm-usb -l' until replugged.