From: Jason Wang <jasowang@redhat.com> To: Stefano Garzarella <sgarzare@redhat.com>, virtualization@lists.linux-foundation.org Cc: Stefan Hajnoczi <stefanha@redhat.com>, linux-kernel@vger.kernel.org, Laurent Vivier <lvivier@redhat.com>, Max Gurtovoy <mgurtovoy@nvidia.com>, "Michael S. Tsirkin" <mst@redhat.com>, Eli Cohen <elic@nvidia.com> Subject: Re: [PATCH v2 16/17] vdpa_sim: split vdpasim_virtqueue's iov field in out_iov and in_iov Date: Mon, 30 Nov 2020 11:29:08 +0800 [thread overview] Message-ID: <5c01a00d-e7a9-2513-7e9f-39fc620c17c0@redhat.com> (raw) In-Reply-To: <20201126144950.92850-17-sgarzare@redhat.com> On 2020/11/26 下午10:49, Stefano Garzarella wrote: > vringh_getdesc_iotlb() manages 2 iovs for writable and readable > descriptors. This is very useful for the block device, where for > each request we have both types of descriptor. > > Let's split the vdpasim_virtqueue's iov field in out_iov and > in_iov to use them with vringh_getdesc_iotlb(). > > We are using VIRTIO terminology for "out" (readable by the device) > and "in" (writable by the device) descriptors. > > Signed-off-by: Stefano Garzarella <sgarzare@redhat.com> > --- > v2: > - used VIRTIO terminology [Stefan] > --- Acked-by: Jason Wang <jasowang@redhat.com> > drivers/vdpa/vdpa_sim/vdpa_sim.c | 11 ++++++----- > 1 file changed, 6 insertions(+), 5 deletions(-) > > diff --git a/drivers/vdpa/vdpa_sim/vdpa_sim.c b/drivers/vdpa/vdpa_sim/vdpa_sim.c > index f5f41f20ee0b..f8ee261ef4ae 100644 > --- a/drivers/vdpa/vdpa_sim/vdpa_sim.c > +++ b/drivers/vdpa/vdpa_sim/vdpa_sim.c > @@ -33,7 +33,8 @@ u8 macaddr_buf[ETH_ALEN]; > > struct vdpasim_virtqueue { > struct vringh vring; > - struct vringh_kiov iov; > + struct vringh_kiov in_iov; > + struct vringh_kiov out_iov; > unsigned short head; > bool ready; > u64 desc_addr; > @@ -197,12 +198,12 @@ static void vdpasim_net_work(struct work_struct *work) > > while (true) { > total_write = 0; > - err = vringh_getdesc_iotlb(&txq->vring, &txq->iov, NULL, > + err = vringh_getdesc_iotlb(&txq->vring, &txq->out_iov, NULL, > &txq->head, GFP_ATOMIC); > if (err <= 0) > break; > > - err = vringh_getdesc_iotlb(&rxq->vring, NULL, &rxq->iov, > + err = vringh_getdesc_iotlb(&rxq->vring, NULL, &rxq->in_iov, > &rxq->head, GFP_ATOMIC); > if (err <= 0) { > vringh_complete_iotlb(&txq->vring, txq->head, 0); > @@ -210,13 +211,13 @@ static void vdpasim_net_work(struct work_struct *work) > } > > while (true) { > - read = vringh_iov_pull_iotlb(&txq->vring, &txq->iov, > + read = vringh_iov_pull_iotlb(&txq->vring, &txq->out_iov, > vdpasim->buffer, > PAGE_SIZE); > if (read <= 0) > break; > > - write = vringh_iov_push_iotlb(&rxq->vring, &rxq->iov, > + write = vringh_iov_push_iotlb(&rxq->vring, &rxq->in_iov, > vdpasim->buffer, read); > if (write <= 0) > break;
WARNING: multiple messages have this Message-ID (diff)
From: Jason Wang <jasowang@redhat.com> To: Stefano Garzarella <sgarzare@redhat.com>, virtualization@lists.linux-foundation.org Cc: Laurent Vivier <lvivier@redhat.com>, Max Gurtovoy <mgurtovoy@nvidia.com>, "Michael S. Tsirkin" <mst@redhat.com>, linux-kernel@vger.kernel.org, Stefan Hajnoczi <stefanha@redhat.com>, Eli Cohen <elic@nvidia.com> Subject: Re: [PATCH v2 16/17] vdpa_sim: split vdpasim_virtqueue's iov field in out_iov and in_iov Date: Mon, 30 Nov 2020 11:29:08 +0800 [thread overview] Message-ID: <5c01a00d-e7a9-2513-7e9f-39fc620c17c0@redhat.com> (raw) In-Reply-To: <20201126144950.92850-17-sgarzare@redhat.com> On 2020/11/26 下午10:49, Stefano Garzarella wrote: > vringh_getdesc_iotlb() manages 2 iovs for writable and readable > descriptors. This is very useful for the block device, where for > each request we have both types of descriptor. > > Let's split the vdpasim_virtqueue's iov field in out_iov and > in_iov to use them with vringh_getdesc_iotlb(). > > We are using VIRTIO terminology for "out" (readable by the device) > and "in" (writable by the device) descriptors. > > Signed-off-by: Stefano Garzarella <sgarzare@redhat.com> > --- > v2: > - used VIRTIO terminology [Stefan] > --- Acked-by: Jason Wang <jasowang@redhat.com> > drivers/vdpa/vdpa_sim/vdpa_sim.c | 11 ++++++----- > 1 file changed, 6 insertions(+), 5 deletions(-) > > diff --git a/drivers/vdpa/vdpa_sim/vdpa_sim.c b/drivers/vdpa/vdpa_sim/vdpa_sim.c > index f5f41f20ee0b..f8ee261ef4ae 100644 > --- a/drivers/vdpa/vdpa_sim/vdpa_sim.c > +++ b/drivers/vdpa/vdpa_sim/vdpa_sim.c > @@ -33,7 +33,8 @@ u8 macaddr_buf[ETH_ALEN]; > > struct vdpasim_virtqueue { > struct vringh vring; > - struct vringh_kiov iov; > + struct vringh_kiov in_iov; > + struct vringh_kiov out_iov; > unsigned short head; > bool ready; > u64 desc_addr; > @@ -197,12 +198,12 @@ static void vdpasim_net_work(struct work_struct *work) > > while (true) { > total_write = 0; > - err = vringh_getdesc_iotlb(&txq->vring, &txq->iov, NULL, > + err = vringh_getdesc_iotlb(&txq->vring, &txq->out_iov, NULL, > &txq->head, GFP_ATOMIC); > if (err <= 0) > break; > > - err = vringh_getdesc_iotlb(&rxq->vring, NULL, &rxq->iov, > + err = vringh_getdesc_iotlb(&rxq->vring, NULL, &rxq->in_iov, > &rxq->head, GFP_ATOMIC); > if (err <= 0) { > vringh_complete_iotlb(&txq->vring, txq->head, 0); > @@ -210,13 +211,13 @@ static void vdpasim_net_work(struct work_struct *work) > } > > while (true) { > - read = vringh_iov_pull_iotlb(&txq->vring, &txq->iov, > + read = vringh_iov_pull_iotlb(&txq->vring, &txq->out_iov, > vdpasim->buffer, > PAGE_SIZE); > if (read <= 0) > break; > > - write = vringh_iov_push_iotlb(&rxq->vring, &rxq->iov, > + write = vringh_iov_push_iotlb(&rxq->vring, &rxq->in_iov, > vdpasim->buffer, read); > if (write <= 0) > break; _______________________________________________ Virtualization mailing list Virtualization@lists.linux-foundation.org https://lists.linuxfoundation.org/mailman/listinfo/virtualization
next prev parent reply other threads:[~2020-11-30 3:31 UTC|newest] Thread overview: 81+ messages / expand[flat|nested] mbox.gz Atom feed top 2020-11-26 14:49 [PATCH v2 00/17] vdpa: generalize vdpa simulator Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-26 14:49 ` [PATCH v2 01/17] vdpa: remove unnecessary 'default n' in Kconfig entries Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:01 ` Jason Wang 2020-11-30 3:01 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 02/17] vdpa_sim: remove unnecessary headers inclusion Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:04 ` Jason Wang 2020-11-30 3:04 ` Jason Wang 2020-11-30 11:10 ` Stefano Garzarella 2020-11-30 11:10 ` Stefano Garzarella 2020-11-26 14:49 ` [PATCH v2 03/17] vdpa_sim: remove hard-coded virtq count Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:05 ` Jason Wang 2020-11-30 3:05 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 04/17] vdpa_sim: remove the limit of IOTLB entries Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:07 ` Jason Wang 2020-11-30 3:07 ` Jason Wang 2020-11-30 11:24 ` Stefano Garzarella 2020-11-30 11:24 ` Stefano Garzarella 2020-11-26 14:49 ` [PATCH v2 05/17] vdpa_sim: rename vdpasim_config_ops variables Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:07 ` Jason Wang 2020-11-30 3:07 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 06/17] vdpa_sim: add struct vdpasim_dev_attr for device attributes Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:09 ` Jason Wang 2020-11-30 3:09 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 07/17] vdpa_sim: add device id field in vdpasim_dev_attr Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:10 ` Jason Wang 2020-11-30 3:10 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 08/17] vdpa_sim: add supported_features " Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:14 ` Jason Wang 2020-11-30 3:14 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 09/17] vdpa_sim: add work_fn " Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:16 ` Jason Wang 2020-11-30 3:16 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 10/17] vdpa_sim: store parsed MAC address in a buffer Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:20 ` Jason Wang 2020-11-30 3:20 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 11/17] vdpa_sim: make 'config' generic and usable for any device type Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-26 14:49 ` [PATCH v2 12/17] vdpa_sim: add get_config callback in vdpasim_dev_attr Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:25 ` Jason Wang 2020-11-30 3:25 ` Jason Wang 2020-11-30 14:14 ` Stefano Garzarella 2020-11-30 14:14 ` Stefano Garzarella 2020-12-01 3:44 ` Jason Wang 2020-12-01 3:44 ` Jason Wang 2020-12-01 10:52 ` Stefano Garzarella 2020-12-01 10:52 ` Stefano Garzarella 2020-11-26 14:49 ` [PATCH v2 13/17] vdpa_sim: set vringh notify callback Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:27 ` Jason Wang 2020-11-30 3:27 ` Jason Wang 2020-11-30 14:16 ` Stefano Garzarella 2020-11-30 14:16 ` Stefano Garzarella 2020-11-26 14:49 ` [PATCH v2 14/17] vdpa_sim: use kvmalloc to allocate vdpasim->buffer Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-26 14:49 ` [PATCH v2 15/17] vdpa_sim: make vdpasim->buffer size configurable Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-26 14:49 ` [PATCH v2 16/17] vdpa_sim: split vdpasim_virtqueue's iov field in out_iov and in_iov Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:29 ` Jason Wang [this message] 2020-11-30 3:29 ` Jason Wang 2020-11-26 14:49 ` [PATCH v2 17/17] vdpa: split vdpasim to core and net modules Stefano Garzarella 2020-11-26 14:49 ` Stefano Garzarella 2020-11-30 3:31 ` Jason Wang 2020-11-30 3:31 ` Jason Wang 2020-11-30 14:17 ` Stefano Garzarella 2020-11-30 14:17 ` Stefano Garzarella 2020-11-26 15:12 ` [PATCH v2 00/17] vdpa: generalize vdpa simulator Max Gurtovoy 2020-11-26 15:24 ` Stefano Garzarella 2020-11-26 15:24 ` Stefano Garzarella
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=5c01a00d-e7a9-2513-7e9f-39fc620c17c0@redhat.com \ --to=jasowang@redhat.com \ --cc=elic@nvidia.com \ --cc=linux-kernel@vger.kernel.org \ --cc=lvivier@redhat.com \ --cc=mgurtovoy@nvidia.com \ --cc=mst@redhat.com \ --cc=sgarzare@redhat.com \ --cc=stefanha@redhat.com \ --cc=virtualization@lists.linux-foundation.org \ /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: linkBe 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.