diff options
author | David Gibson <dwg@au1.ibm.com> | 2011-06-28 20:22:41 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2011-07-12 06:16:56 -0400 |
commit | 54738c097163c3f01e67ccc85462b78d4d4f495f (patch) | |
tree | cba8d389d50251856cbe967c16ba2193a30d6d12 /arch/powerpc/kvm/powerpc.c | |
parent | a8606e20e41a8149456bafdf76ad29d47672027c (diff) |
KVM: PPC: Accelerate H_PUT_TCE by implementing it in real mode
This improves I/O performance for guests using the PAPR
paravirtualization interface by making the H_PUT_TCE hcall faster, by
implementing it in real mode. H_PUT_TCE is used for updating virtual
IOMMU tables, and is used both for virtual I/O and for real I/O in the
PAPR interface.
Since this moves the IOMMU tables into the kernel, we define a new
KVM_CREATE_SPAPR_TCE ioctl to allow qemu to create the tables. The
ioctl returns a file descriptor which can be used to mmap the newly
created table. The qemu driver models use them in the same way as
userspace managed tables, but they can be updated directly by the
guest with a real-mode H_PUT_TCE implementation, reducing the number
of host/guest context switches during guest IO.
There are certain circumstances where it is useful for userland qemu
to write to the TCE table even if the kernel H_PUT_TCE path is used
most of the time. Specifically, allowing this will avoid awkwardness
when we need to reset the table. More importantly, we will in the
future need to write the table in order to restore its state after a
checkpoint resume or migration.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'arch/powerpc/kvm/powerpc.c')
-rw-r--r-- | arch/powerpc/kvm/powerpc.c | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/arch/powerpc/kvm/powerpc.c b/arch/powerpc/kvm/powerpc.c index 6fc9ee499b61..c78ceb9d5605 100644 --- a/arch/powerpc/kvm/powerpc.c +++ b/arch/powerpc/kvm/powerpc.c | |||
@@ -203,6 +203,11 @@ int kvm_dev_ioctl_check_extension(long ext) | |||
203 | r = KVM_COALESCED_MMIO_PAGE_OFFSET; | 203 | r = KVM_COALESCED_MMIO_PAGE_OFFSET; |
204 | break; | 204 | break; |
205 | #endif | 205 | #endif |
206 | #ifdef CONFIG_KVM_BOOK3S_64_HV | ||
207 | case KVM_CAP_SPAPR_TCE: | ||
208 | r = 1; | ||
209 | break; | ||
210 | #endif | ||
206 | default: | 211 | default: |
207 | r = 0; | 212 | r = 0; |
208 | break; | 213 | break; |
@@ -653,6 +658,19 @@ long kvm_arch_vm_ioctl(struct file *filp, | |||
653 | 658 | ||
654 | break; | 659 | break; |
655 | } | 660 | } |
661 | #ifdef CONFIG_KVM_BOOK3S_64_HV | ||
662 | case KVM_CREATE_SPAPR_TCE: { | ||
663 | struct kvm_create_spapr_tce create_tce; | ||
664 | struct kvm *kvm = filp->private_data; | ||
665 | |||
666 | r = -EFAULT; | ||
667 | if (copy_from_user(&create_tce, argp, sizeof(create_tce))) | ||
668 | goto out; | ||
669 | r = kvm_vm_ioctl_create_spapr_tce(kvm, &create_tce); | ||
670 | goto out; | ||
671 | } | ||
672 | #endif /* CONFIG_KVM_BOOK3S_64_HV */ | ||
673 | |||
656 | default: | 674 | default: |
657 | r = -ENOTTY; | 675 | r = -ENOTTY; |
658 | } | 676 | } |