diff options
author | Michael Mueller <mimu@linux.vnet.ibm.com> | 2015-02-02 09:49:35 -0500 |
---|---|---|
committer | Christian Borntraeger <borntraeger@de.ibm.com> | 2015-02-09 06:44:13 -0500 |
commit | 658b6eda2042c0fe0e3f8acd7ffd11fc6f280119 (patch) | |
tree | 51849b96f3a5b295af5d943ad02659fab7caa714 /arch/s390/include | |
parent | 9d8d578605b4fca37bd2230bbacb3ad0ee48e7e4 (diff) |
KVM: s390: add cpu model support
This patch enables cpu model support in kvm/s390 via the vm attribute
interface.
During KVM initialization, the host properties cpuid, IBC value and the
facility list are stored in the architecture specific cpu model structure.
During vcpu setup, these properties are taken to initialize the related SIE
state. This mechanism allows to adjust the properties from user space and thus
to implement different selectable cpu models.
This patch uses the IBC functionality to block instructions that have not
been implemented at the requested CPU type and GA level compared to the
full host capability.
Userspace has to initialize the cpu model before vcpu creation. A cpu model
change of running vcpus is not possible.
Signed-off-by: Michael Mueller <mimu@linux.vnet.ibm.com>
Reviewed-by: Cornelia Huck <cornelia.huck@de.ibm.com>
Reviewed-by: David Hildenbrand <dahi@linux.vnet.ibm.com>
Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
Diffstat (limited to 'arch/s390/include')
-rw-r--r-- | arch/s390/include/asm/kvm_host.h | 4 | ||||
-rw-r--r-- | arch/s390/include/uapi/asm/kvm.h | 21 |
2 files changed, 24 insertions, 1 deletions
diff --git a/arch/s390/include/asm/kvm_host.h b/arch/s390/include/asm/kvm_host.h index 79dc3b0aa65f..d84559e31f32 100644 --- a/arch/s390/include/asm/kvm_host.h +++ b/arch/s390/include/asm/kvm_host.h | |||
@@ -89,7 +89,8 @@ struct kvm_s390_sie_block { | |||
89 | atomic_t cpuflags; /* 0x0000 */ | 89 | atomic_t cpuflags; /* 0x0000 */ |
90 | __u32 : 1; /* 0x0004 */ | 90 | __u32 : 1; /* 0x0004 */ |
91 | __u32 prefix : 18; | 91 | __u32 prefix : 18; |
92 | __u32 : 13; | 92 | __u32 : 1; |
93 | __u32 ibc : 12; | ||
93 | __u8 reserved08[4]; /* 0x0008 */ | 94 | __u8 reserved08[4]; /* 0x0008 */ |
94 | #define PROG_IN_SIE (1<<0) | 95 | #define PROG_IN_SIE (1<<0) |
95 | __u32 prog0c; /* 0x000c */ | 96 | __u32 prog0c; /* 0x000c */ |
@@ -524,6 +525,7 @@ struct s390_model_fac { | |||
524 | struct kvm_s390_cpu_model { | 525 | struct kvm_s390_cpu_model { |
525 | struct s390_model_fac *fac; | 526 | struct s390_model_fac *fac; |
526 | struct cpuid cpu_id; | 527 | struct cpuid cpu_id; |
528 | unsigned short ibc; | ||
527 | }; | 529 | }; |
528 | 530 | ||
529 | struct kvm_s390_crypto { | 531 | struct kvm_s390_crypto { |
diff --git a/arch/s390/include/uapi/asm/kvm.h b/arch/s390/include/uapi/asm/kvm.h index 546fc3a302e5..9c77e60b9a26 100644 --- a/arch/s390/include/uapi/asm/kvm.h +++ b/arch/s390/include/uapi/asm/kvm.h | |||
@@ -59,6 +59,7 @@ struct kvm_s390_io_adapter_req { | |||
59 | #define KVM_S390_VM_MEM_CTRL 0 | 59 | #define KVM_S390_VM_MEM_CTRL 0 |
60 | #define KVM_S390_VM_TOD 1 | 60 | #define KVM_S390_VM_TOD 1 |
61 | #define KVM_S390_VM_CRYPTO 2 | 61 | #define KVM_S390_VM_CRYPTO 2 |
62 | #define KVM_S390_VM_CPU_MODEL 3 | ||
62 | 63 | ||
63 | /* kvm attributes for mem_ctrl */ | 64 | /* kvm attributes for mem_ctrl */ |
64 | #define KVM_S390_VM_MEM_ENABLE_CMMA 0 | 65 | #define KVM_S390_VM_MEM_ENABLE_CMMA 0 |
@@ -69,6 +70,26 @@ struct kvm_s390_io_adapter_req { | |||
69 | #define KVM_S390_VM_TOD_LOW 0 | 70 | #define KVM_S390_VM_TOD_LOW 0 |
70 | #define KVM_S390_VM_TOD_HIGH 1 | 71 | #define KVM_S390_VM_TOD_HIGH 1 |
71 | 72 | ||
73 | /* kvm attributes for KVM_S390_VM_CPU_MODEL */ | ||
74 | /* processor related attributes are r/w */ | ||
75 | #define KVM_S390_VM_CPU_PROCESSOR 0 | ||
76 | struct kvm_s390_vm_cpu_processor { | ||
77 | __u64 cpuid; | ||
78 | __u16 ibc; | ||
79 | __u8 pad[6]; | ||
80 | __u64 fac_list[256]; | ||
81 | }; | ||
82 | |||
83 | /* machine related attributes are r/o */ | ||
84 | #define KVM_S390_VM_CPU_MACHINE 1 | ||
85 | struct kvm_s390_vm_cpu_machine { | ||
86 | __u64 cpuid; | ||
87 | __u32 ibc; | ||
88 | __u8 pad[4]; | ||
89 | __u64 fac_mask[256]; | ||
90 | __u64 fac_list[256]; | ||
91 | }; | ||
92 | |||
72 | /* kvm attributes for crypto */ | 93 | /* kvm attributes for crypto */ |
73 | #define KVM_S390_VM_CRYPTO_ENABLE_AES_KW 0 | 94 | #define KVM_S390_VM_CRYPTO_ENABLE_AES_KW 0 |
74 | #define KVM_S390_VM_CRYPTO_ENABLE_DEA_KW 1 | 95 | #define KVM_S390_VM_CRYPTO_ENABLE_DEA_KW 1 |