mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-13 14:24:11 +08:00
vdpa_sim: not reset state in vdpasim_queue_ready
vdpasim_queue_ready calls vringh_init_iotlb, which resets split indexes.
But it can be called after setting a ring base with
vdpasim_set_vq_state.
Fix it by stashing them. They're still resetted in vdpasim_vq_reset.
This was discovered and tested live migrating the vdpa_sim_net device.
Fixes: 2c53d0f64c
("vdpasim: vDPA device simulator")
Signed-off-by: Eugenio Pérez <eperezma@redhat.com>
Message-Id: <20230118164359.1523760-2-eperezma@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Acked-by: Jason Wang <jasowang@redhat.com>
Tested-by: Lei Yang <leiyang@redhat.com>
This commit is contained in:
parent
ceaa837f96
commit
0e84f918fa
@ -66,6 +66,7 @@ static void vdpasim_vq_notify(struct vringh *vring)
|
|||||||
static void vdpasim_queue_ready(struct vdpasim *vdpasim, unsigned int idx)
|
static void vdpasim_queue_ready(struct vdpasim *vdpasim, unsigned int idx)
|
||||||
{
|
{
|
||||||
struct vdpasim_virtqueue *vq = &vdpasim->vqs[idx];
|
struct vdpasim_virtqueue *vq = &vdpasim->vqs[idx];
|
||||||
|
uint16_t last_avail_idx = vq->vring.last_avail_idx;
|
||||||
|
|
||||||
vringh_init_iotlb(&vq->vring, vdpasim->features, vq->num, false,
|
vringh_init_iotlb(&vq->vring, vdpasim->features, vq->num, false,
|
||||||
(struct vring_desc *)(uintptr_t)vq->desc_addr,
|
(struct vring_desc *)(uintptr_t)vq->desc_addr,
|
||||||
@ -74,6 +75,7 @@ static void vdpasim_queue_ready(struct vdpasim *vdpasim, unsigned int idx)
|
|||||||
(struct vring_used *)
|
(struct vring_used *)
|
||||||
(uintptr_t)vq->device_addr);
|
(uintptr_t)vq->device_addr);
|
||||||
|
|
||||||
|
vq->vring.last_avail_idx = last_avail_idx;
|
||||||
vq->vring.notify = vdpasim_vq_notify;
|
vq->vring.notify = vdpasim_vq_notify;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user