2020-07-02 13:25:19 +01:00
|
|
|
[package]
|
|
|
|
name = "virtio-devices"
|
|
|
|
version = "0.1.0"
|
|
|
|
authors = ["The Cloud Hypervisor Authors"]
|
2022-04-08 15:11:04 +00:00
|
|
|
edition = "2021"
|
2020-07-02 13:25:19 +01:00
|
|
|
|
|
|
|
[features]
|
|
|
|
default = []
|
2021-07-12 14:40:50 -07:00
|
|
|
mshv = []
|
2020-07-02 13:25:19 +01:00
|
|
|
|
|
|
|
[dependencies]
|
2022-03-07 23:49:42 +00:00
|
|
|
anyhow = "1.0.56"
|
2021-11-15 23:09:49 +00:00
|
|
|
arc-swap = "1.5.0"
|
2020-08-03 19:45:53 -07:00
|
|
|
block_util = { path = "../block_util" }
|
2021-03-10 12:36:39 +00:00
|
|
|
byteorder = "1.4.3"
|
2021-08-06 10:11:40 +01:00
|
|
|
epoll = "4.3.1"
|
2021-02-18 15:10:51 +00:00
|
|
|
event_monitor = { path = "../event_monitor" }
|
2021-08-23 23:07:20 +00:00
|
|
|
io-uring = "0.5.2"
|
2022-04-12 23:19:07 +00:00
|
|
|
libc = "0.2.123"
|
2022-03-25 16:52:26 +00:00
|
|
|
log = "0.4.16"
|
2020-07-02 13:25:19 +01:00
|
|
|
net_gen = { path = "../net_gen" }
|
|
|
|
net_util = { path = "../net_util" }
|
2020-10-15 17:54:56 +02:00
|
|
|
pci = { path = "../pci" }
|
2021-03-22 11:23:51 -07:00
|
|
|
rate_limiter = { path = "../rate_limiter" }
|
2021-10-01 10:29:21 -07:00
|
|
|
seccompiler = "0.2.0"
|
2022-01-26 14:12:30 +00:00
|
|
|
serde = "1.0.136"
|
2022-01-26 15:14:53 +00:00
|
|
|
serde_derive = "1.0.136"
|
2022-02-14 23:14:11 +00:00
|
|
|
serde_json = "1.0.79"
|
virtio-devices: Add Vdpa device
vDPA is a kernel framework introduced fairly recently in order to handle
devices complying with virtio specification on their datapath, while the
control path is vendor specific. For the datapath, that means the
virtqueues are handled through DMA directly between the hardware and the
guest, while the control path goes through the vDPA framework,
eventually exposed through a vhost-vdpa device.
vDPA, like VFIO, aims at achieving baremetal performance for devices
that are passed into a VM. But unlike VFIO, it provides a simpler/better
framework for achieving migration. Because the DMA accesses between the
device and the guest are going through virtio queues, migration can be
achieved way more easily, and doesn't require each device driver to
implement the migration support. In the VFIO case, each vendor is
expected to provide an implementation of the VFIO migration framework,
which makes things harder as it must be done for each and every device.
So to summarize the point is to support migration for hardware devices
through which we can achieve baremetal performances.
Signed-off-by: Sebastien Boeuf <sebastien.boeuf@intel.com>
2022-03-07 15:34:44 +01:00
|
|
|
thiserror = "1.0.30"
|
2021-05-06 13:34:31 +00:00
|
|
|
versionize = "0.1.6"
|
|
|
|
versionize_derive = "0.1.4"
|
2022-03-25 17:11:56 +01:00
|
|
|
vhost = { version = "0.4.0", features = ["vhost-user-master", "vhost-user-slave", "vhost-kern", "vhost-vdpa"] }
|
2021-08-10 14:52:10 +01:00
|
|
|
virtio-bindings = { version = "0.1.0", features = ["virtio-v5_0_0"] }
|
2022-03-07 13:47:51 +01:00
|
|
|
virtio-queue = "0.2.0"
|
2020-07-02 13:25:19 +01:00
|
|
|
vm-allocator = { path = "../vm-allocator" }
|
|
|
|
vm-device = { path = "../vm-device" }
|
2021-12-21 10:21:37 +01:00
|
|
|
vm-memory = { version = "0.7.0", features = ["backend-mmap", "backend-atomic", "backend-bitmap"] }
|
2020-07-02 13:25:19 +01:00
|
|
|
vm-migration = { path = "../vm-migration" }
|
|
|
|
vm-virtio = { path = "../vm-virtio" }
|
2021-09-15 00:12:33 +00:00
|
|
|
vmm-sys-util = "0.9.0"
|