xref: /qemu/include/hw/virtio/vhost.h (revision 24d1eb33eb2ccd995a845a4d4b793e2619a9e460)
1d5970055SMichael S. Tsirkin #ifndef VHOST_H
2d5970055SMichael S. Tsirkin #define VHOST_H
3d5970055SMichael S. Tsirkin 
4d5970055SMichael S. Tsirkin #include "hw/hw.h"
5*24d1eb33SNikolay 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     int control;
35d5970055SMichael S. Tsirkin     struct vhost_memory *mem;
362817b260SAvi Kivity     int n_mem_sections;
372817b260SAvi Kivity     MemoryRegionSection *mem_sections;
38d5970055SMichael S. Tsirkin     struct vhost_virtqueue *vqs;
39d5970055SMichael S. Tsirkin     int nvqs;
40a9f98bb5SJason Wang     /* the first virtuque which would be used by this vhost dev */
41a9f98bb5SJason Wang     int vq_index;
42d5970055SMichael S. Tsirkin     unsigned long long features;
43d5970055SMichael S. Tsirkin     unsigned long long acked_features;
44d5970055SMichael S. Tsirkin     unsigned long long backend_features;
45d5970055SMichael S. Tsirkin     bool started;
46d5970055SMichael S. Tsirkin     bool log_enabled;
47d5970055SMichael S. Tsirkin     vhost_log_chunk_t *log;
48d5970055SMichael S. Tsirkin     unsigned long long log_size;
495430a28fSmst@redhat.com     bool force;
50af603142SNicholas Bellinger     bool memory_changed;
51af603142SNicholas Bellinger     hwaddr mem_changed_start_addr;
52af603142SNicholas Bellinger     hwaddr mem_changed_end_addr;
53*24d1eb33SNikolay Nikolaev     const VhostOps *vhost_ops;
54d5970055SMichael S. Tsirkin };
55d5970055SMichael S. Tsirkin 
5681647a65SNikolay Nikolaev int vhost_dev_init(struct vhost_dev *hdev, void *opaque,
571241ed94SStefan Hajnoczi                    bool force);
58d5970055SMichael S. Tsirkin void vhost_dev_cleanup(struct vhost_dev *hdev);
595430a28fSmst@redhat.com bool vhost_dev_query(struct vhost_dev *hdev, VirtIODevice *vdev);
60d5970055SMichael S. Tsirkin int vhost_dev_start(struct vhost_dev *hdev, VirtIODevice *vdev);
61d5970055SMichael S. Tsirkin void vhost_dev_stop(struct vhost_dev *hdev, VirtIODevice *vdev);
62b0b3db79SMichael S. Tsirkin int vhost_dev_enable_notifiers(struct vhost_dev *hdev, VirtIODevice *vdev);
63b0b3db79SMichael S. Tsirkin void vhost_dev_disable_notifiers(struct vhost_dev *hdev, VirtIODevice *vdev);
64d5970055SMichael S. Tsirkin 
65f56a1247SMichael S. Tsirkin /* Test and clear masked event pending status.
66f56a1247SMichael S. Tsirkin  * Should be called after unmask to avoid losing events.
67f56a1247SMichael S. Tsirkin  */
68f56a1247SMichael S. Tsirkin bool vhost_virtqueue_pending(struct vhost_dev *hdev, int n);
69f56a1247SMichael S. Tsirkin 
70f56a1247SMichael S. Tsirkin /* Mask/unmask events from this vq.
71f56a1247SMichael S. Tsirkin  */
72f56a1247SMichael S. Tsirkin void vhost_virtqueue_mask(struct vhost_dev *hdev, VirtIODevice *vdev, int n,
73f56a1247SMichael S. Tsirkin                           bool mask);
742e6d46d7SNikolay Nikolaev unsigned vhost_get_features(struct vhost_dev *hdev, const int *feature_bits,
752e6d46d7SNikolay Nikolaev         unsigned features);
762e6d46d7SNikolay Nikolaev void vhost_ack_features(struct vhost_dev *hdev, const int *feature_bits,
772e6d46d7SNikolay Nikolaev         unsigned features);
78d5970055SMichael S. Tsirkin #endif
79