KVM: VMX: simplify rdtscp handling in vmx_cpuid_update()
if vmx_rdtscp_supported() is true SECONDARY_EXEC_RDTSCP must have already been set in current vmcs by vmx_secondary_exec_control() Signed-off-by: Xiao Guangrong <guangrong.xiao@linux.intel.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
e2821620c0
commit
f36201e5f4
@ -8677,16 +8677,15 @@ static void vmx_cpuid_update(struct kvm_vcpu *vcpu)
|
||||
vmx->rdtscp_enabled = false;
|
||||
if (vmx_rdtscp_supported()) {
|
||||
exec_control = vmcs_read32(SECONDARY_VM_EXEC_CONTROL);
|
||||
if (exec_control & SECONDARY_EXEC_RDTSCP) {
|
||||
best = kvm_find_cpuid_entry(vcpu, 0x80000001, 0);
|
||||
if (best && (best->edx & bit(X86_FEATURE_RDTSCP)))
|
||||
vmx->rdtscp_enabled = true;
|
||||
else {
|
||||
exec_control &= ~SECONDARY_EXEC_RDTSCP;
|
||||
vmcs_write32(SECONDARY_VM_EXEC_CONTROL,
|
||||
exec_control);
|
||||
}
|
||||
best = kvm_find_cpuid_entry(vcpu, 0x80000001, 0);
|
||||
if (best && (best->edx & bit(X86_FEATURE_RDTSCP)))
|
||||
vmx->rdtscp_enabled = true;
|
||||
else {
|
||||
exec_control &= ~SECONDARY_EXEC_RDTSCP;
|
||||
vmcs_write32(SECONDARY_VM_EXEC_CONTROL,
|
||||
exec_control);
|
||||
}
|
||||
|
||||
if (nested && !vmx->rdtscp_enabled)
|
||||
vmx->nested.nested_vmx_secondary_ctls_high &=
|
||||
~SECONDARY_EXEC_RDTSCP;
|
||||
|
Loading…
Reference in New Issue
Block a user