All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Michael S. Tsirkin" <mst@redhat.com>
To: Xuewei Niu <niuxuewei97@gmail.com>
Cc: sgarzare@redhat.com, parav@nvidia.com, fupan.lfp@antgroup.com,
	virtio-comment@lists.linux.dev,
	Xuewei Niu <niuxuewei.nxw@antgroup.com>
Subject: Re: [PATCH v7] virtio-vsock: Add support for multi devices
Date: Sun, 18 May 2025 17:52:06 -0400	[thread overview]
Message-ID: <20250518174619-mutt-send-email-mst@kernel.org> (raw)
In-Reply-To: <20250412142825.3180245-1-niuxuewei.nxw@antgroup.com>

On Sat, Apr 12, 2025 at 10:28:25PM +0800, Xuewei Niu wrote:
> This patch brings a new feature, called "multi devices", to the virtio
> vsock. It introduces a "VIRTIO_VSOCK_F_MULTI_DEVICES" feature bit, and a
> "device_order" field to the config for the virtio vsock.
> 
> == Motivition ==
> 
> Vsock is a lightweight and widely used data exchange mechanism between host
> and guest. Currently, the virtio-vsock only supports one device, resulting
> in the inability to enable more than one backend. For instance, two devices
> are required: one to transfer data to the VMM via virtio-vsock, and another
> to a user process via vhost-user-vsock.
> 
> Apart from that, a side gain is that theoretically the performance might be
> improved since each device has its own queue. But it varies depending on
> the implementation.
> 
> == Typical Usages ==
> 
> Assuming there are two virtio-vsock devices on the guest, with CIDs 3 and 4
> respectively. And the device with CID 3 is default.
> 
> Connect to the host using the device with CID 3.
> 
> ```c
> // use default one (no bind)
> fd = socket(AF_VSOCK);
> connect(fd, 2, 1234);
> n = write(fd, buffer);
> 
> // or bind explicitly
> fd = socket(AF_VSOCK);
> bind(fd, 3, -1);
> connect(fd, 2, 1234);
> n = write(fd, buffer);
> ```
> 
> Connect to the host using the device with CID 4.
> 
> ```c
> // must bind explicitly as the device with CID 4 is not default.
> fd = socket(AF_VSOCK);
> bind(fd, 4, -1);
> connect(fd, 2, 1234);
> n = write(fd, buffer);
> ```
> 
> The first version of multi-devices implementation is available at [1].
> 
> v6 -> v7:
> - Addresses minor review comments from Stefano.
> 
> [1] https://lore.kernel.org/virtualization/20240517144607.2595798-1-niuxuewei.nxw@antgroup.com
> 
> Signed-off-by: Xuewei Niu <niuxuewei.nxw@antgroup.com>
> ---
>  device-types/vsock/description.tex | 30 ++++++++++++++++++++++++++++--
>  1 file changed, 28 insertions(+), 2 deletions(-)
> 
> diff --git a/device-types/vsock/description.tex b/device-types/vsock/description.tex
> index 7d91d15..392dc76 100644
> --- a/device-types/vsock/description.tex
> +++ b/device-types/vsock/description.tex
> @@ -20,6 +20,7 @@ \subsection{Feature bits}\label{sec:Device Types / Socket Device / Feature bits}
>  \item[VIRTIO_VSOCK_F_STREAM (0)] stream socket type is supported.
>  \item[VIRTIO_VSOCK_F_SEQPACKET (1)] seqpacket socket type is supported.
>  \item[VIRTIO_VSOCK_F_NO_IMPLIED_STREAM (2)] stream socket type is not implied.
> +\item[VIRTIO_VSOCK_F_MULTI_DEVICES (3)] multiple devices feature is supported.
>  \end{description}
>  
>  \drivernormative{\subsubsection}{Feature bits}{Device Types / Socket Device / Feature bits}
> @@ -34,6 +35,12 @@ \subsection{Feature bits}\label{sec:Device Types / Socket Device / Feature bits}
>  VIRTIO_VSOCK_F_NO_IMPLIED_STREAM, the driver MAY act as if
>  VIRTIO_VSOCK_F_STREAM has also been negotiated.
>  
> +The driver SHOULD ignore devices that do not have
> +VIRTIO_VSOCK_F_MULTI_DEVICES if the feature has been negotiated.
> +
> +The driver SHOULD ignore all subsequent devices if a device without
> +VIRTIO_VSOCK_F_MULTI_DEVICES is present.
> +

all this is really vague. any better way to put it?

what are subsequent devices? if the feature has been negotiated where?
what does ignore mean? you can not know features without interacting
with the device.



>  \devicenormative{\subsubsection}{Feature bits}{Device Types / Socket Device / Feature bits}
>  
>  The device SHOULD offer the VIRTIO_VSOCK_F_NO_IMPLIED_STREAM feature.
> @@ -52,6 +59,7 @@ \subsection{Device configuration layout}\label{sec:Device Types / Socket Device
>  \begin{lstlisting}
>  struct virtio_vsock_config {
>  	le64 guest_cid;
> +	le16 device_order;
>  };
>  \end{lstlisting}
>  
> @@ -77,11 +85,27 @@ \subsection{Device configuration layout}\label{sec:Device Types / Socket Device
>  \hline
>  \end{tabular}
>  
> +The \field{device_order} is used to identify the default device.

no explanation what is the default device.
is it just for the cid?

> Up to
> +65,535 devices can be supported due to the size.

can be -> are
drop "due to the size".

> +
> +\devicenormative{\subsubsection}{Device configuration layout}{Device Types / Socket Device / Device configuration layout}
> +
> +The device MUST provide a distinct \field{device_order} if
> +VIRTIO_VSOCK_F_MULTI_DEVICES feature has been negotiated.

distinct to what?

> +
> +\drivernormative{\subsubsection}{Device configuration layout}{Device Types / Socket Device / Device configuration layout}
> +
> +The driver MUST treat the device with the lowest \field{device_order} as
> +the default device.
> +
>  \subsection{Device Initialization}\label{sec:Device Types / Socket Device / Device Initialization}
>  
>  \begin{enumerate}
>  \item The guest's cid is read from \field{guest_cid}.
>  
> +\item If VIRTIO_VSOCK_F_MULTI_DEVICES has been negotiated, the device's
> +order will be read from \field{device_order}.
> +
>  \item Buffers are added to the event virtqueue to receive events from the device.
>  
>  \item Buffers are added to the rx virtqueue to start receiving packets.
> @@ -233,8 +257,10 @@ \subsubsection{Receive and Transmit}\label{sec:Device Types / Socket Device / De
>  
>  \drivernormative{\paragraph}{Device Operation: Receive and Transmit}{Device Types / Socket Device / Device Operation / Receive and Transmit}
>  
> -The \field{guest_cid} configuration field MUST be used as the source CID when
> -sending outgoing packets.
> +If the source socket is not bound to any source CID, the driver MUST assign
> +one. If more than one device is present, the driver SHOULD use the default
> +device's \field{guest_cid} configuration. Otherwise, the driver SHOULD use
> +the \field{guest_cid} of the only available device.

why did you drop requirement about outgoing packets?

>  
>  A VIRTIO_VSOCK_OP_RST reply MUST be sent if a packet is received with an
>  unknown \field{type} value.
> -- 
> 2.34.1


  parent reply	other threads:[~2025-05-18 21:52 UTC|newest]

Thread overview: 59+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-04-12 14:28 [PATCH v7] virtio-vsock: Add support for multi devices Xuewei Niu
2025-04-12 14:38 ` Xuewei Niu
2025-05-18 21:52 ` Michael S. Tsirkin [this message]
2025-05-19  9:37   ` Xuewei Niu
2025-06-11 14:51     ` Xuewei Niu
2025-06-11 14:53       ` Parav Pandit
2025-06-11 18:02     ` Michael S. Tsirkin
2025-06-12  3:28       ` Xuewei Niu
2025-06-14 17:11     ` Parav Pandit
2025-06-16  8:18       ` Xuewei Niu
2025-06-16  8:26         ` Parav Pandit
2025-06-16  8:59           ` Xuewei Niu
2025-06-16 10:05             ` Parav Pandit
2025-06-16 10:56               ` Xuewei Niu
2025-06-16 11:00                 ` Xuewei Niu
2025-06-17  6:01                 ` Parav Pandit
2025-06-17  7:41                   ` Xuewei Niu
2025-06-19  3:26                   ` Xuewei Niu
2025-06-19  4:40                     ` Parav Pandit
2025-06-19  5:10                       ` Xuewei Niu
2025-06-19  5:25                         ` Parav Pandit
2025-06-22 13:54                           ` Xuewei Niu
2025-06-23  7:53                         ` Stefano Garzarella
2025-06-23  8:48                           ` Xuewei Niu
2025-06-23  9:16                             ` Stefano Garzarella
2025-06-23 10:35                               ` Xuewei Niu
2025-06-23 11:01                                 ` Xuewei Niu
2025-06-23 11:15                                 ` Stefano Garzarella
2025-06-23 12:14                                   ` Xuewei Niu
2025-06-23 12:51                                     ` Stefano Garzarella
2025-06-23 15:51                                       ` Xuewei Niu
2025-07-01 10:31                                         ` Stefano Garzarella
2025-07-02  6:05                                           ` Xuewei Niu
2025-07-10 10:19                                             ` Stefano Garzarella
2025-07-11  4:40                                               ` Xuewei Niu
2025-06-13  4:23 ` Jason Wang
2025-06-13  4:57   ` Xuewei Niu
2025-06-13  8:35     ` Stefano Garzarella
2025-06-13  8:46       ` Xuewei Niu
2025-06-16  3:06         ` Jason Wang
2025-06-16  8:29           ` Xuewei Niu
2025-06-16  8:38             ` Stefano Garzarella
2025-06-17  2:52               ` Jason Wang
2025-06-17  2:54                 ` Jason Wang
2025-06-17  7:45                   ` Xuewei Niu
2025-06-18  0:49                     ` Jason Wang
2025-06-18  2:47                       ` Xuewei Niu
2025-06-18  4:19                         ` Jason Wang
2025-06-18  5:40                           ` Xuewei Niu
2025-06-18  8:36                             ` Jason Wang
2025-06-18  9:51                               ` Xuewei Niu
2025-06-19  1:10                                 ` Jason Wang
2025-06-19  2:42                                   ` Xuewei Niu
2025-06-23  8:01                                     ` Jason Wang
2025-06-23  9:47                                       ` Xuewei Niu
2025-06-24  0:51                                         ` Jason Wang
2025-06-24  3:33                                           ` Xuewei Niu
2025-06-13  8:31   ` Stefano Garzarella
2025-06-13  8:36     ` Xuewei Niu

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20250518174619-mutt-send-email-mst@kernel.org \
    --to=mst@redhat.com \
    --cc=fupan.lfp@antgroup.com \
    --cc=niuxuewei.nxw@antgroup.com \
    --cc=niuxuewei97@gmail.com \
    --cc=parav@nvidia.com \
    --cc=sgarzare@redhat.com \
    --cc=virtio-comment@lists.linux.dev \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.