diff options
author | Avi Kivity <avi@qumranet.com> | 2007-11-18 06:54:33 -0500 |
---|---|---|
committer | Avi Kivity <avi@qumranet.com> | 2008-01-30 10:53:04 -0500 |
commit | f096ed8588b53bf802b84862c6c4d00d25d1ed72 (patch) | |
tree | 5050a7f7c00b47897c2f4e28c338673bc2dc8fa7 /drivers | |
parent | e1beb1d37c3187aa12c6463bd15ba594e9986761 (diff) |
KVM: Add fpu_reload counter
Measure the number of times we switch the fpu state.
Signed-off-by: Avi Kivity <avi@qumranet.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/kvm/kvm.h | 1 | ||||
-rw-r--r-- | drivers/kvm/x86.c | 2 |
2 files changed, 3 insertions, 0 deletions
diff --git a/drivers/kvm/kvm.h b/drivers/kvm/kvm.h index 04efe8833e09..a85c5903591f 100644 --- a/drivers/kvm/kvm.h +++ b/drivers/kvm/kvm.h | |||
@@ -248,6 +248,7 @@ struct kvm_stat { | |||
248 | u32 irq_exits; | 248 | u32 irq_exits; |
249 | u32 host_state_reload; | 249 | u32 host_state_reload; |
250 | u32 efer_reload; | 250 | u32 efer_reload; |
251 | u32 fpu_reload; | ||
251 | }; | 252 | }; |
252 | 253 | ||
253 | struct kvm_io_device { | 254 | struct kvm_io_device { |
diff --git a/drivers/kvm/x86.c b/drivers/kvm/x86.c index 923dfd4e0afd..c1211e125b43 100644 --- a/drivers/kvm/x86.c +++ b/drivers/kvm/x86.c | |||
@@ -62,6 +62,7 @@ struct kvm_stats_debugfs_item debugfs_entries[] = { | |||
62 | { "irq_exits", STAT_OFFSET(irq_exits) }, | 62 | { "irq_exits", STAT_OFFSET(irq_exits) }, |
63 | { "host_state_reload", STAT_OFFSET(host_state_reload) }, | 63 | { "host_state_reload", STAT_OFFSET(host_state_reload) }, |
64 | { "efer_reload", STAT_OFFSET(efer_reload) }, | 64 | { "efer_reload", STAT_OFFSET(efer_reload) }, |
65 | { "fpu_reload", STAT_OFFSET(fpu_reload) }, | ||
65 | { NULL } | 66 | { NULL } |
66 | }; | 67 | }; |
67 | 68 | ||
@@ -2417,6 +2418,7 @@ void kvm_put_guest_fpu(struct kvm_vcpu *vcpu) | |||
2417 | vcpu->guest_fpu_loaded = 0; | 2418 | vcpu->guest_fpu_loaded = 0; |
2418 | fx_save(&vcpu->guest_fx_image); | 2419 | fx_save(&vcpu->guest_fx_image); |
2419 | fx_restore(&vcpu->host_fx_image); | 2420 | fx_restore(&vcpu->host_fx_image); |
2421 | ++vcpu->stat.fpu_reload; | ||
2420 | } | 2422 | } |
2421 | EXPORT_SYMBOL_GPL(kvm_put_guest_fpu); | 2423 | EXPORT_SYMBOL_GPL(kvm_put_guest_fpu); |
2422 | 2424 | ||