aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm
diff options
context:
space:
mode:
authorXiao Guangrong <xiaoguangrong@linux.vnet.ibm.com>2013-05-30 20:36:25 -0400
committerGleb Natapov <gleb@redhat.com>2013-06-05 05:32:57 -0400
commit35006126f024f68727c67001b9cb703c38f69268 (patch)
treef98b3c3de0b0f3407eccd5db3b52efdfbf742f0e /arch/x86/kvm
parent2248b023219251908aedda0621251cffc548f258 (diff)
KVM: MMU: add tracepoint for kvm_mmu_invalidate_all_pages
It is good for debug and development Signed-off-by: Xiao Guangrong <xiaoguangrong@linux.vnet.ibm.com> Reviewed-by: Marcelo Tosatti <mtosatti@redhat.com> Signed-off-by: Gleb Natapov <gleb@redhat.com>
Diffstat (limited to 'arch/x86/kvm')
-rw-r--r--arch/x86/kvm/mmu.c1
-rw-r--r--arch/x86/kvm/mmutrace.h20
2 files changed, 21 insertions, 0 deletions
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c
index c8063b9b30ee..3fd060af5394 100644
--- a/arch/x86/kvm/mmu.c
+++ b/arch/x86/kvm/mmu.c
@@ -4264,6 +4264,7 @@ restart:
4264void kvm_mmu_invalidate_zap_all_pages(struct kvm *kvm) 4264void kvm_mmu_invalidate_zap_all_pages(struct kvm *kvm)
4265{ 4265{
4266 spin_lock(&kvm->mmu_lock); 4266 spin_lock(&kvm->mmu_lock);
4267 trace_kvm_mmu_invalidate_zap_all_pages(kvm);
4267 kvm->arch.mmu_valid_gen++; 4268 kvm->arch.mmu_valid_gen++;
4268 4269
4269 kvm_zap_obsolete_pages(kvm); 4270 kvm_zap_obsolete_pages(kvm);
diff --git a/arch/x86/kvm/mmutrace.h b/arch/x86/kvm/mmutrace.h
index 697f46664990..eb444dd374af 100644
--- a/arch/x86/kvm/mmutrace.h
+++ b/arch/x86/kvm/mmutrace.h
@@ -276,6 +276,26 @@ TRACE_EVENT(
276 __spte_satisfied(old_spte), __spte_satisfied(new_spte) 276 __spte_satisfied(old_spte), __spte_satisfied(new_spte)
277 ) 277 )
278); 278);
279
280TRACE_EVENT(
281 kvm_mmu_invalidate_zap_all_pages,
282 TP_PROTO(struct kvm *kvm),
283 TP_ARGS(kvm),
284
285 TP_STRUCT__entry(
286 __field(unsigned long, mmu_valid_gen)
287 __field(unsigned int, mmu_used_pages)
288 ),
289
290 TP_fast_assign(
291 __entry->mmu_valid_gen = kvm->arch.mmu_valid_gen;
292 __entry->mmu_used_pages = kvm->arch.n_used_mmu_pages;
293 ),
294
295 TP_printk("kvm-mmu-valid-gen %lx used_pages %x",
296 __entry->mmu_valid_gen, __entry->mmu_used_pages
297 )
298);
279#endif /* _TRACE_KVMMMU_H */ 299#endif /* _TRACE_KVMMMU_H */
280 300
281#undef TRACE_INCLUDE_PATH 301#undef TRACE_INCLUDE_PATH