diff options
Diffstat (limited to 'arch')
-rw-r--r-- | arch/ia64/kvm/kvm-ia64.c | 5 | ||||
-rw-r--r-- | arch/powerpc/kvm/powerpc.c | 5 | ||||
-rw-r--r-- | arch/s390/kvm/Kconfig | 9 | ||||
-rw-r--r-- | arch/s390/kvm/kvm-s390.c | 24 | ||||
-rw-r--r-- | arch/s390/kvm/kvm-s390.h | 10 | ||||
-rw-r--r-- | arch/x86/kvm/x86.c | 5 |
6 files changed, 50 insertions, 8 deletions
diff --git a/arch/ia64/kvm/kvm-ia64.c b/arch/ia64/kvm/kvm-ia64.c index 405052002493..df6b14194051 100644 --- a/arch/ia64/kvm/kvm-ia64.c +++ b/arch/ia64/kvm/kvm-ia64.c | |||
@@ -809,10 +809,13 @@ static void kvm_build_io_pmt(struct kvm *kvm) | |||
809 | #define GUEST_PHYSICAL_RR4 0x2739 | 809 | #define GUEST_PHYSICAL_RR4 0x2739 |
810 | #define VMM_INIT_RR 0x1660 | 810 | #define VMM_INIT_RR 0x1660 |
811 | 811 | ||
812 | int kvm_arch_init_vm(struct kvm *kvm) | 812 | int kvm_arch_init_vm(struct kvm *kvm, unsigned long type) |
813 | { | 813 | { |
814 | BUG_ON(!kvm); | 814 | BUG_ON(!kvm); |
815 | 815 | ||
816 | if (type) | ||
817 | return -EINVAL; | ||
818 | |||
816 | kvm->arch.is_sn2 = ia64_platform_is("sn2"); | 819 | kvm->arch.is_sn2 = ia64_platform_is("sn2"); |
817 | 820 | ||
818 | kvm->arch.metaphysical_rr0 = GUEST_PHYSICAL_RR0; | 821 | kvm->arch.metaphysical_rr0 = GUEST_PHYSICAL_RR0; |
diff --git a/arch/powerpc/kvm/powerpc.c b/arch/powerpc/kvm/powerpc.c index 607fbdf24b84..83f244569874 100644 --- a/arch/powerpc/kvm/powerpc.c +++ b/arch/powerpc/kvm/powerpc.c | |||
@@ -171,8 +171,11 @@ void kvm_arch_check_processor_compat(void *rtn) | |||
171 | *(int *)rtn = kvmppc_core_check_processor_compat(); | 171 | *(int *)rtn = kvmppc_core_check_processor_compat(); |
172 | } | 172 | } |
173 | 173 | ||
174 | int kvm_arch_init_vm(struct kvm *kvm) | 174 | int kvm_arch_init_vm(struct kvm *kvm, unsigned long type) |
175 | { | 175 | { |
176 | if (type) | ||
177 | return -EINVAL; | ||
178 | |||
176 | return kvmppc_core_init_vm(kvm); | 179 | return kvmppc_core_init_vm(kvm); |
177 | } | 180 | } |
178 | 181 | ||
diff --git a/arch/s390/kvm/Kconfig b/arch/s390/kvm/Kconfig index a21634173a66..78eb9847008f 100644 --- a/arch/s390/kvm/Kconfig +++ b/arch/s390/kvm/Kconfig | |||
@@ -34,6 +34,15 @@ config KVM | |||
34 | 34 | ||
35 | If unsure, say N. | 35 | If unsure, say N. |
36 | 36 | ||
37 | config KVM_S390_UCONTROL | ||
38 | bool "Userspace controlled virtual machines" | ||
39 | depends on KVM | ||
40 | ---help--- | ||
41 | Allow CAP_SYS_ADMIN users to create KVM virtual machines that are | ||
42 | controlled by userspace. | ||
43 | |||
44 | If unsure, say N. | ||
45 | |||
37 | # OK, it's a little counter-intuitive to do this, but it puts it neatly under | 46 | # OK, it's a little counter-intuitive to do this, but it puts it neatly under |
38 | # the virtualization menu. | 47 | # the virtualization menu. |
39 | source drivers/vhost/Kconfig | 48 | source drivers/vhost/Kconfig |
diff --git a/arch/s390/kvm/kvm-s390.c b/arch/s390/kvm/kvm-s390.c index d1c445732451..f0937552175b 100644 --- a/arch/s390/kvm/kvm-s390.c +++ b/arch/s390/kvm/kvm-s390.c | |||
@@ -171,11 +171,22 @@ long kvm_arch_vm_ioctl(struct file *filp, | |||
171 | return r; | 171 | return r; |
172 | } | 172 | } |
173 | 173 | ||
174 | int kvm_arch_init_vm(struct kvm *kvm) | 174 | int kvm_arch_init_vm(struct kvm *kvm, unsigned long type) |
175 | { | 175 | { |
176 | int rc; | 176 | int rc; |
177 | char debug_name[16]; | 177 | char debug_name[16]; |
178 | 178 | ||
179 | rc = -EINVAL; | ||
180 | #ifdef CONFIG_KVM_S390_UCONTROL | ||
181 | if (type & ~KVM_VM_S390_UCONTROL) | ||
182 | goto out_err; | ||
183 | if ((type & KVM_VM_S390_UCONTROL) && (!capable(CAP_SYS_ADMIN))) | ||
184 | goto out_err; | ||
185 | #else | ||
186 | if (type) | ||
187 | goto out_err; | ||
188 | #endif | ||
189 | |||
179 | rc = s390_enable_sie(); | 190 | rc = s390_enable_sie(); |
180 | if (rc) | 191 | if (rc) |
181 | goto out_err; | 192 | goto out_err; |
@@ -198,10 +209,13 @@ int kvm_arch_init_vm(struct kvm *kvm) | |||
198 | debug_register_view(kvm->arch.dbf, &debug_sprintf_view); | 209 | debug_register_view(kvm->arch.dbf, &debug_sprintf_view); |
199 | VM_EVENT(kvm, 3, "%s", "vm created"); | 210 | VM_EVENT(kvm, 3, "%s", "vm created"); |
200 | 211 | ||
201 | kvm->arch.gmap = gmap_alloc(current->mm); | 212 | if (type & KVM_VM_S390_UCONTROL) { |
202 | if (!kvm->arch.gmap) | 213 | kvm->arch.gmap = NULL; |
203 | goto out_nogmap; | 214 | } else { |
204 | 215 | kvm->arch.gmap = gmap_alloc(current->mm); | |
216 | if (!kvm->arch.gmap) | ||
217 | goto out_nogmap; | ||
218 | } | ||
205 | return 0; | 219 | return 0; |
206 | out_nogmap: | 220 | out_nogmap: |
207 | debug_unregister(kvm->arch.dbf); | 221 | debug_unregister(kvm->arch.dbf); |
diff --git a/arch/s390/kvm/kvm-s390.h b/arch/s390/kvm/kvm-s390.h index 99b0b7597115..45b236a7c730 100644 --- a/arch/s390/kvm/kvm-s390.h +++ b/arch/s390/kvm/kvm-s390.h | |||
@@ -47,6 +47,16 @@ static inline int __cpu_is_stopped(struct kvm_vcpu *vcpu) | |||
47 | return atomic_read(&vcpu->arch.sie_block->cpuflags) & CPUSTAT_STOP_INT; | 47 | return atomic_read(&vcpu->arch.sie_block->cpuflags) & CPUSTAT_STOP_INT; |
48 | } | 48 | } |
49 | 49 | ||
50 | static inline int kvm_is_ucontrol(struct kvm *kvm) | ||
51 | { | ||
52 | #ifdef CONFIG_KVM_S390_UCONTROL | ||
53 | if (kvm->arch.gmap) | ||
54 | return 0; | ||
55 | return 1; | ||
56 | #else | ||
57 | return 0; | ||
58 | #endif | ||
59 | } | ||
50 | int kvm_s390_handle_wait(struct kvm_vcpu *vcpu); | 60 | int kvm_s390_handle_wait(struct kvm_vcpu *vcpu); |
51 | enum hrtimer_restart kvm_s390_idle_wakeup(struct hrtimer *timer); | 61 | enum hrtimer_restart kvm_s390_idle_wakeup(struct hrtimer *timer); |
52 | void kvm_s390_tasklet(unsigned long parm); | 62 | void kvm_s390_tasklet(unsigned long parm); |
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 9cbfc0698118..06925b4bcc27 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c | |||
@@ -6031,8 +6031,11 @@ void kvm_arch_vcpu_uninit(struct kvm_vcpu *vcpu) | |||
6031 | free_page((unsigned long)vcpu->arch.pio_data); | 6031 | free_page((unsigned long)vcpu->arch.pio_data); |
6032 | } | 6032 | } |
6033 | 6033 | ||
6034 | int kvm_arch_init_vm(struct kvm *kvm) | 6034 | int kvm_arch_init_vm(struct kvm *kvm, unsigned long type) |
6035 | { | 6035 | { |
6036 | if (type) | ||
6037 | return -EINVAL; | ||
6038 | |||
6036 | INIT_LIST_HEAD(&kvm->arch.active_mmu_pages); | 6039 | INIT_LIST_HEAD(&kvm->arch.active_mmu_pages); |
6037 | INIT_LIST_HEAD(&kvm->arch.assigned_dev_head); | 6040 | INIT_LIST_HEAD(&kvm->arch.assigned_dev_head); |
6038 | 6041 | ||