[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [RFC PATCH 0/7] AMD IOMMU emulation patchset
From: |
Eduard - Gabriel Munteanu |
Subject: |
[Qemu-devel] [RFC PATCH 0/7] AMD IOMMU emulation patchset |
Date: |
Wed, 14 Jul 2010 08:45:00 +0300 |
Hi everybody,
This is my work on the AMD IOMMU emulation project. I've put this, along
with the SeaBIOS patches (which you need to test), in my Git repos here:
http://repo.or.cz/w/qemu-kvm/amd-iommu.git
http://repo.or.cz/w/seabios/amd-iommu.git
While it works for Linux guests (didn't try anything else), it's not yet
complete. But the ported devices work, and so may others that either
don't do DMA (VGA for example) or they're not on a PCI bus.
Passing devices from a guest to a nested guest also works. It seems no
modifications were needed for that (well, except getting a host kernel
on which nested SVM works right ;), and I'd recommend 2.6.34.1), but I
only tested with the rtl8139. Will test soon with a doubly nested guest
to cover that scenario as well, along with testing other emulated hw.
I'd like your opinions on this. Perhaps you could test it and report if
you find any issues. Some things aren't done/complete yet:
- fixing the theoretical AIO issue, but it's not a priority right now
- actually testing that access checking works (should inject faults)
- implementing skipped translation levels
- a translation cache might be a good idea
- implementing features not used by Linux (e.g. interrupt remapping)
That being said, any feedback is welcome.
Thanks,
Eduard
P.S.: I'd also like to thank Paul Brook for his help on figuring out
some aspects of the IOMMU layer.
Eduard - Gabriel Munteanu (7):
Generic IOMMU layer
AMD IOMMU emulation
pci: call IOMMU hooks
ide: IOMMU support
rtl8139: IOMMU support
eepro100: IOMMU support
ac97: IOMMU support
Makefile.target | 3 +
configure | 11 +
hw/ac97.c | 20 ++-
hw/amd_iommu.c | 621 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
hw/eepro100.c | 141 +++++++++----
hw/ide/core.c | 46 +++--
hw/iommu.c | 82 ++++++++
hw/iommu.h | 260 +++++++++++++++++++++++
hw/pc.c | 4 +
hw/pc.h | 3 +
hw/pci.c | 21 ++
hw/pci_ids.h | 2 +
hw/pci_regs.h | 1 +
hw/qdev.h | 6 +
hw/rtl8139.c | 98 ++++++----
15 files changed, 1225 insertions(+), 94 deletions(-)
create mode 100644 hw/amd_iommu.c
create mode 100644 hw/iommu.c
create mode 100644 hw/iommu.h
- [Qemu-devel] [RFC PATCH 0/7] AMD IOMMU emulation patchset,
Eduard - Gabriel Munteanu <=
- [Qemu-devel] [RFC PATCH 3/7] pci: call IOMMU hooks, Eduard - Gabriel Munteanu, 2010/07/14
- [Qemu-devel] [RFC PATCH 4/7] ide: IOMMU support, Eduard - Gabriel Munteanu, 2010/07/14
- [Qemu-devel] Re: [RFC PATCH 4/7] ide: IOMMU support, Paul Brook, 2010/07/14
- [Qemu-devel] Re: [RFC PATCH 4/7] ide: IOMMU support, Joerg Roedel, 2010/07/14
- Re: [Qemu-devel] Re: [RFC PATCH 4/7] ide: IOMMU support, Paul Brook, 2010/07/14
- Re: [Qemu-devel] Re: [RFC PATCH 4/7] ide: IOMMU support, Anthony Liguori, 2010/07/14
- Re: [Qemu-devel] Re: [RFC PATCH 4/7] ide: IOMMU support, Chris Wright, 2010/07/14
- Re: [Qemu-devel] Re: [RFC PATCH 4/7] ide: IOMMU support, Paul Brook, 2010/07/15