|
@@ -366,6 +366,7 @@ int kvm_arch_init(MachineState *ms, KVMState *s)
|
|
|
kvm_vm_enable_cap(s, KVM_CAP_S390_USER_SIGP, 0);
|
|
|
kvm_vm_enable_cap(s, KVM_CAP_S390_VECTOR_REGISTERS, 0);
|
|
|
kvm_vm_enable_cap(s, KVM_CAP_S390_USER_STSI, 0);
|
|
|
+ kvm_vm_enable_cap(s, KVM_CAP_S390_CPU_TOPOLOGY, 0);
|
|
|
if (ri_allowed()) {
|
|
|
if (kvm_vm_enable_cap(s, KVM_CAP_S390_RI, 0) == 0) {
|
|
|
cap_ri = 1;
|
|
@@ -2509,6 +2510,14 @@ void kvm_s390_get_host_cpu_model(S390CPUModel *model, Error **errp)
|
|
|
set_bit(S390_FEAT_UNPACK, model->features);
|
|
|
}
|
|
|
|
|
|
+ /*
|
|
|
+ * If we have kernel support for CPU Topology indicate the
|
|
|
+ * configuration-topology facility.
|
|
|
+ */
|
|
|
+ if (kvm_check_extension(kvm_state, KVM_CAP_S390_CPU_TOPOLOGY)) {
|
|
|
+ set_bit(S390_FEAT_CONFIGURATION_TOPOLOGY, model->features);
|
|
|
+ }
|
|
|
+
|
|
|
/* We emulate a zPCI bus and AEN, therefore we don't need HW support */
|
|
|
set_bit(S390_FEAT_ZPCI, model->features);
|
|
|
set_bit(S390_FEAT_ADAPTER_EVENT_NOTIFICATION, model->features);
|