@@ -2,6 +2,11 @@
#include "hw/virtio/vhost.h"
#include "hw/virtio/vhost-user.h"
+unsigned int vhost_get_max_memslots(void)
+{
+ return UINT_MAX;
+}
+
bool vhost_has_free_slot(void)
{
return true;
@@ -55,6 +55,17 @@ static unsigned int used_shared_memslots;
static QLIST_HEAD(, vhost_dev) vhost_devices =
QLIST_HEAD_INITIALIZER(vhost_devices);
+unsigned int vhost_get_max_memslots(void)
+{
+ unsigned int max = UINT_MAX;
+ struct vhost_dev *hdev;
+
+ QLIST_FOREACH(hdev, &vhost_devices, entry) {
+ max = MIN(max, hdev->vhost_ops->vhost_backend_memslots_limit(hdev));
+ }
+ return max;
+}
+
bool vhost_has_free_slot(void)
{
unsigned int free = UINT_MAX;
@@ -315,6 +315,7 @@ uint64_t vhost_get_features(struct vhost_dev *hdev, const int *feature_bits,
*/
void vhost_ack_features(struct vhost_dev *hdev, const int *feature_bits,
uint64_t features);
+unsigned int vhost_get_max_memslots(void);
bool vhost_has_free_slot(void);
int vhost_net_set_backend(struct vhost_dev *hdev,
Let's add vhost_get_max_memslots(), to perform a similar task as kvm_get_max_memslots(). Signed-off-by: David Hildenbrand <david@redhat.com> --- hw/virtio/vhost-stub.c | 5 +++++ hw/virtio/vhost.c | 11 +++++++++++ include/hw/virtio/vhost.h | 1 + 3 files changed, 17 insertions(+)