diff options
| -rw-r--r-- | arch/x86/kvm/x86.c | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index f71500af1f81..f7c850b36910 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c | |||
| @@ -1416,15 +1416,6 @@ static int kvm_guest_time_update(struct kvm_vcpu *v) | |||
| 1416 | kernel_ns = 0; | 1416 | kernel_ns = 0; |
| 1417 | host_tsc = 0; | 1417 | host_tsc = 0; |
| 1418 | 1418 | ||
| 1419 | /* Keep irq disabled to prevent changes to the clock */ | ||
| 1420 | local_irq_save(flags); | ||
| 1421 | this_tsc_khz = __get_cpu_var(cpu_tsc_khz); | ||
| 1422 | if (unlikely(this_tsc_khz == 0)) { | ||
| 1423 | local_irq_restore(flags); | ||
| 1424 | kvm_make_request(KVM_REQ_CLOCK_UPDATE, v); | ||
| 1425 | return 1; | ||
| 1426 | } | ||
| 1427 | |||
| 1428 | /* | 1419 | /* |
| 1429 | * If the host uses TSC clock, then passthrough TSC as stable | 1420 | * If the host uses TSC clock, then passthrough TSC as stable |
| 1430 | * to the guest. | 1421 | * to the guest. |
| @@ -1436,6 +1427,15 @@ static int kvm_guest_time_update(struct kvm_vcpu *v) | |||
| 1436 | kernel_ns = ka->master_kernel_ns; | 1427 | kernel_ns = ka->master_kernel_ns; |
| 1437 | } | 1428 | } |
| 1438 | spin_unlock(&ka->pvclock_gtod_sync_lock); | 1429 | spin_unlock(&ka->pvclock_gtod_sync_lock); |
| 1430 | |||
| 1431 | /* Keep irq disabled to prevent changes to the clock */ | ||
| 1432 | local_irq_save(flags); | ||
| 1433 | this_tsc_khz = __get_cpu_var(cpu_tsc_khz); | ||
| 1434 | if (unlikely(this_tsc_khz == 0)) { | ||
| 1435 | local_irq_restore(flags); | ||
| 1436 | kvm_make_request(KVM_REQ_CLOCK_UPDATE, v); | ||
| 1437 | return 1; | ||
| 1438 | } | ||
| 1439 | if (!use_master_clock) { | 1439 | if (!use_master_clock) { |
| 1440 | host_tsc = native_read_tsc(); | 1440 | host_tsc = native_read_tsc(); |
| 1441 | kernel_ns = get_kernel_ns(); | 1441 | kernel_ns = get_kernel_ns(); |
