diff options
author | Alexander Graf <agraf@suse.de> | 2010-03-24 16:48:29 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2010-05-17 05:17:09 -0400 |
commit | 71fbfd5f38f73515f1516a68fbe04dba198b70f0 (patch) | |
tree | 653626126cef565890652f83f4eba7f376642709 | |
parent | ca7f4203b9b66e12d0d9968ff7dfe781f3a9695a (diff) |
KVM: Add support for enabling capabilities per-vcpu
Some times we don't want all capabilities to be available to all
our vcpus. One example for that is the OSI interface, implemented
in the next patch.
In order to have a generic mechanism in how to enable capabilities
individually, this patch introduces a new ioctl that can be used
for this purpose. That way features we don't want in all guests or
userspace configurations can just not be enabled and we're good.
Signed-off-by: Alexander Graf <agraf@suse.de>
Signed-off-by: Avi Kivity <avi@redhat.com>
-rw-r--r-- | Documentation/kvm/api.txt | 35 | ||||
-rw-r--r-- | arch/powerpc/kvm/powerpc.c | 27 | ||||
-rw-r--r-- | include/linux/kvm.h | 11 |
3 files changed, 73 insertions, 0 deletions
diff --git a/Documentation/kvm/api.txt b/Documentation/kvm/api.txt index 2cc0120ccdb5..f9724dc8d079 100644 --- a/Documentation/kvm/api.txt +++ b/Documentation/kvm/api.txt | |||
@@ -813,6 +813,41 @@ This ioctl is required on Intel-based hosts. This is needed on Intel hardware | |||
813 | because of a quirk in the virtualization implementation (see the internals | 813 | because of a quirk in the virtualization implementation (see the internals |
814 | documentation when it pops into existence). | 814 | documentation when it pops into existence). |
815 | 815 | ||
816 | 4.36 KVM_ENABLE_CAP | ||
817 | |||
818 | Capability: KVM_CAP_ENABLE_CAP | ||
819 | Architectures: ppc | ||
820 | Type: vcpu ioctl | ||
821 | Parameters: struct kvm_enable_cap (in) | ||
822 | Returns: 0 on success; -1 on error | ||
823 | |||
824 | +Not all extensions are enabled by default. Using this ioctl the application | ||
825 | can enable an extension, making it available to the guest. | ||
826 | |||
827 | On systems that do not support this ioctl, it always fails. On systems that | ||
828 | do support it, it only works for extensions that are supported for enablement. | ||
829 | |||
830 | To check if a capability can be enabled, the KVM_CHECK_EXTENSION ioctl should | ||
831 | be used. | ||
832 | |||
833 | struct kvm_enable_cap { | ||
834 | /* in */ | ||
835 | __u32 cap; | ||
836 | |||
837 | The capability that is supposed to get enabled. | ||
838 | |||
839 | __u32 flags; | ||
840 | |||
841 | A bitfield indicating future enhancements. Has to be 0 for now. | ||
842 | |||
843 | __u64 args[4]; | ||
844 | |||
845 | Arguments for enabling a feature. If a feature needs initial values to | ||
846 | function properly, this is the place to put them. | ||
847 | |||
848 | __u8 pad[64]; | ||
849 | }; | ||
850 | |||
816 | 5. The kvm_run structure | 851 | 5. The kvm_run structure |
817 | 852 | ||
818 | Application code obtains a pointer to the kvm_run structure by | 853 | Application code obtains a pointer to the kvm_run structure by |
diff --git a/arch/powerpc/kvm/powerpc.c b/arch/powerpc/kvm/powerpc.c index 0bb6a7e826d1..646bfd256e5d 100644 --- a/arch/powerpc/kvm/powerpc.c +++ b/arch/powerpc/kvm/powerpc.c | |||
@@ -150,6 +150,7 @@ int kvm_dev_ioctl_check_extension(long ext) | |||
150 | case KVM_CAP_PPC_SEGSTATE: | 150 | case KVM_CAP_PPC_SEGSTATE: |
151 | case KVM_CAP_PPC_PAIRED_SINGLES: | 151 | case KVM_CAP_PPC_PAIRED_SINGLES: |
152 | case KVM_CAP_PPC_UNSET_IRQ: | 152 | case KVM_CAP_PPC_UNSET_IRQ: |
153 | case KVM_CAP_ENABLE_CAP: | ||
153 | r = 1; | 154 | r = 1; |
154 | break; | 155 | break; |
155 | case KVM_CAP_COALESCED_MMIO: | 156 | case KVM_CAP_COALESCED_MMIO: |
@@ -465,6 +466,23 @@ int kvm_vcpu_ioctl_interrupt(struct kvm_vcpu *vcpu, struct kvm_interrupt *irq) | |||
465 | return 0; | 466 | return 0; |
466 | } | 467 | } |
467 | 468 | ||
469 | static int kvm_vcpu_ioctl_enable_cap(struct kvm_vcpu *vcpu, | ||
470 | struct kvm_enable_cap *cap) | ||
471 | { | ||
472 | int r; | ||
473 | |||
474 | if (cap->flags) | ||
475 | return -EINVAL; | ||
476 | |||
477 | switch (cap->cap) { | ||
478 | default: | ||
479 | r = -EINVAL; | ||
480 | break; | ||
481 | } | ||
482 | |||
483 | return r; | ||
484 | } | ||
485 | |||
468 | int kvm_arch_vcpu_ioctl_get_mpstate(struct kvm_vcpu *vcpu, | 486 | int kvm_arch_vcpu_ioctl_get_mpstate(struct kvm_vcpu *vcpu, |
469 | struct kvm_mp_state *mp_state) | 487 | struct kvm_mp_state *mp_state) |
470 | { | 488 | { |
@@ -493,6 +511,15 @@ long kvm_arch_vcpu_ioctl(struct file *filp, | |||
493 | r = kvm_vcpu_ioctl_interrupt(vcpu, &irq); | 511 | r = kvm_vcpu_ioctl_interrupt(vcpu, &irq); |
494 | break; | 512 | break; |
495 | } | 513 | } |
514 | case KVM_ENABLE_CAP: | ||
515 | { | ||
516 | struct kvm_enable_cap cap; | ||
517 | r = -EFAULT; | ||
518 | if (copy_from_user(&cap, argp, sizeof(cap))) | ||
519 | goto out; | ||
520 | r = kvm_vcpu_ioctl_enable_cap(vcpu, &cap); | ||
521 | break; | ||
522 | } | ||
496 | default: | 523 | default: |
497 | r = -EINVAL; | 524 | r = -EINVAL; |
498 | } | 525 | } |
diff --git a/include/linux/kvm.h b/include/linux/kvm.h index c36d093e9806..ecb68e433558 100644 --- a/include/linux/kvm.h +++ b/include/linux/kvm.h | |||
@@ -400,6 +400,15 @@ struct kvm_ioeventfd { | |||
400 | __u8 pad[36]; | 400 | __u8 pad[36]; |
401 | }; | 401 | }; |
402 | 402 | ||
403 | /* for KVM_ENABLE_CAP */ | ||
404 | struct kvm_enable_cap { | ||
405 | /* in */ | ||
406 | __u32 cap; | ||
407 | __u32 flags; | ||
408 | __u64 args[4]; | ||
409 | __u8 pad[64]; | ||
410 | }; | ||
411 | |||
403 | #define KVMIO 0xAE | 412 | #define KVMIO 0xAE |
404 | 413 | ||
405 | /* | 414 | /* |
@@ -508,6 +517,7 @@ struct kvm_ioeventfd { | |||
508 | #endif | 517 | #endif |
509 | #define KVM_CAP_X86_ROBUST_SINGLESTEP 51 | 518 | #define KVM_CAP_X86_ROBUST_SINGLESTEP 51 |
510 | #define KVM_CAP_PPC_UNSET_IRQ 53 | 519 | #define KVM_CAP_PPC_UNSET_IRQ 53 |
520 | #define KVM_CAP_ENABLE_CAP 54 | ||
511 | 521 | ||
512 | #ifdef KVM_CAP_IRQ_ROUTING | 522 | #ifdef KVM_CAP_IRQ_ROUTING |
513 | 523 | ||
@@ -697,6 +707,7 @@ struct kvm_clock_data { | |||
697 | /* Available with KVM_CAP_DEBUGREGS */ | 707 | /* Available with KVM_CAP_DEBUGREGS */ |
698 | #define KVM_GET_DEBUGREGS _IOR(KVMIO, 0xa1, struct kvm_debugregs) | 708 | #define KVM_GET_DEBUGREGS _IOR(KVMIO, 0xa1, struct kvm_debugregs) |
699 | #define KVM_SET_DEBUGREGS _IOW(KVMIO, 0xa2, struct kvm_debugregs) | 709 | #define KVM_SET_DEBUGREGS _IOW(KVMIO, 0xa2, struct kvm_debugregs) |
710 | #define KVM_ENABLE_CAP _IOW(KVMIO, 0xa3, struct kvm_enable_cap) | ||
700 | 711 | ||
701 | #define KVM_DEV_ASSIGN_ENABLE_IOMMU (1 << 0) | 712 | #define KVM_DEV_ASSIGN_ENABLE_IOMMU (1 << 0) |
702 | 713 | ||