diff options
| author | Paolo Bonzini <pbonzini@redhat.com> | 2015-09-15 12:27:57 -0400 |
|---|---|---|
| committer | Paolo Bonzini <pbonzini@redhat.com> | 2015-09-16 06:17:00 -0400 |
| commit | 62bea5bff486644ecf363fe8a1a2f6f32c614a49 (patch) | |
| tree | 774180da187dabef4995896aec803248b075a36d /arch/powerpc | |
| parent | 8f4216c7d28976f7ec1b2bcbfa0a9f787133c45e (diff) | |
KVM: add halt_attempted_poll to VCPU stats
This new statistic can help diagnosing VCPUs that, for any reason,
trigger bad behavior of halt_poll_ns autotuning.
For example, say halt_poll_ns = 480000, and wakeups are spaced exactly
like 479us, 481us, 479us, 481us. Then KVM always fails polling and wastes
10+20+40+80+160+320+480 = 1110 microseconds out of every
479+481+479+481+479+481+479 = 3359 microseconds. The VCPU then
is consuming about 30% more CPU than it would use without
polling. This would show as an abnormally high number of
attempted polling compared to the successful polls.
Acked-by: Christian Borntraeger <borntraeger@de.ibm.com<
Reviewed-by: David Matlack <dmatlack@google.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'arch/powerpc')
| -rw-r--r-- | arch/powerpc/include/asm/kvm_host.h | 1 | ||||
| -rw-r--r-- | arch/powerpc/kvm/book3s.c | 1 | ||||
| -rw-r--r-- | arch/powerpc/kvm/booke.c | 1 |
3 files changed, 3 insertions, 0 deletions
diff --git a/arch/powerpc/include/asm/kvm_host.h b/arch/powerpc/include/asm/kvm_host.h index 98eebbf66340..195886a583ba 100644 --- a/arch/powerpc/include/asm/kvm_host.h +++ b/arch/powerpc/include/asm/kvm_host.h | |||
| @@ -108,6 +108,7 @@ struct kvm_vcpu_stat { | |||
| 108 | u32 dec_exits; | 108 | u32 dec_exits; |
| 109 | u32 ext_intr_exits; | 109 | u32 ext_intr_exits; |
| 110 | u32 halt_successful_poll; | 110 | u32 halt_successful_poll; |
| 111 | u32 halt_attempted_poll; | ||
| 111 | u32 halt_wakeup; | 112 | u32 halt_wakeup; |
| 112 | u32 dbell_exits; | 113 | u32 dbell_exits; |
| 113 | u32 gdbell_exits; | 114 | u32 gdbell_exits; |
diff --git a/arch/powerpc/kvm/book3s.c b/arch/powerpc/kvm/book3s.c index d75bf325f54a..cf009167d208 100644 --- a/arch/powerpc/kvm/book3s.c +++ b/arch/powerpc/kvm/book3s.c | |||
| @@ -53,6 +53,7 @@ struct kvm_stats_debugfs_item debugfs_entries[] = { | |||
| 53 | { "ext_intr", VCPU_STAT(ext_intr_exits) }, | 53 | { "ext_intr", VCPU_STAT(ext_intr_exits) }, |
| 54 | { "queue_intr", VCPU_STAT(queue_intr) }, | 54 | { "queue_intr", VCPU_STAT(queue_intr) }, |
| 55 | { "halt_successful_poll", VCPU_STAT(halt_successful_poll), }, | 55 | { "halt_successful_poll", VCPU_STAT(halt_successful_poll), }, |
| 56 | { "halt_attempted_poll", VCPU_STAT(halt_attempted_poll), }, | ||
| 56 | { "halt_wakeup", VCPU_STAT(halt_wakeup) }, | 57 | { "halt_wakeup", VCPU_STAT(halt_wakeup) }, |
| 57 | { "pf_storage", VCPU_STAT(pf_storage) }, | 58 | { "pf_storage", VCPU_STAT(pf_storage) }, |
| 58 | { "sp_storage", VCPU_STAT(sp_storage) }, | 59 | { "sp_storage", VCPU_STAT(sp_storage) }, |
diff --git a/arch/powerpc/kvm/booke.c b/arch/powerpc/kvm/booke.c index ae458f0fd061..fd5875179e5c 100644 --- a/arch/powerpc/kvm/booke.c +++ b/arch/powerpc/kvm/booke.c | |||
| @@ -63,6 +63,7 @@ struct kvm_stats_debugfs_item debugfs_entries[] = { | |||
| 63 | { "dec", VCPU_STAT(dec_exits) }, | 63 | { "dec", VCPU_STAT(dec_exits) }, |
| 64 | { "ext_intr", VCPU_STAT(ext_intr_exits) }, | 64 | { "ext_intr", VCPU_STAT(ext_intr_exits) }, |
| 65 | { "halt_successful_poll", VCPU_STAT(halt_successful_poll) }, | 65 | { "halt_successful_poll", VCPU_STAT(halt_successful_poll) }, |
| 66 | { "halt_attempted_poll", VCPU_STAT(halt_attempted_poll) }, | ||
| 66 | { "halt_wakeup", VCPU_STAT(halt_wakeup) }, | 67 | { "halt_wakeup", VCPU_STAT(halt_wakeup) }, |
| 67 | { "doorbell", VCPU_STAT(dbell_exits) }, | 68 | { "doorbell", VCPU_STAT(dbell_exits) }, |
| 68 | { "guest doorbell", VCPU_STAT(gdbell_exits) }, | 69 | { "guest doorbell", VCPU_STAT(gdbell_exits) }, |
