* [PATCH v6 0/9] virtio DMA API, yet again
@ 2016-02-01 18:00 Andy Lutomirski
0 siblings, 0 replies; 2+ messages in thread
From: Andy Lutomirski @ 2016-02-01 18:00 UTC (permalink / raw)
To: Michael S. Tsirkin
Cc: Cornelia Huck, Joerg Roedel, KVM, linux-s390,
Benjamin Herrenschmidt, Stefano Stabellini, Sebastian Ott,
linux-kernel@vger.kernel.org, Christoph Hellwig,
Christian Borntraeger, David Vrabel, Andy Lutomirski, xen-devel,
sparclinux, Paolo Bonzini, Linux Virtualization, David Woodhouse,
David S. Miller, Martin Schwidefsky
This switches virtio to use the DMA API on Xen and if requested by
module option.
This fixes virtio on Xen, and it should break anything because it's
off by default on everything except Xen PV on x86.
To the Xen people: is this okay? If it doesn't work on other Xen
variants (PVH? HVM?), can you submit follow-up patches to fix it?
To everyone else: we've waffled on this for way too long. I think
we should to get DMA API implementation in with a conservative
policy like this rather than waiting until we achieve perfection.
I'm tired of carrying these patches around.
Michael, if these survive review, can you stage these in your tree?
Can you also take a look at tools/virtio? I probably broke it, but I
couldn't get it to build without these patches either, so I'm stuck.
Changes from v5:
- Typo fixes (David Woodhouse)
- Use xen_domain() to detect Xen (David Vrabel)
- Pass struct vring_virtqueue * into vring_use_dma_api for future proofing
- Removed module parameter (Michael)
Changes from v4:
- Bake vring_use_dma_api in from the beginning.
- Automatically enable only on Xen.
- Add module parameter.
- Add s390 and alpha DMA API implementations.
- Rebase to 4.5-rc1.
Changes from v3:
- More big-endian fixes.
- Added better virtio-ring APIs that handle allocation and use them in
virtio-mmio and virtio-pci.
- Switch to Michael's virtio-net patch.
Changes from v2:
- Fix vring_mapping_error incorrect argument
Changes from v1:
- Fix an endian conversion error causing a BUG to hit.
- Fix a DMA ordering issue (swiotlb=force works now).
- Minor cleanups.
Andy Lutomirski (6):
vring: Introduce vring_use_dma_api()
virtio_ring: Support DMA APIs
virtio: Add improved queue allocation API
virtio_mmio: Use the DMA API if enabled
virtio_pci: Use the DMA API if enabled
vring: Use the DMA API on Xen
Christian Borntraeger (3):
dma: Provide simple noop dma ops
alpha/dma: use common noop dma ops
s390/dma: Allow per device dma ops
arch/alpha/kernel/pci-noop.c | 46 +---
arch/s390/Kconfig | 6 +-
arch/s390/include/asm/device.h | 6 +-
arch/s390/include/asm/dma-mapping.h | 6 +-
arch/s390/pci/pci.c | 1 +
arch/s390/pci/pci_dma.c | 4 +-
drivers/virtio/Kconfig | 2 +-
drivers/virtio/virtio_mmio.c | 67 ++----
drivers/virtio/virtio_pci_common.h | 6 -
drivers/virtio/virtio_pci_legacy.c | 42 ++--
drivers/virtio/virtio_pci_modern.c | 61 ++----
drivers/virtio/virtio_ring.c | 408 ++++++++++++++++++++++++++++++------
include/linux/dma-mapping.h | 2 +
include/linux/virtio.h | 23 +-
include/linux/virtio_ring.h | 35 ++++
lib/Makefile | 1 +
lib/dma-noop.c | 75 +++++++
tools/virtio/linux/dma-mapping.h | 17 ++
18 files changed, 564 insertions(+), 244 deletions(-)
create mode 100644 lib/dma-noop.c
create mode 100644 tools/virtio/linux/dma-mapping.h
--
2.5.0
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [PATCH v6 0/9] virtio DMA API, yet again
[not found] <cover.1454349471.git.luto@kernel.org>
@ 2016-02-02 9:54 ` Christian Borntraeger
0 siblings, 0 replies; 2+ messages in thread
From: Christian Borntraeger @ 2016-02-02 9:54 UTC (permalink / raw)
To: Andy Lutomirski, Michael S. Tsirkin
Cc: linux-s390, Joerg Roedel, KVM, Stefano Stabellini,
Benjamin Herrenschmidt, Sebastian Ott,
linux-kernel@vger.kernel.org, Christoph Hellwig, Cornelia Huck,
David Vrabel, xen-devel, sparclinux, Paolo Bonzini,
Linux Virtualization, David Woodhouse, David S. Miller,
Martin Schwidefsky
On 02/01/2016 07:00 PM, Andy Lutomirski wrote:
> This switches virtio to use the DMA API on Xen and if requested by
> module option.
>
> This fixes virtio on Xen, and it should break anything because it's
> off by default on everything except Xen PV on x86.
>
> To the Xen people: is this okay? If it doesn't work on other Xen
> variants (PVH? HVM?), can you submit follow-up patches to fix it?
>
> To everyone else: we've waffled on this for way too long. I think
> we should to get DMA API implementation in with a conservative
> policy like this rather than waiting until we achieve perfection.
> I'm tired of carrying these patches around.
I used your branch pub/scm/linux/kernel/git/luto/linux.git virtio_dma
on kernel.org.
It seems to survive a basic test (simple block and net) on s390 with
and without dma api enabled. No full test, though.
>
> Michael, if these survive review, can you stage these in your tree?
> Can you also take a look at tools/virtio? I probably broke it, but I
> couldn't get it to build without these patches either, so I'm stuck.
>
> Changes from v5:
> - Typo fixes (David Woodhouse)
> - Use xen_domain() to detect Xen (David Vrabel)
> - Pass struct vring_virtqueue * into vring_use_dma_api for future proofing
> - Removed module parameter (Michael)
>
> Changes from v4:
> - Bake vring_use_dma_api in from the beginning.
> - Automatically enable only on Xen.
> - Add module parameter.
> - Add s390 and alpha DMA API implementations.
> - Rebase to 4.5-rc1.
>
> Changes from v3:
> - More big-endian fixes.
> - Added better virtio-ring APIs that handle allocation and use them in
> virtio-mmio and virtio-pci.
> - Switch to Michael's virtio-net patch.
>
> Changes from v2:
> - Fix vring_mapping_error incorrect argument
>
> Changes from v1:
> - Fix an endian conversion error causing a BUG to hit.
> - Fix a DMA ordering issue (swiotlb=force works now).
> - Minor cleanups.
>
> Andy Lutomirski (6):
> vring: Introduce vring_use_dma_api()
> virtio_ring: Support DMA APIs
> virtio: Add improved queue allocation API
> virtio_mmio: Use the DMA API if enabled
> virtio_pci: Use the DMA API if enabled
> vring: Use the DMA API on Xen
>
> Christian Borntraeger (3):
> dma: Provide simple noop dma ops
> alpha/dma: use common noop dma ops
> s390/dma: Allow per device dma ops
>
> arch/alpha/kernel/pci-noop.c | 46 +---
> arch/s390/Kconfig | 6 +-
> arch/s390/include/asm/device.h | 6 +-
> arch/s390/include/asm/dma-mapping.h | 6 +-
> arch/s390/pci/pci.c | 1 +
> arch/s390/pci/pci_dma.c | 4 +-
> drivers/virtio/Kconfig | 2 +-
> drivers/virtio/virtio_mmio.c | 67 ++----
> drivers/virtio/virtio_pci_common.h | 6 -
> drivers/virtio/virtio_pci_legacy.c | 42 ++--
> drivers/virtio/virtio_pci_modern.c | 61 ++----
> drivers/virtio/virtio_ring.c | 408 ++++++++++++++++++++++++++++++------
> include/linux/dma-mapping.h | 2 +
> include/linux/virtio.h | 23 +-
> include/linux/virtio_ring.h | 35 ++++
> lib/Makefile | 1 +
> lib/dma-noop.c | 75 +++++++
> tools/virtio/linux/dma-mapping.h | 17 ++
> 18 files changed, 564 insertions(+), 244 deletions(-)
> create mode 100644 lib/dma-noop.c
> create mode 100644 tools/virtio/linux/dma-mapping.h
>
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2016-02-02 9:54 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-02-01 18:00 [PATCH v6 0/9] virtio DMA API, yet again Andy Lutomirski
[not found] <cover.1454349471.git.luto@kernel.org>
2016-02-02 9:54 ` Christian Borntraeger
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).