On 6/25/20 3:38 PM, Matan Azrad wrote:
> When virtq call or kick file descriptors are changed in the device
> configuration when the queue is ready, the application and the vDPA
> driver should be notified to be aligned to the new file descriptors.
> 
> Notify the state to be disabled before the file descriptor update and
> return it back to be enabled after the update.
> 
> Signed-off-by: Matan Azrad <ma...@mellanox.com>
> ---
>  lib/librte_vhost/vhost_user.c | 11 +++++++++++
>  1 file changed, 11 insertions(+)
> 
> diff --git a/lib/librte_vhost/vhost_user.c b/lib/librte_vhost/vhost_user.c
> index f690fdb..f3966b6 100644
> --- a/lib/librte_vhost/vhost_user.c
> +++ b/lib/librte_vhost/vhost_user.c
> @@ -1624,6 +1624,12 @@
>               "vring call idx:%d file:%d\n", file.index, file.fd);
>  
>       vq = dev->virtqueue[file.index];
> +
> +     if (vq->ready) {
> +             vhost_user_notify_queue_state(dev, file.index, 0);
> +             vq->ready = 0;
> +     }
> +
>       if (vq->callfd >= 0)
>               close(vq->callfd);
>  
> @@ -1882,6 +1888,11 @@ static int vhost_user_set_vring_err(struct virtio_net 
> **pdev __rte_unused,
>                               dev->vid, file.index, 1);
>       }
>  
> +     if (vq->ready) {
> +             vhost_user_notify_queue_state(dev, file.index, 0);
> +             vq->ready = 0;
> +     }
> +
>       if (vq->kickfd >= 0)
>               close(vq->kickfd);
>       vq->kickfd = file.fd;
> 

Reviewed-by: Maxime Coquelin <maxime.coque...@redhat.com>

Thanks,
Maxime

Reply via email to