From: Jason Wang <jasowang@redhat.com>
To: Cornelia Huck <cohuck@redhat.com>
Cc: kvm@vger.kernel.org, linux-s390@vger.kernel.org,
linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org,
intel-gfx@lists.freedesktop.org,
intel-gvt-dev@lists.freedesktop.org, kwankhede@nvidia.com,
alex.williamson@redhat.com, mst@redhat.com, tiwei.bie@intel.com,
gregkh@linuxfoundation.org, jgg@mellanox.com,
netdev@vger.kernel.org, maxime.coquelin@redhat.com,
cunming.liang@intel.com, zhihong.wang@intel.com,
rob.miller@broadcom.com, xiao.w.wang@intel.com,
haotian.wang@sifive.com, zhenyuw@linux.intel.com,
zhi.a.wang@intel.com, jani.nikula@linux.intel.com,
joonas.lahtinen@linux.intel.com, rodrigo.vivi@intel.com,
airlied@linux.ie, daniel@ffwll.ch, farman@linux.ibm.com,
pasic@linux.ibm.com, sebott@linux.ibm.com, oberpar@linux.ibm.com,
heiko.carstens@de.ibm.com, gor@linux.ibm.com,
borntraeger@de.ibm.com, akrowiak@linux.ibm.com,
freude@linux.ibm.com, lingshan.zhu@intel.com,
eperezma@redhat.com, lulu@redhat.com, parav@mellanox.com,
christophe.de.dinechin@gmail.com, kevin.tian@intel.com,
stefanha@redhat.com, rdunlap@infradead.org, hch@infradead.org,
aadam@redhat.com, jakub.kicinski@netronome.com,
jiri@mellanox.com, jeffrey.t.kirsher@intel.com
Subject: Re: [PATCH V13 6/6] docs: sample driver to demonstrate how to implement virtio-mdev framework
Date: Tue, 19 Nov 2019 11:04:51 +0800 [thread overview]
Message-ID: <8a4e504d-abb9-44f1-73ea-e337f596bf75@redhat.com> (raw)
In-Reply-To: <20191118164510.549c097b.cohuck@redhat.com>
On 2019/11/18 下午11:45, Cornelia Huck wrote:
> On Mon, 18 Nov 2019 18:59:23 +0800
> Jason Wang <jasowang@redhat.com> wrote:
>
> [Note: I have not looked into the reworked architecture of this *at all*
> so far; just something that I noted...]
>
>> This sample driver creates mdev device that simulate virtio net device
>> over virtio mdev transport. The device is implemented through vringh
>> and workqueue. A device specific dma ops is to make sure HVA is used
>> directly as the IOVA. This should be sufficient for kernel virtio
>> driver to work.
>>
>> Only 'virtio' type is supported right now. I plan to add 'vhost' type
>> on top which requires some virtual IOMMU implemented in this sample
>> driver.
>>
>> Signed-off-by: Jason Wang <jasowang@redhat.com>
>> ---
>> MAINTAINERS | 1 +
>> samples/Kconfig | 10 +
>> samples/vfio-mdev/Makefile | 1 +
>> samples/vfio-mdev/mvnet_loopback.c | 690 +++++++++++++++++++++++++++++
>> 4 files changed, 702 insertions(+)
>> create mode 100644 samples/vfio-mdev/mvnet_loopback.c
>>
>> +static struct mvnet_dev {
>> + struct class *vd_class;
>> + struct idr vd_idr;
>> + struct device dev;
>> +} mvnet_dev;
> This structure embeds a struct device (a reference-counted structure),
> yet it is a static variable. This is giving a bad example to potential
> implementers; just allocate it dynamically.
Yes, as spotted by Greg.
>
>> +static void mvnet_device_release(struct device *dev)
>> +{
>> + dev_dbg(dev, "mvnet: released\n");
> And that also means you need a proper release function here, of
> course.
Right.
Thanks
>
>> +}
WARNING: multiple messages have this Message-ID (diff)
From: Jason Wang <jasowang@redhat.com>
To: Cornelia Huck <cohuck@redhat.com>
Cc: kvm@vger.kernel.org, linux-s390@vger.kernel.org,
linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org,
intel-gfx@lists.freedesktop.org,
intel-gvt-dev@lists.freedesktop.org, kwankhede@nvidia.com,
alex.williamson@redhat.com, mst@redhat.com, tiwei.bie@intel.com,
gregkh@linuxfoundation.org, jgg@mellanox.com,
netdev@vger.kernel.org, maxime.coquelin@redhat.com,
cunming.liang@intel.com, zhihong.wang@intel.com,
rob.miller@broadcom.com, xiao.w.wang@intel.com,
haotian.wang@sifive.com, zhenyuw@linux.intel.com,
zhi.a.wang@intel.com, jani.nikula@linux.intel.com,
joonas.lahtinen@linux.intel.com, rodrigo.vivi@intel.com,
airlied@linux.ie, daniel@ffwll.ch, farman@linux.ibm.com,
pasic@linux.ibm.com, sebott@linux.ibm.com, oberpar@linux.ibm.com,
heiko.carstens@de.ibm.com, gor@linux.ib
Subject: Re: [PATCH V13 6/6] docs: sample driver to demonstrate how to implement virtio-mdev framework
Date: Tue, 19 Nov 2019 11:04:51 +0800 [thread overview]
Message-ID: <8a4e504d-abb9-44f1-73ea-e337f596bf75@redhat.com> (raw)
In-Reply-To: <20191118164510.549c097b.cohuck@redhat.com>
On 2019/11/18 下午11:45, Cornelia Huck wrote:
> On Mon, 18 Nov 2019 18:59:23 +0800
> Jason Wang <jasowang@redhat.com> wrote:
>
> [Note: I have not looked into the reworked architecture of this *at all*
> so far; just something that I noted...]
>
>> This sample driver creates mdev device that simulate virtio net device
>> over virtio mdev transport. The device is implemented through vringh
>> and workqueue. A device specific dma ops is to make sure HVA is used
>> directly as the IOVA. This should be sufficient for kernel virtio
>> driver to work.
>>
>> Only 'virtio' type is supported right now. I plan to add 'vhost' type
>> on top which requires some virtual IOMMU implemented in this sample
>> driver.
>>
>> Signed-off-by: Jason Wang <jasowang@redhat.com>
>> ---
>> MAINTAINERS | 1 +
>> samples/Kconfig | 10 +
>> samples/vfio-mdev/Makefile | 1 +
>> samples/vfio-mdev/mvnet_loopback.c | 690 +++++++++++++++++++++++++++++
>> 4 files changed, 702 insertions(+)
>> create mode 100644 samples/vfio-mdev/mvnet_loopback.c
>>
>> +static struct mvnet_dev {
>> + struct class *vd_class;
>> + struct idr vd_idr;
>> + struct device dev;
>> +} mvnet_dev;
> This structure embeds a struct device (a reference-counted structure),
> yet it is a static variable. This is giving a bad example to potential
> implementers; just allocate it dynamically.
Yes, as spotted by Greg.
>
>> +static void mvnet_device_release(struct device *dev)
>> +{
>> + dev_dbg(dev, "mvnet: released\n");
> And that also means you need a proper release function here, of
> course.
Right.
Thanks
>
>> +}
WARNING: multiple messages have this Message-ID (diff)
From: Jason Wang <jasowang@redhat.com>
To: Cornelia Huck <cohuck@redhat.com>
Cc: jakub.kicinski@netronome.com, christophe.de.dinechin@gmail.com,
kvm@vger.kernel.org, mst@redhat.com, airlied@linux.ie,
heiko.carstens@de.ibm.com, haotian.wang@sifive.com,
dri-devel@lists.freedesktop.org, oberpar@linux.ibm.com,
kwankhede@nvidia.com, rob.miller@broadcom.com,
linux-s390@vger.kernel.org, sebott@linux.ibm.com,
lulu@redhat.com, eperezma@redhat.com, pasic@linux.ibm.com,
borntraeger@de.ibm.com, jgg@mellanox.com,
jeffrey.t.kirsher@intel.com, cunming.liang@intel.com,
zhi.a.wang@intel.com, farman@linux.ibm.com, parav@mellanox.com,
gor@linux.ibm.com, intel-gfx@lists.freedesktop.org,
kevin.tian@intel.com, alex.williamson@redhat.com,
xiao.w.wang@intel.com, freude@linux.ibm.com, stefanha@redhat.com,
zhihong.wang@intel.com, rodrigo.vivi@intel.com,
intel-gvt-dev@lists.freedesktop.org, hch@infradead.org,
akrowiak@linux.ibm.com, aadam@redhat.com, jiri@mellanox.com,
tiwei.bie@intel.com, gregkh@linuxfoundation.org,
rdunlap@infradead.org, linux-kernel@vger.kernel.org,
maxime.coquelin@redhat.com, netdev@vger.kernel.org,
lingshan.zhu@intel.com
Subject: Re: [PATCH V13 6/6] docs: sample driver to demonstrate how to implement virtio-mdev framework
Date: Tue, 19 Nov 2019 11:04:51 +0800 [thread overview]
Message-ID: <8a4e504d-abb9-44f1-73ea-e337f596bf75@redhat.com> (raw)
Message-ID: <20191119030451.Xza7R_ZXQy0R2B87KOFK1-sRs7FciAM3sfeac_p1e1o@z> (raw)
In-Reply-To: <20191118164510.549c097b.cohuck@redhat.com>
On 2019/11/18 下午11:45, Cornelia Huck wrote:
> On Mon, 18 Nov 2019 18:59:23 +0800
> Jason Wang <jasowang@redhat.com> wrote:
>
> [Note: I have not looked into the reworked architecture of this *at all*
> so far; just something that I noted...]
>
>> This sample driver creates mdev device that simulate virtio net device
>> over virtio mdev transport. The device is implemented through vringh
>> and workqueue. A device specific dma ops is to make sure HVA is used
>> directly as the IOVA. This should be sufficient for kernel virtio
>> driver to work.
>>
>> Only 'virtio' type is supported right now. I plan to add 'vhost' type
>> on top which requires some virtual IOMMU implemented in this sample
>> driver.
>>
>> Signed-off-by: Jason Wang <jasowang@redhat.com>
>> ---
>> MAINTAINERS | 1 +
>> samples/Kconfig | 10 +
>> samples/vfio-mdev/Makefile | 1 +
>> samples/vfio-mdev/mvnet_loopback.c | 690 +++++++++++++++++++++++++++++
>> 4 files changed, 702 insertions(+)
>> create mode 100644 samples/vfio-mdev/mvnet_loopback.c
>>
>> +static struct mvnet_dev {
>> + struct class *vd_class;
>> + struct idr vd_idr;
>> + struct device dev;
>> +} mvnet_dev;
> This structure embeds a struct device (a reference-counted structure),
> yet it is a static variable. This is giving a bad example to potential
> implementers; just allocate it dynamically.
Yes, as spotted by Greg.
>
>> +static void mvnet_device_release(struct device *dev)
>> +{
>> + dev_dbg(dev, "mvnet: released\n");
> And that also means you need a proper release function here, of
> course.
Right.
Thanks
>
>> +}
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel
WARNING: multiple messages have this Message-ID (diff)
From: Jason Wang <jasowang@redhat.com>
To: Cornelia Huck <cohuck@redhat.com>
Cc: jakub.kicinski@netronome.com, christophe.de.dinechin@gmail.com,
kvm@vger.kernel.org, mst@redhat.com, airlied@linux.ie,
heiko.carstens@de.ibm.com, haotian.wang@sifive.com,
dri-devel@lists.freedesktop.org, oberpar@linux.ibm.com,
kwankhede@nvidia.com, rob.miller@broadcom.com,
linux-s390@vger.kernel.org, sebott@linux.ibm.com,
lulu@redhat.com, eperezma@redhat.com, pasic@linux.ibm.com,
borntraeger@de.ibm.com, jgg@mellanox.com,
jeffrey.t.kirsher@intel.com, cunming.liang@intel.com,
farman@linux.ibm.com, parav@mellanox.com, gor@linux.ibm.com,
intel-gfx@lists.freedesktop.org, xiao.w.wang@intel.com,
freude@linux.ibm.com, stefanha@redhat.com,
zhihong.wang@intel.com, intel-gvt-dev@lists.freedesktop.org,
hch@infradead.org, akrowiak@linux.ibm.com, aadam@redhat.com,
jiri@mellanox.com, tiwei.bie@intel.com,
gregkh@linuxfoundation.org, rdunlap@infradead.org,
linux-kernel@vger.kernel.org, maxime.coquelin@redhat.com,
netdev@vger.kernel.org, lingshan.zhu@intel.com
Subject: Re: [Intel-gfx] [PATCH V13 6/6] docs: sample driver to demonstrate how to implement virtio-mdev framework
Date: Tue, 19 Nov 2019 11:04:51 +0800 [thread overview]
Message-ID: <8a4e504d-abb9-44f1-73ea-e337f596bf75@redhat.com> (raw)
Message-ID: <20191119030451.2k4ZkdLIJwBOu971AmvLaebOCvOMeAUfErcZdR6W5qo@z> (raw)
In-Reply-To: <20191118164510.549c097b.cohuck@redhat.com>
On 2019/11/18 下午11:45, Cornelia Huck wrote:
> On Mon, 18 Nov 2019 18:59:23 +0800
> Jason Wang <jasowang@redhat.com> wrote:
>
> [Note: I have not looked into the reworked architecture of this *at all*
> so far; just something that I noted...]
>
>> This sample driver creates mdev device that simulate virtio net device
>> over virtio mdev transport. The device is implemented through vringh
>> and workqueue. A device specific dma ops is to make sure HVA is used
>> directly as the IOVA. This should be sufficient for kernel virtio
>> driver to work.
>>
>> Only 'virtio' type is supported right now. I plan to add 'vhost' type
>> on top which requires some virtual IOMMU implemented in this sample
>> driver.
>>
>> Signed-off-by: Jason Wang <jasowang@redhat.com>
>> ---
>> MAINTAINERS | 1 +
>> samples/Kconfig | 10 +
>> samples/vfio-mdev/Makefile | 1 +
>> samples/vfio-mdev/mvnet_loopback.c | 690 +++++++++++++++++++++++++++++
>> 4 files changed, 702 insertions(+)
>> create mode 100644 samples/vfio-mdev/mvnet_loopback.c
>>
>> +static struct mvnet_dev {
>> + struct class *vd_class;
>> + struct idr vd_idr;
>> + struct device dev;
>> +} mvnet_dev;
> This structure embeds a struct device (a reference-counted structure),
> yet it is a static variable. This is giving a bad example to potential
> implementers; just allocate it dynamically.
Yes, as spotted by Greg.
>
>> +static void mvnet_device_release(struct device *dev)
>> +{
>> + dev_dbg(dev, "mvnet: released\n");
> And that also means you need a proper release function here, of
> course.
Right.
Thanks
>
>> +}
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx
next prev parent reply other threads:[~2019-11-19 3:05 UTC|newest]
Thread overview: 100+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-11-18 10:59 [PATCH V13 0/6] mdev based hardware virtio offloading support Jason Wang
2019-11-18 10:59 ` [Intel-gfx] " Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 10:59 ` [PATCH V13 1/6] mdev: make mdev bus agnostic Jason Wang
2019-11-18 10:59 ` [Intel-gfx] " Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-19 3:08 ` Randy Dunlap
2019-11-19 3:08 ` [Intel-gfx] " Randy Dunlap
2019-11-19 3:08 ` Randy Dunlap
2019-11-19 3:08 ` Randy Dunlap
2019-11-18 10:59 ` [PATCH V13 2/6] mdev: split out VFIO bus specific parent ops Jason Wang
2019-11-18 10:59 ` [Intel-gfx] " Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 10:59 ` [PATCH V13 3/6] mdev: move to drivers/ Jason Wang
2019-11-18 10:59 ` [Intel-gfx] " Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-19 3:11 ` Randy Dunlap
2019-11-19 3:11 ` [Intel-gfx] " Randy Dunlap
2019-11-19 3:11 ` Randy Dunlap
2019-11-19 3:11 ` Randy Dunlap
2019-11-18 10:59 ` [PATCH V13 4/6] mdev: introduce mediated virtio bus Jason Wang
2019-11-18 10:59 ` [Intel-gfx] " Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 13:41 ` Jason Gunthorpe
2019-11-18 13:41 ` [Intel-gfx] " Jason Gunthorpe
2019-11-18 13:41 ` Jason Gunthorpe
2019-11-18 20:27 ` Michael S. Tsirkin
2019-11-18 20:27 ` [Intel-gfx] " Michael S. Tsirkin
2019-11-18 20:27 ` Michael S. Tsirkin
2019-11-18 20:28 ` Jason Gunthorpe
2019-11-18 20:28 ` [Intel-gfx] " Jason Gunthorpe
2019-11-18 20:28 ` Jason Gunthorpe
2019-11-19 2:41 ` Jason Wang
2019-11-19 2:41 ` [Intel-gfx] " Jason Wang
2019-11-19 2:41 ` Jason Wang
2019-11-19 12:38 ` Jason Gunthorpe
2019-11-19 12:38 ` [Intel-gfx] " Jason Gunthorpe
2019-11-19 14:02 ` Jason Wang
2019-11-19 14:02 ` [Intel-gfx] " Jason Wang
2019-11-19 14:02 ` Jason Wang
2019-11-19 14:14 ` Jason Gunthorpe
2019-11-19 14:14 ` [Intel-gfx] " Jason Gunthorpe
2019-11-20 2:14 ` Jason Wang
2019-11-20 2:14 ` [Intel-gfx] " Jason Wang
2019-11-20 2:14 ` Jason Wang
2019-11-20 13:49 ` Jason Gunthorpe
2019-11-20 13:49 ` [Intel-gfx] " Jason Gunthorpe
2019-11-20 13:49 ` Jason Gunthorpe
2019-11-21 3:05 ` Jason Wang
2019-11-21 3:05 ` [Intel-gfx] " Jason Wang
2019-11-21 3:05 ` Jason Wang
2019-11-26 12:07 ` Rob Miller
2019-11-26 12:07 ` [Intel-gfx] " Rob Miller
2019-11-26 12:07 ` Rob Miller
2019-11-19 2:40 ` Jason Wang
2019-11-19 2:40 ` [Intel-gfx] " Jason Wang
2019-11-19 2:40 ` Jason Wang
2019-11-19 3:13 ` Randy Dunlap
2019-11-19 3:13 ` [Intel-gfx] " Randy Dunlap
2019-11-19 3:13 ` Randy Dunlap
2019-11-19 3:13 ` Randy Dunlap
2019-11-18 10:59 ` [PATCH V13 5/6] virtio: introduce a mdev based transport Jason Wang
2019-11-18 10:59 ` [Intel-gfx] " Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 10:59 ` [PATCH V13 6/6] docs: sample driver to demonstrate how to implement virtio-mdev framework Jason Wang
2019-11-18 10:59 ` [Intel-gfx] " Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 10:59 ` Jason Wang
2019-11-18 15:17 ` Greg KH
2019-11-18 15:17 ` [Intel-gfx] " Greg KH
2019-11-18 15:17 ` Greg KH
2019-11-18 15:17 ` Greg KH
2019-11-19 3:03 ` Jason Wang
2019-11-19 3:03 ` [Intel-gfx] " Jason Wang
2019-11-19 3:03 ` Jason Wang
2019-11-19 3:03 ` Jason Wang
2019-11-19 12:40 ` Jason Gunthorpe
2019-11-19 12:40 ` [Intel-gfx] " Jason Gunthorpe
2019-11-19 14:07 ` Jason Wang
2019-11-19 14:07 ` [Intel-gfx] " Jason Wang
2019-11-19 14:07 ` Jason Wang
2019-11-19 16:39 ` Jason Gunthorpe
2019-11-19 16:39 ` [Intel-gfx] " Jason Gunthorpe
2019-11-18 15:45 ` Cornelia Huck
2019-11-18 15:45 ` [Intel-gfx] " Cornelia Huck
2019-11-18 15:45 ` Cornelia Huck
2019-11-18 15:45 ` Cornelia Huck
2019-11-19 3:04 ` Jason Wang [this message]
2019-11-19 3:04 ` [Intel-gfx] " Jason Wang
2019-11-19 3:04 ` Jason Wang
2019-11-19 3:04 ` Jason Wang
2019-11-18 13:35 ` ✗ Fi.CI.CHECKPATCH: warning for mdev based hardware virtio offloading support Patchwork
2019-11-18 13:35 ` [Intel-gfx] " Patchwork
2019-11-18 13:51 ` ✗ Fi.CI.DOCS: " Patchwork
2019-11-18 13:51 ` [Intel-gfx] " Patchwork
2019-11-18 14:25 ` ✗ Fi.CI.BAT: failure " Patchwork
2019-11-18 14:25 ` [Intel-gfx] " Patchwork
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=8a4e504d-abb9-44f1-73ea-e337f596bf75@redhat.com \
--to=jasowang@redhat.com \
--cc=aadam@redhat.com \
--cc=airlied@linux.ie \
--cc=akrowiak@linux.ibm.com \
--cc=alex.williamson@redhat.com \
--cc=borntraeger@de.ibm.com \
--cc=christophe.de.dinechin@gmail.com \
--cc=cohuck@redhat.com \
--cc=cunming.liang@intel.com \
--cc=daniel@ffwll.ch \
--cc=dri-devel@lists.freedesktop.org \
--cc=eperezma@redhat.com \
--cc=farman@linux.ibm.com \
--cc=freude@linux.ibm.com \
--cc=gor@linux.ibm.com \
--cc=gregkh@linuxfoundation.org \
--cc=haotian.wang@sifive.com \
--cc=hch@infradead.org \
--cc=heiko.carstens@de.ibm.com \
--cc=intel-gfx@lists.freedesktop.org \
--cc=intel-gvt-dev@lists.freedesktop.org \
--cc=jakub.kicinski@netronome.com \
--cc=jani.nikula@linux.intel.com \
--cc=jeffrey.t.kirsher@intel.com \
--cc=jgg@mellanox.com \
--cc=jiri@mellanox.com \
--cc=joonas.lahtinen@linux.intel.com \
--cc=kevin.tian@intel.com \
--cc=kvm@vger.kernel.org \
--cc=kwankhede@nvidia.com \
--cc=lingshan.zhu@intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-s390@vger.kernel.org \
--cc=lulu@redhat.com \
--cc=maxime.coquelin@redhat.com \
--cc=mst@redhat.com \
--cc=netdev@vger.kernel.org \
--cc=oberpar@linux.ibm.com \
--cc=parav@mellanox.com \
--cc=pasic@linux.ibm.com \
--cc=rdunlap@infradead.org \
--cc=rob.miller@broadcom.com \
--cc=rodrigo.vivi@intel.com \
--cc=sebott@linux.ibm.com \
--cc=stefanha@redhat.com \
--cc=tiwei.bie@intel.com \
--cc=xiao.w.wang@intel.com \
--cc=zhenyuw@linux.intel.com \
--cc=zhi.a.wang@intel.com \
--cc=zhihong.wang@intel.com \
/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.