mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 08:43:55 -06:00
vdpa-dev: get iova range explicitly
In commita585fad26b
("vdpa: request iova_range only once") we remove GET_IOVA_RANGE form vhost_vdpa_init, the generic vdpa device will start without iova_range populated, so the device won't work. Let's call GET_IOVA_RANGE ioctl explicitly. Fixes:a585fad26b
("vdpa: request iova_range only once") Signed-off-by: Longpeng <longpeng2@huawei.com> Message-Id: <20221224114848.3062-2-longpeng2@huawei.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Acked-by: Jason Wang <jasowang@redhat.com>
This commit is contained in:
parent
f07ceffdf5
commit
c672f348cb
4 changed files with 18 additions and 8 deletions
|
@ -53,6 +53,7 @@ static void vhost_vdpa_device_realize(DeviceState *dev, Error **errp)
|
||||||
{
|
{
|
||||||
VirtIODevice *vdev = VIRTIO_DEVICE(dev);
|
VirtIODevice *vdev = VIRTIO_DEVICE(dev);
|
||||||
VhostVdpaDevice *v = VHOST_VDPA_DEVICE(vdev);
|
VhostVdpaDevice *v = VHOST_VDPA_DEVICE(vdev);
|
||||||
|
struct vhost_vdpa_iova_range iova_range;
|
||||||
uint16_t max_queue_size;
|
uint16_t max_queue_size;
|
||||||
struct vhost_virtqueue *vqs;
|
struct vhost_virtqueue *vqs;
|
||||||
int i, ret;
|
int i, ret;
|
||||||
|
@ -108,6 +109,14 @@ static void vhost_vdpa_device_realize(DeviceState *dev, Error **errp)
|
||||||
v->dev.backend_features = 0;
|
v->dev.backend_features = 0;
|
||||||
v->started = false;
|
v->started = false;
|
||||||
|
|
||||||
|
ret = vhost_vdpa_get_iova_range(v->vhostfd, &iova_range);
|
||||||
|
if (ret < 0) {
|
||||||
|
error_setg(errp, "vhost-vdpa-device: get iova range failed: %s",
|
||||||
|
strerror(-ret));
|
||||||
|
goto free_vqs;
|
||||||
|
}
|
||||||
|
v->vdpa.iova_range = iova_range;
|
||||||
|
|
||||||
ret = vhost_dev_init(&v->dev, &v->vdpa, VHOST_BACKEND_TYPE_VDPA, 0, NULL);
|
ret = vhost_dev_init(&v->dev, &v->vdpa, VHOST_BACKEND_TYPE_VDPA, 0, NULL);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
error_setg(errp, "vhost-vdpa-device: vhost initialization failed: %s",
|
error_setg(errp, "vhost-vdpa-device: vhost initialization failed: %s",
|
||||||
|
|
|
@ -378,6 +378,13 @@ static int vhost_vdpa_add_status(struct vhost_dev *dev, uint8_t status)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int vhost_vdpa_get_iova_range(int fd, struct vhost_vdpa_iova_range *iova_range)
|
||||||
|
{
|
||||||
|
int ret = ioctl(fd, VHOST_VDPA_GET_IOVA_RANGE, iova_range);
|
||||||
|
|
||||||
|
return ret < 0 ? -errno : 0;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The use of this function is for requests that only need to be
|
* The use of this function is for requests that only need to be
|
||||||
* applied once. Typically such request occurs at the beginning
|
* applied once. Typically such request occurs at the beginning
|
||||||
|
|
|
@ -51,6 +51,8 @@ typedef struct vhost_vdpa {
|
||||||
VhostVDPAHostNotifier notifier[VIRTIO_QUEUE_MAX];
|
VhostVDPAHostNotifier notifier[VIRTIO_QUEUE_MAX];
|
||||||
} VhostVDPA;
|
} VhostVDPA;
|
||||||
|
|
||||||
|
int vhost_vdpa_get_iova_range(int fd, struct vhost_vdpa_iova_range *iova_range);
|
||||||
|
|
||||||
int vhost_vdpa_dma_map(struct vhost_vdpa *v, uint32_t asid, hwaddr iova,
|
int vhost_vdpa_dma_map(struct vhost_vdpa *v, uint32_t asid, hwaddr iova,
|
||||||
hwaddr size, void *vaddr, bool readonly);
|
hwaddr size, void *vaddr, bool readonly);
|
||||||
int vhost_vdpa_dma_unmap(struct vhost_vdpa *v, uint32_t asid, hwaddr iova,
|
int vhost_vdpa_dma_unmap(struct vhost_vdpa *v, uint32_t asid, hwaddr iova,
|
||||||
|
|
|
@ -710,14 +710,6 @@ static NetClientState *net_vhost_vdpa_init(NetClientState *peer,
|
||||||
return nc;
|
return nc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int vhost_vdpa_get_iova_range(int fd,
|
|
||||||
struct vhost_vdpa_iova_range *iova_range)
|
|
||||||
{
|
|
||||||
int ret = ioctl(fd, VHOST_VDPA_GET_IOVA_RANGE, iova_range);
|
|
||||||
|
|
||||||
return ret < 0 ? -errno : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int vhost_vdpa_get_features(int fd, uint64_t *features, Error **errp)
|
static int vhost_vdpa_get_features(int fd, uint64_t *features, Error **errp)
|
||||||
{
|
{
|
||||||
int ret = ioctl(fd, VHOST_GET_FEATURES, features);
|
int ret = ioctl(fd, VHOST_GET_FEATURES, features);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue