From: Shunsuke Mie <mie@igel.co.jp>
To: Jason Wang <jasowang@redhat.com>
Cc: "Kishon Vijay Abraham I" <kishon@kernel.org>,
"Krzysztof Wilczyński" <kw@linux.com>,
"Randy Dunlap" <rdunlap@infradead.org>,
"Michael S. Tsirkin" <mst@redhat.com>,
linux-pci@vger.kernel.org,
"Lorenzo Pieralisi" <lpieralisi@kernel.org>,
"Manivannan Sadhasivam" <mani@kernel.org>,
"Frank Li" <Frank.Li@nxp.com>,
linux-kernel@vger.kernel.org,
virtualization@lists.linux-foundation.org,
"Ren Zhijie" <renzhijie2@huawei.com>,
"Jon Mason" <jdmason@kudzu.us>,
"Bjorn Helgaas" <bhelgaas@google.com>
Subject: Re: [RFC PATCH v2 3/3] PCI: endpoint: Add EP function driver to provide virtio-console functionality
Date: Wed, 31 May 2023 19:51:38 +0900 [thread overview]
Message-ID: <2422273d-5ac2-63ef-8a31-230ebfbe3b23@igel.co.jp> (raw)
In-Reply-To: <CACGkMEvdVHQEcDD74TpeWgmHQ+J9aMpv5ui=iwT8E_SDZoY7EA@mail.gmail.com>
I'm sorry for late response.
On 2023/05/19 11:01, Jason Wang wrote:
> On Thu, May 18, 2023 at 5:54 PM Shunsuke Mie <mie@igel.co.jp> wrote:
>> Gentle ping ...
>>
>>
>> Thanks,
>>
>> Shunsuke.
>>
>> On 2023/05/10 12:17, Shunsuke Mie wrote:
>>> Hi Json,
>>> 2023年5月8日(月) 13:03 Jason Wang <jasowang@redhat.com>:
>>>> On Thu, Apr 27, 2023 at 6:44 PM Shunsuke Mie <mie@igel.co.jp> wrote:
>>>>> Add a new PCIe endpoint function driver that works as a pci virtio-console
>>>>> device. The console connect to endpoint side console. It enables to
>>>>> communicate PCIe host and endpoint.
>>>>>
>>>>> Architecture is following:
>>>>>
>>>>> ┌────────────┐ ┌──────────────────────┬────────────┐
>>>>> │virtioe │ │ │virtio │
>>>>> │console drv │ ├───────────────┐ │console drv │
>>>>> ├────────────┤ │(virtio console│ ├────────────┤
>>>>> │ virtio bus │ │ device) │◄────►│ virtio bus │
>>>>> ├────────────┤ ├---------------┤ └────────────┤
>>>>> │ │ │ pci ep virtio │ │
>>>>> │ pci bus │ │ console drv │ │
>>>>> │ │ pcie ├───────────────┤ │
>>>>> │ │ ◄─────► │ pci ep Bus │ │
>>>>> └────────────┘ └───────────────┴───────────────────┘
>>>>> PCIe Root PCIe Endpoint
>>>>>
>>>> I think it might only works for peer devices like:
>>>>
>>>> net, console or vsock.
>>> Could you tell me what "peer devices" means?
> I meant, for example we know in the case of virtio-net, TX can talk
> with RX belonging to another device directly.
>
> But this is not the case for other devices like virito-blk.
Thank you. I comprehended it.
>>>> So there're many choices here, I'd like to know what's the reason for
>>>> you to implement a mediation.
>>>>
>>>> An alternative is to implement a dedicated net, console and vsock
>>>> driver for vringh (CAIF somehow works like this). This would have
>>>> better performance.
>>> Does it mean that the driver also functions as a network driver directly?
> I meant, e.g in the case of networking, you can have a dedicated
> driver with two vringh in the endpoint side.
>
> The benefit is the performance, no need for the (datapath) mediation.
>
> But if we don't care about the performance, this proposal seems to be fine.
>
> Thanks
I agree with you. The design you suggested is better in terms of
performance.
However, the proposed design is not bad for the following the reasons I
think.
The proposed design has one more operation in control plane because the data
steps over the virtio-net driver, but the number of copies at the data plane
remains the same. I think the operation added in control plane has small
effects
for performance.
Moreover, there are some advantages when the data step over the virtio-net
driver. We can make use of the optimizations and some functions without
modifications and implementations. e.g. ethtool and XDP(BPF) supports.
Any comments would be appreciated.
>>>>> This driver has two roles. The first is as a PCIe endpoint virtio console
>>>>> function, which is implemented using the PCIe endpoint framework and PCIe
>>>>> EP virtio helpers. The second is as a virtual virtio console device
>>>>> connected to the virtio bus on PCIe endpoint Linux.
>>>>>
>>>>> Communication between the two is achieved by copying the virtqueue data
>>>>> between PCIe root and endpoint, respectively.
>>>>>
>>>>> This is a simple implementation and does not include features of
>>>>> virtio-console such as MULTIPORT, EMERG_WRITE, etc. As a result, each
>>>>> virtio console driver only displays /dev/hvc0.
>>>>>
>>>>> As an example of usage, by setting getty to /dev/hvc0, it is possible to
>>>>> login to another host.
>>>>>
>>>>> Signed-off-by: Shunsuke Mie <mie@igel.co.jp>
>>>>> ---
>>>>> Changes from v2:
>>>>> - Change to use copy functions between kiovs of pci-epf-virtio.
>>>>>
>>>>> drivers/pci/endpoint/functions/Kconfig | 12 +
>>>>> drivers/pci/endpoint/functions/Makefile | 1 +
>>>>> drivers/pci/endpoint/functions/pci-epf-vcon.c | 596 ++++++++++++++++++
>>>>> 3 files changed, 609 insertions(+)
>>>>> create mode 100644 drivers/pci/endpoint/functions/pci-epf-vcon.c
>>>>>
>>>>> diff --git a/drivers/pci/endpoint/functions/Kconfig b/drivers/pci/endpoint/functions/Kconfig
>>>>> index fa1a6a569a8f..9ce2698b67e1 100644
>>>>> --- a/drivers/pci/endpoint/functions/Kconfig
>>>>> +++ b/drivers/pci/endpoint/functions/Kconfig
>>>>> @@ -44,3 +44,15 @@ config PCI_EPF_VIRTIO
>>>>> select VHOST_RING_IOMEM
>>>>> help
>>>>> Helpers to implement PCI virtio Endpoint function
>>>>> +
>>>>> +config PCI_EPF_VCON
>>>>> + tristate "PCI Endpoint virito-console driver"
>>>>> + depends on PCI_ENDPOINT
>>>>> + select VHOST_RING
>>>>> + select PCI_EPF_VIRTIO
>>>>> + help
>>>>> + PCIe Endpoint virtio-console function implementatino. This module
>>>>> + enables to show the virtio-console as pci device to PCIe host side, and
>>>>> + another virtual virtio-console device registers to endpoint system.
>>>>> + Those devices are connected virtually and can communicate each other.
>>>>> +
>>>>> diff --git a/drivers/pci/endpoint/functions/Makefile b/drivers/pci/endpoint/functions/Makefile
>>>>> index a96f127ce900..b4056689ce33 100644
>>>>> --- a/drivers/pci/endpoint/functions/Makefile
>>>>> +++ b/drivers/pci/endpoint/functions/Makefile
>>>>> @@ -7,3 +7,4 @@ obj-$(CONFIG_PCI_EPF_TEST) += pci-epf-test.o
>>>>> obj-$(CONFIG_PCI_EPF_NTB) += pci-epf-ntb.o
>>>>> obj-$(CONFIG_PCI_EPF_VNTB) += pci-epf-vntb.o
>>>>> obj-$(CONFIG_PCI_EPF_VIRTIO) += pci-epf-virtio.o
>>>>> +obj-$(CONFIG_PCI_EPF_VCON) += pci-epf-vcon.o
>>>>> diff --git a/drivers/pci/endpoint/functions/pci-epf-vcon.c b/drivers/pci/endpoint/functions/pci-epf-vcon.c
>>>>> new file mode 100644
>>>>> index 000000000000..31f4247cd10f
>>>>> --- /dev/null
>>>>> +++ b/drivers/pci/endpoint/functions/pci-epf-vcon.c
>>>>> @@ -0,0 +1,596 @@
>>>>> +// SPDX-License-Identifier: GPL-2.0
>>>>> +/*
>>>>> + * PCI Endpoint function driver to impliment virtio-console device
>>>>> + * functionality.
>>>>> + */
>>>>> +#include <linux/pci-epf.h>
>>>>> +#include <linux/virtio_ids.h>
>>>>> +#include <linux/virtio_pci.h>
>>>>> +#include <linux/virtio_console.h>
>>>>> +#include <linux/virtio_ring.h>
>>>>> +
>>>>> +#include "pci-epf-virtio.h"
>>>>> +
>>>>> +static int virtio_queue_size = 0x100;
>>>>> +module_param(virtio_queue_size, int, 0444);
>>>>> +MODULE_PARM_DESC(virtio_queue_size, "A length of virtqueue");
>>>>> +
>>>>> +struct epf_vcon {
>>>>> + /* To access virtqueues on remote host */
>>>>> + struct epf_virtio evio;
>>>>> + struct vringh_kiov *rdev_iovs;
>>>>> +
>>>>> + /* To register a local virtio bus */
>>>>> + struct virtio_device vdev;
>>>>> +
>>>>> + /* To access virtqueus of local host driver */
>>>>> + struct vringh *vdev_vrhs;
>>>>> + struct vringh_kiov *vdev_iovs;
>>>>> + struct virtqueue **vdev_vqs;
>>>>> +
>>>>> + /* For transportation and notification */
>>>>> + struct workqueue_struct *task_wq;
>>>>> + struct work_struct raise_irq_work, rx_work, tx_work;
>>>>> +
>>>>> + /* To retain virtio features. It is commonly used local and remote. */
>>>>> + u64 features;
>>>>> +
>>>>> + /* To show a status whether this driver is ready and the remote is connected */
>>>>> + bool connected;
>>>>> +};
>>>>> +
>>>>> +enum {
>>>>> + VCON_VIRTQUEUE_RX,
>>>>> + VCON_VIRTQUEUE_TX,
>>>>> + // Should be end of enum
>>>>> + VCON_VIRTQUEUE_NUM
>>>>> +};
>>>> It would be better if we can split the console specific thing out,
>>>> then it allows us to do ethernet and vsock in the future.
>>> I'm planning to implement each virtio device in a separate file.
>>> https://lwn.net/Articles/922124/
>>>
>>>
>>>
>>>> Thanks
>>>>
>>> Best regards,
>>> Shunsuke
Best regards,
Shunsuke
_______________________________________________
Virtualization mailing list
Virtualization@lists.linux-foundation.org
https://lists.linuxfoundation.org/mailman/listinfo/virtualization
next prev parent reply other threads:[~2023-05-31 10:51 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-04-27 10:44 [RFC PATCH v2 0/3] Introduce a PCIe endpoint virtio console Shunsuke Mie
2023-04-27 10:44 ` [RFC PATCH v2 1/3] PCI: endpoint: introduce a helper to implement pci ep virtio function Shunsuke Mie
2023-04-27 18:28 ` Bjorn Helgaas
2023-05-10 3:49 ` Shunsuke Mie
2023-05-08 3:57 ` Jason Wang
2023-04-27 10:44 ` [RFC PATCH v2 2/3] virtio_pci: add a definition of queue flag in ISR Shunsuke Mie
2023-05-08 3:59 ` Jason Wang
2023-05-10 3:18 ` Shunsuke Mie
2023-04-27 10:44 ` [RFC PATCH v2 3/3] PCI: endpoint: Add EP function driver to provide virtio-console functionality Shunsuke Mie
2023-04-27 18:09 ` Bjorn Helgaas
2023-05-10 1:25 ` Shunsuke Mie
2023-05-08 4:03 ` Jason Wang
2023-05-10 3:17 ` Shunsuke Mie
2023-05-18 9:54 ` Shunsuke Mie
2023-05-19 2:01 ` Jason Wang
2023-05-31 10:51 ` Shunsuke Mie [this message]
2023-04-27 17:52 ` [RFC PATCH v2 0/3] Introduce a PCIe endpoint virtio console Bjorn Helgaas
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=2422273d-5ac2-63ef-8a31-230ebfbe3b23@igel.co.jp \
--to=mie@igel.co.jp \
--cc=Frank.Li@nxp.com \
--cc=bhelgaas@google.com \
--cc=jasowang@redhat.com \
--cc=jdmason@kudzu.us \
--cc=kishon@kernel.org \
--cc=kw@linux.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=lpieralisi@kernel.org \
--cc=mani@kernel.org \
--cc=mst@redhat.com \
--cc=rdunlap@infradead.org \
--cc=renzhijie2@huawei.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: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox