Skip to content

Commit

Permalink
KVM: grow_halt_poll_ns() should never shrink vCPU halt_poll_ns
Browse files Browse the repository at this point in the history
grow_halt_poll_ns() have a strange behavior in case
(halt_poll_ns_grow == 0) && (vcpu->halt_poll_ns != 0).

In this case, vcpu->halt_pol_ns will be set to zero.
That results in shrinking instead of growing.

Fix issue by changing grow_halt_poll_ns() to not modify
vcpu->halt_poll_ns in case halt_poll_ns_grow is zero

Reviewed-by: Boris Ostrovsky <[email protected]>
Reviewed-by: Liran Alon <[email protected]>
Signed-off-by: Nir Weiner <[email protected]>
Suggested-by: Liran Alon <[email protected]>
Signed-off-by: Paolo Bonzini <[email protected]>
  • Loading branch information
Nir Weiner authored and bonzini committed Feb 20, 2019
1 parent 8ab3c47 commit 7fa08e7
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 2 deletions.
5 changes: 4 additions & 1 deletion arch/powerpc/kvm/book3s_hv.c
Original file line number Diff line number Diff line change
Expand Up @@ -3631,8 +3631,11 @@ static void kvmppc_wait_for_exec(struct kvmppc_vcore *vc,

static void grow_halt_poll_ns(struct kvmppc_vcore *vc)
{
if (!halt_poll_ns_grow)
return;

/* 10us base */
if (vc->halt_poll_ns == 0 && halt_poll_ns_grow)
if (vc->halt_poll_ns == 0)
vc->halt_poll_ns = 10000;
else
vc->halt_poll_ns *= halt_poll_ns_grow;
Expand Down
6 changes: 5 additions & 1 deletion virt/kvm/kvm_main.c
Original file line number Diff line number Diff line change
Expand Up @@ -2188,8 +2188,11 @@ static void grow_halt_poll_ns(struct kvm_vcpu *vcpu)

old = val = vcpu->halt_poll_ns;
grow = READ_ONCE(halt_poll_ns_grow);
if (!grow)
goto out;

/* 10us base */
if (val == 0 && grow)
if (val == 0)
val = 10000;
else
val *= grow;
Expand All @@ -2198,6 +2201,7 @@ static void grow_halt_poll_ns(struct kvm_vcpu *vcpu)
val = halt_poll_ns;

vcpu->halt_poll_ns = val;
out:
trace_kvm_halt_poll_ns_grow(vcpu->vcpu_id, val, old);
}

Expand Down

0 comments on commit 7fa08e7

Please sign in to comment.