xref: /qemu/include/hw/virtio/vhost.h (revision 9be6e69f12bc65e9c43ee5b8eb026412f11b8b71)
1d5970055SMichael S. Tsirkin #ifndef VHOST_H
2d5970055SMichael S. Tsirkin #define VHOST_H
3d5970055SMichael S. Tsirkin 
4d5970055SMichael S. Tsirkin #include "hw/hw.h"
524d1eb33SNikolay Nikolaev #include "hw/virtio/vhost-backend.h"
60d09e41aSPaolo Bonzini #include "hw/virtio/virtio.h"
7022c62cbSPaolo Bonzini #include "exec/memory.h"
8d5970055SMichael S. Tsirkin 
9d5970055SMichael S. Tsirkin /* Generic structures common for any vhost based device. */
10d5970055SMichael S. Tsirkin struct vhost_virtqueue {
11d5970055SMichael S. Tsirkin     int kick;
12d5970055SMichael S. Tsirkin     int call;
13d5970055SMichael S. Tsirkin     void *desc;
14d5970055SMichael S. Tsirkin     void *avail;
15d5970055SMichael S. Tsirkin     void *used;
16d5970055SMichael S. Tsirkin     int num;
17d5970055SMichael S. Tsirkin     unsigned long long used_phys;
18d5970055SMichael S. Tsirkin     unsigned used_size;
19d5970055SMichael S. Tsirkin     void *ring;
20d5970055SMichael S. Tsirkin     unsigned long long ring_phys;
21d5970055SMichael S. Tsirkin     unsigned ring_size;
22f56a1247SMichael S. Tsirkin     EventNotifier masked_notifier;
23d5970055SMichael S. Tsirkin };
24d5970055SMichael S. Tsirkin 
25d5970055SMichael S. Tsirkin typedef unsigned long vhost_log_chunk_t;
26d5970055SMichael S. Tsirkin #define VHOST_LOG_PAGE 0x1000
27d5970055SMichael S. Tsirkin #define VHOST_LOG_BITS (8 * sizeof(vhost_log_chunk_t))
28d5970055SMichael S. Tsirkin #define VHOST_LOG_CHUNK (VHOST_LOG_PAGE * VHOST_LOG_BITS)
292e6d46d7SNikolay Nikolaev #define VHOST_INVALID_FEATURE_BIT   (0xff)
30d5970055SMichael S. Tsirkin 
31d5970055SMichael S. Tsirkin struct vhost_memory;
32d5970055SMichael S. Tsirkin struct vhost_dev {
3304097f7cSAvi Kivity     MemoryListener memory_listener;
34d5970055SMichael S. Tsirkin     struct vhost_memory *mem;
352817b260SAvi Kivity     int n_mem_sections;
362817b260SAvi Kivity     MemoryRegionSection *mem_sections;
37d5970055SMichael S. Tsirkin     struct vhost_virtqueue *vqs;
38d5970055SMichael S. Tsirkin     int nvqs;
39*9be6e69fSGreg Kurz     /* the first virtqueue which would be used by this vhost dev */
40a9f98bb5SJason Wang     int vq_index;
41d5970055SMichael S. Tsirkin     unsigned long long features;
42d5970055SMichael S. Tsirkin     unsigned long long acked_features;
43d5970055SMichael S. Tsirkin     unsigned long long backend_features;
44d5970055SMichael S. Tsirkin     bool started;
45d5970055SMichael S. Tsirkin     bool log_enabled;
46d5970055SMichael S. Tsirkin     vhost_log_chunk_t *log;
47d5970055SMichael S. Tsirkin     unsigned long long log_size;
487145872eSMichael S. Tsirkin     Error *migration_blocker;
495430a28fSmst@redhat.com     bool force;
50af603142SNicholas Bellinger     bool memory_changed;
51af603142SNicholas Bellinger     hwaddr mem_changed_start_addr;
52af603142SNicholas Bellinger     hwaddr mem_changed_end_addr;
5324d1eb33SNikolay Nikolaev     const VhostOps *vhost_ops;
541a1bfac9SNikolay Nikolaev     void *opaque;
55d5970055SMichael S. Tsirkin };
56d5970055SMichael S. Tsirkin 
5781647a65SNikolay Nikolaev int vhost_dev_init(struct vhost_dev *hdev, void *opaque,
581a1bfac9SNikolay Nikolaev                    VhostBackendType backend_type, bool force);
59d5970055SMichael S. Tsirkin void vhost_dev_cleanup(struct vhost_dev *hdev);
605430a28fSmst@redhat.com bool vhost_dev_query(struct vhost_dev *hdev, VirtIODevice *vdev);
61d5970055SMichael S. Tsirkin int vhost_dev_start(struct vhost_dev *hdev, VirtIODevice *vdev);
62d5970055SMichael S. Tsirkin void vhost_dev_stop(struct vhost_dev *hdev, VirtIODevice *vdev);
63b0b3db79SMichael S. Tsirkin int vhost_dev_enable_notifiers(struct vhost_dev *hdev, VirtIODevice *vdev);
64b0b3db79SMichael S. Tsirkin void vhost_dev_disable_notifiers(struct vhost_dev *hdev, VirtIODevice *vdev);
65d5970055SMichael S. Tsirkin 
66f56a1247SMichael S. Tsirkin /* Test and clear masked event pending status.
67f56a1247SMichael S. Tsirkin  * Should be called after unmask to avoid losing events.
68f56a1247SMichael S. Tsirkin  */
69f56a1247SMichael S. Tsirkin bool vhost_virtqueue_pending(struct vhost_dev *hdev, int n);
70f56a1247SMichael S. Tsirkin 
71f56a1247SMichael S. Tsirkin /* Mask/unmask events from this vq.
72f56a1247SMichael S. Tsirkin  */
73f56a1247SMichael S. Tsirkin void vhost_virtqueue_mask(struct vhost_dev *hdev, VirtIODevice *vdev, int n,
74f56a1247SMichael S. Tsirkin                           bool mask);
752e6d46d7SNikolay Nikolaev unsigned vhost_get_features(struct vhost_dev *hdev, const int *feature_bits,
762e6d46d7SNikolay Nikolaev         unsigned features);
772e6d46d7SNikolay Nikolaev void vhost_ack_features(struct vhost_dev *hdev, const int *feature_bits,
782e6d46d7SNikolay Nikolaev         unsigned features);
79d5970055SMichael S. Tsirkin #endif
80