* [RFC] crypto/virtio: add vhost-vdpa backend
@ 2024-11-21 18:02 Gowrishankar Muthukrishnan
2024-11-27 6:50 ` Gowrishankar Muthukrishnan
2024-11-27 8:10 ` Jason Wang
0 siblings, 2 replies; 7+ messages in thread
From: Gowrishankar Muthukrishnan @ 2024-11-21 18:02 UTC (permalink / raw)
To: dev, Maxime Coquelin, Chenbo Xia, Jay Zhou
Cc: techboard, Anoob Joseph, Akhil Goyal, Jerin Jacob, Fan Zhang,
Gowrishankar Muthukrishnan
Hi,
We are adding support for vDPA user backend for virtio-crypto PMD in DPDK. We have come up with functional changes which is similar to the support available in net:
commit 6b901437056eed3ed7c9932c333ba24ac5be116f
net/virtio: introduce vhost-vDPA backend
vhost-vDPA is a new virtio backend type introduced by vDPA kernel
framework, which provides abstraction to the vDPA devices and
exposes an unified control interface through a char dev.
Our current development reuses some code from net/virtio/virtio_user/, and we realize that we could keep a few things in common between net and crypto, such as:
-> vhost_vdpa.c (and its header file) from net/virtio/virtio_user/:
Except for VHOST_VDPA_GET_DEVICE_ID and enabling queue pairs, virtio_user_backend_ops can be reused.
-> virtio_user_dev.c (and its header file) from net/virtio/virtio_user/:
virtio_user_dev_init and its capabilities differ.
-> virtio_cvq.c (and its header file) from net/virtio/:
There is a difference in the usage of the first and last descriptors for the virtio header and status (net vs. crypto).
We need to standardize these codes to ensure they work universally. Therefore, we propose creating a driver/common/virtio/ directory to house them. This approach will help address common issues and extend Virtio functionalities shared between crypto and net. For example, the crypto PMD can benefit from packed ring support. We welcome your valuable feedback and any suggestions.
Thanks,
Gowrishankar
--
2.37.1
^ permalink raw reply [flat|nested] 7+ messages in thread
* RE: [RFC] crypto/virtio: add vhost-vdpa backend
2024-11-21 18:02 [RFC] crypto/virtio: add vhost-vdpa backend Gowrishankar Muthukrishnan
@ 2024-11-27 6:50 ` Gowrishankar Muthukrishnan
2024-11-27 7:52 ` Chenbo Xia
2024-11-27 8:10 ` Jason Wang
1 sibling, 1 reply; 7+ messages in thread
From: Gowrishankar Muthukrishnan @ 2024-11-27 6:50 UTC (permalink / raw)
To: dev, Maxime Coquelin, Chenbo Xia, Jay Zhou
Cc: techboard, Anoob Joseph, Akhil Goyal, Jerin Jacob, Fan Zhang,
Nithin Kumar Dabilpuram, Thomas Monjalon
Hi,
I wanted to follow up on my previous message regarding the development of a vhost vDPA host driver for crypto/virtio. We have proposed creating a driver/common/virtio/ directory to hold common implementations for both net and crypto functionalities. This approach aims to help in fixing common issues and extending virtio functionalities efficiently.
As we plan to include this feature in DPDK 25.03, we would like to conclude on the implementation direction soon. We would greatly appreciate your valuable feedback or any suggestions on this proposal. Thank you!
Thanks,
Gowrishankar
> Hi,
> We are adding support for vDPA user backend for virtio-crypto PMD in DPDK.
> We have come up with functional changes which is similar to the support
> available in net:
>
> commit 6b901437056eed3ed7c9932c333ba24ac5be116f
>
> net/virtio: introduce vhost-vDPA backend
> vhost-vDPA is a new virtio backend type introduced by vDPA kernel
> framework, which provides abstraction to the vDPA devices and
> exposes an unified control interface through a char dev.
>
> Our current development reuses some code from net/virtio/virtio_user/, and
> we realize that we could keep a few things in common between net and
> crypto, such as:
>
> -> vhost_vdpa.c (and its header file) from net/virtio/virtio_user/:
> Except for VHOST_VDPA_GET_DEVICE_ID and enabling queue pairs,
> virtio_user_backend_ops can be reused.
> -> virtio_user_dev.c (and its header file) from net/virtio/virtio_user/:
> virtio_user_dev_init and its capabilities differ.
> -> virtio_cvq.c (and its header file) from net/virtio/:
> There is a difference in the usage of the first and last descriptors for the virtio
> header and status (net vs. crypto).
>
> We need to standardize these codes to ensure they work universally.
> Therefore, we propose creating a driver/common/virtio/ directory to house
> them. This approach will help address common issues and extend Virtio
> functionalities shared between crypto and net. For example, the crypto PMD
> can benefit from packed ring support. We welcome your valuable feedback
> and any suggestions.
>
> Thanks,
> Gowrishankar
> --
> 2.37.1
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [RFC] crypto/virtio: add vhost-vdpa backend
2024-11-27 6:50 ` Gowrishankar Muthukrishnan
@ 2024-11-27 7:52 ` Chenbo Xia
0 siblings, 0 replies; 7+ messages in thread
From: Chenbo Xia @ 2024-11-27 7:52 UTC (permalink / raw)
To: Gowrishankar Muthukrishnan
Cc: dev, Maxime Coquelin, Jay Zhou, techboard, Anoob Joseph,
Akhil Goyal, Jerin Jacob, Fan Zhang, Nithin Kumar Dabilpuram,
NBU-Contact-Thomas Monjalon (EXTERNAL)
Hi Gowrishankar,
> On Nov 27, 2024, at 14:50, Gowrishankar Muthukrishnan <gmuthukrishn@marvell.com> wrote:
>
> External email: Use caution opening links or attachments
>
>
> Hi,
> I wanted to follow up on my previous message regarding the development of a vhost vDPA host driver for crypto/virtio. We have proposed creating a driver/common/virtio/ directory to hold common implementations for both net and crypto functionalities. This approach aims to help in fixing common issues and extending virtio functionalities efficiently.
>
> As we plan to include this feature in DPDK 25.03, we would like to conclude on the implementation direction soon. We would greatly appreciate your valuable feedback or any suggestions on this proposal. Thank you!
Thanks for the efforts!
IIUC, you want to make sure it’s good direction to have a common folder for both net and
crypto. Of course overall this is a good idea as it’s more friendly for maintaining the
code. I checked your list of code to be shared, seems it will be many code in the common
layer. So please go on with this :)
Cheers,
Chenbo
>
> Thanks,
> Gowrishankar
>
>> Hi,
>> We are adding support for vDPA user backend for virtio-crypto PMD in DPDK.
>> We have come up with functional changes which is similar to the support
>> available in net:
>>
>> commit 6b901437056eed3ed7c9932c333ba24ac5be116f
>>
>> net/virtio: introduce vhost-vDPA backend
>> vhost-vDPA is a new virtio backend type introduced by vDPA kernel
>> framework, which provides abstraction to the vDPA devices and
>> exposes an unified control interface through a char dev.
>>
>> Our current development reuses some code from net/virtio/virtio_user/, and
>> we realize that we could keep a few things in common between net and
>> crypto, such as:
>>
>> -> vhost_vdpa.c (and its header file) from net/virtio/virtio_user/:
>> Except for VHOST_VDPA_GET_DEVICE_ID and enabling queue pairs,
>> virtio_user_backend_ops can be reused.
>> -> virtio_user_dev.c (and its header file) from net/virtio/virtio_user/:
>> virtio_user_dev_init and its capabilities differ.
>> -> virtio_cvq.c (and its header file) from net/virtio/:
>> There is a difference in the usage of the first and last descriptors for the virtio
>> header and status (net vs. crypto).
>>
>> We need to standardize these codes to ensure they work universally.
>> Therefore, we propose creating a driver/common/virtio/ directory to house
>> them. This approach will help address common issues and extend Virtio
>> functionalities shared between crypto and net. For example, the crypto PMD
>> can benefit from packed ring support. We welcome your valuable feedback
>> and any suggestions.
>>
>> Thanks,
>> Gowrishankar
>> --
>> 2.37.1
>
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [RFC] crypto/virtio: add vhost-vdpa backend
2024-11-21 18:02 [RFC] crypto/virtio: add vhost-vdpa backend Gowrishankar Muthukrishnan
2024-11-27 6:50 ` Gowrishankar Muthukrishnan
@ 2024-11-27 8:10 ` Jason Wang
2024-11-28 4:31 ` [EXTERNAL] " Gowrishankar Muthukrishnan
1 sibling, 1 reply; 7+ messages in thread
From: Jason Wang @ 2024-11-27 8:10 UTC (permalink / raw)
To: Gowrishankar Muthukrishnan
Cc: dev, Maxime Coquelin, Chenbo Xia, Jay Zhou, techboard,
Anoob Joseph, Akhil Goyal, Jerin Jacob, Fan Zhang
Hello:
On Fri, Nov 22, 2024 at 2:03 AM Gowrishankar Muthukrishnan
<gmuthukrishn@marvell.com> wrote:
>
> Hi,
> We are adding support for vDPA user backend for virtio-crypto PMD in DPDK.
I wonder what kind of vDPA device you are using? Is there a marvell
specific vDPA or just a standard virtio-pci device via vp-vdpa.
Thanks
^ permalink raw reply [flat|nested] 7+ messages in thread
* RE: [EXTERNAL] Re: [RFC] crypto/virtio: add vhost-vdpa backend
2024-11-27 8:10 ` Jason Wang
@ 2024-11-28 4:31 ` Gowrishankar Muthukrishnan
2024-11-29 2:19 ` Jason Wang
0 siblings, 1 reply; 7+ messages in thread
From: Gowrishankar Muthukrishnan @ 2024-11-28 4:31 UTC (permalink / raw)
To: Jason Wang
Cc: dev, Maxime Coquelin, Chenbo Xia, Jay Zhou, techboard,
Anoob Joseph, Akhil Goyal, Jerin Jacob, Fan Zhang
Hi Jason,
> Hello:
>
> On Fri, Nov 22, 2024 at 2:03 AM Gowrishankar Muthukrishnan
> <gmuthukrishn@marvell.com> wrote:
> >
> > Hi,
> > We are adding support for vDPA user backend for virtio-crypto PMD in DPDK.
>
> I wonder what kind of vDPA device you are using? Is there a marvell specific
> vDPA or just a standard virtio-pci device via vp-vdpa.
>
Yes, we have Marvell specific vDPA.
https://github.com/ColinIanKing/linux-next/commit/8b6c724cdab85d8923dd8c474a5a9464228379c5
Thanks,
Gowrishankar
> Thanks
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [EXTERNAL] Re: [RFC] crypto/virtio: add vhost-vdpa backend
2024-11-28 4:31 ` [EXTERNAL] " Gowrishankar Muthukrishnan
@ 2024-11-29 2:19 ` Jason Wang
2024-12-05 12:27 ` Gowrishankar Muthukrishnan
0 siblings, 1 reply; 7+ messages in thread
From: Jason Wang @ 2024-11-29 2:19 UTC (permalink / raw)
To: Gowrishankar Muthukrishnan
Cc: dev, Maxime Coquelin, Chenbo Xia, Jay Zhou, techboard,
Anoob Joseph, Akhil Goyal, Jerin Jacob, Fan Zhang
On Thu, Nov 28, 2024 at 12:32 PM Gowrishankar Muthukrishnan
<gmuthukrishn@marvell.com> wrote:
>
> Hi Jason,
> > Hello:
> >
> > On Fri, Nov 22, 2024 at 2:03 AM Gowrishankar Muthukrishnan
> > <gmuthukrishn@marvell.com> wrote:
> > >
> > > Hi,
> > > We are adding support for vDPA user backend for virtio-crypto PMD in DPDK.
> >
> > I wonder what kind of vDPA device you are using? Is there a marvell specific
> > vDPA or just a standard virtio-pci device via vp-vdpa.
> >
> Yes, we have Marvell specific vDPA.
> https://github.com/ColinIanKing/linux-next/commit/8b6c724cdab85d8923dd8c474a5a9464228379c5
>
Right, I'm asking since it claims to support networking device only:
static struct virtio_device_id id_table[] = {
{ VIRTIO_ID_NET, VIRTIO_DEV_ANY_ID },
{ 0 },
};
Thanks
> Thanks,
> Gowrishankar
> > Thanks
>
^ permalink raw reply [flat|nested] 7+ messages in thread
* RE: [EXTERNAL] Re: [RFC] crypto/virtio: add vhost-vdpa backend
2024-11-29 2:19 ` Jason Wang
@ 2024-12-05 12:27 ` Gowrishankar Muthukrishnan
0 siblings, 0 replies; 7+ messages in thread
From: Gowrishankar Muthukrishnan @ 2024-12-05 12:27 UTC (permalink / raw)
To: Jason Wang
Cc: dev, Maxime Coquelin, Chenbo Xia, Jay Zhou, techboard,
Anoob Joseph, Akhil Goyal, Jerin Jacob, Fan Zhang
Hi Jason,
>
> Right, I'm asking since it claims to support networking device only:
>
> static struct virtio_device_id id_table[] = {
> { VIRTIO_ID_NET, VIRTIO_DEV_ANY_ID },
> { 0 },
> };
>
Yes, there is already a fix in it to support crypto id as well.
https://lore.kernel.org/virtualization/20241121134002.990285-3-sthotton@marvell.com/
Regards,
Gowrishankar
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2024-12-05 12:27 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-11-21 18:02 [RFC] crypto/virtio: add vhost-vdpa backend Gowrishankar Muthukrishnan
2024-11-27 6:50 ` Gowrishankar Muthukrishnan
2024-11-27 7:52 ` Chenbo Xia
2024-11-27 8:10 ` Jason Wang
2024-11-28 4:31 ` [EXTERNAL] " Gowrishankar Muthukrishnan
2024-11-29 2:19 ` Jason Wang
2024-12-05 12:27 ` Gowrishankar Muthukrishnan
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).