[Kimchi-devel] [PATCH v7 0/4] Host device passthrough: Summary

Aline Manera alinefm at linux.vnet.ibm.com
Sun Jul 13 14:51:17 UTC 2014



On 07/09/2014 04:01 AM, Zhou Zheng Sheng wrote:
> Hi,
>
> This patch series is to enable Kimchi to assign hos devices directly to
> a VM, thus greately improve VM performance. Currently we support assigning
> PCI device, USB device and SCSI LUN. For example, we can assign an NIC
> to VM to improve guest network throughput, or passthrough a USB camera
> to enable the guest OS to record video.
>
> Host devices form a tree. We can assign most of the devices in the tree
> to VM. By assigning a device, all the devices in its sub-tree are also
> assigned. It might not make sense to assign a USB controller, because
> the host may be using one of the devices connected to the controller.
> Instead, Kimchi just presents the "leaf" devices to assign to guest.
>
> In recent Linux kernel and KVM, it is able to recognize the IOMMU group
> of a PCI device. The "leaf" PCI devices in the same IOMMU group should
> be assigned and dismissed together. The IOMMU group is the actual
> smallest isolation granularity of the PCI devices.
>
> The first patch is to list all host devices information. It's useful on
> its own to show host devices information.
>
> The second patch is to list all eligible host devices to assign, as well
> as the "affected" devices in the same IOMMU group.
>
> The third patch creates a sub-collection "hostdevs" to the VM resource,
> and deals with assigning and dismissing devices.
>
> The fourth patch adds a sub-collection "vm_holders" to the host device
> resource. It's to list all VMs that are holding the device.
>
> I'll update API and unit test once everyone is happy with the interface
> and logic.
>

Don't forget to also update mockmodel.py to reflect those changes.

> v7:
>    Some minor coding style improvements.
> v6:
>    Do not passthrough PCI device of class code 0x07. It might contains
> system device not suitable to assign to guest.
> v5:
>    Filter ealigible pci devices according to pci class. When assigning a
> device to VM, check if there are other VMs holding it. Use
> "kimchi.model.utils.get_vm_config_flag()" to correctly set the device
> attaching API flag.
> v4:
>    Add new sub-collection to host device to list the VMs holding the device.
> v3:
>    Fix a small naming error introduced by rebase.
> v2:
>    Handle the devices in VM's sub-collection "hostdevs".
> v1:
>    Handle the devices in VM template.
>
> Zhou Zheng Sheng (4):
>    Host device passthrough: List all types of host devices
>    Host device passthrough: List eligible device to passthrough
>    Host device passthrough: Directly assign and dissmis host device from
>      VM
>    Host device passthrough: List VMs that are holding a host device
>
>   docs/API.md                            |  11 +-
>   src/kimchi/control/host.py             |  16 ++
>   src/kimchi/control/vm/hostdevs.py      |  44 +++++
>   src/kimchi/featuretests.py             |  10 +-
>   src/kimchi/hostdev.py                  | 311 +++++++++++++++++++++++++++++++
>   src/kimchi/i18n.py                     |   9 +
>   src/kimchi/mockmodel.py                |   7 +-
>   src/kimchi/model/config.py             |   2 +
>   src/kimchi/model/host.py               |  32 ++--
>   src/kimchi/model/libvirtstoragepool.py |  18 +-
>   src/kimchi/model/vmhostdevs.py         | 323 +++++++++++++++++++++++++++++++++
>   src/kimchi/rollbackcontext.py          |   3 +
>   src/kimchi/xmlutils.py                 |  26 ++-
>   tests/test_rest.py                     |   6 +-
>   tests/test_storagepool.py              |   7 +-
>   15 files changed, 786 insertions(+), 39 deletions(-)
>   create mode 100644 src/kimchi/control/vm/hostdevs.py
>   create mode 100644 src/kimchi/hostdev.py
>   create mode 100644 src/kimchi/model/vmhostdevs.py
>




More information about the Kimchi-devel mailing list