trace.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #if !defined(_TRACE_KVM_H) || defined(TRACE_HEADER_MULTI_READ)
  3. #define _TRACE_KVM_H
  4. #include <linux/tracepoint.h>
  5. #undef TRACE_SYSTEM
  6. #define TRACE_SYSTEM kvm
  7. #define TRACE_INCLUDE_PATH .
  8. #define TRACE_INCLUDE_FILE trace
  9. /*
  10. * Tracepoint for guest mode entry.
  11. */
  12. TRACE_EVENT(kvm_ppc_instr,
  13. TP_PROTO(unsigned int inst, unsigned long _pc, unsigned int emulate),
  14. TP_ARGS(inst, _pc, emulate),
  15. TP_STRUCT__entry(
  16. __field( unsigned int, inst )
  17. __field( unsigned long, pc )
  18. __field( unsigned int, emulate )
  19. ),
  20. TP_fast_assign(
  21. __entry->inst = inst;
  22. __entry->pc = _pc;
  23. __entry->emulate = emulate;
  24. ),
  25. TP_printk("inst %u pc 0x%lx emulate %u\n",
  26. __entry->inst, __entry->pc, __entry->emulate)
  27. );
  28. TRACE_EVENT(kvm_stlb_inval,
  29. TP_PROTO(unsigned int stlb_index),
  30. TP_ARGS(stlb_index),
  31. TP_STRUCT__entry(
  32. __field( unsigned int, stlb_index )
  33. ),
  34. TP_fast_assign(
  35. __entry->stlb_index = stlb_index;
  36. ),
  37. TP_printk("stlb_index %u", __entry->stlb_index)
  38. );
  39. TRACE_EVENT(kvm_stlb_write,
  40. TP_PROTO(unsigned int victim, unsigned int tid, unsigned int word0,
  41. unsigned int word1, unsigned int word2),
  42. TP_ARGS(victim, tid, word0, word1, word2),
  43. TP_STRUCT__entry(
  44. __field( unsigned int, victim )
  45. __field( unsigned int, tid )
  46. __field( unsigned int, word0 )
  47. __field( unsigned int, word1 )
  48. __field( unsigned int, word2 )
  49. ),
  50. TP_fast_assign(
  51. __entry->victim = victim;
  52. __entry->tid = tid;
  53. __entry->word0 = word0;
  54. __entry->word1 = word1;
  55. __entry->word2 = word2;
  56. ),
  57. TP_printk("victim %u tid %u w0 %u w1 %u w2 %u",
  58. __entry->victim, __entry->tid, __entry->word0,
  59. __entry->word1, __entry->word2)
  60. );
  61. TRACE_EVENT(kvm_gtlb_write,
  62. TP_PROTO(unsigned int gtlb_index, unsigned int tid, unsigned int word0,
  63. unsigned int word1, unsigned int word2),
  64. TP_ARGS(gtlb_index, tid, word0, word1, word2),
  65. TP_STRUCT__entry(
  66. __field( unsigned int, gtlb_index )
  67. __field( unsigned int, tid )
  68. __field( unsigned int, word0 )
  69. __field( unsigned int, word1 )
  70. __field( unsigned int, word2 )
  71. ),
  72. TP_fast_assign(
  73. __entry->gtlb_index = gtlb_index;
  74. __entry->tid = tid;
  75. __entry->word0 = word0;
  76. __entry->word1 = word1;
  77. __entry->word2 = word2;
  78. ),
  79. TP_printk("gtlb_index %u tid %u w0 %u w1 %u w2 %u",
  80. __entry->gtlb_index, __entry->tid, __entry->word0,
  81. __entry->word1, __entry->word2)
  82. );
  83. TRACE_EVENT(kvm_check_requests,
  84. TP_PROTO(struct kvm_vcpu *vcpu),
  85. TP_ARGS(vcpu),
  86. TP_STRUCT__entry(
  87. __field( __u32, cpu_nr )
  88. __field( __u32, requests )
  89. ),
  90. TP_fast_assign(
  91. __entry->cpu_nr = vcpu->vcpu_id;
  92. __entry->requests = vcpu->requests;
  93. ),
  94. TP_printk("vcpu=%x requests=%x",
  95. __entry->cpu_nr, __entry->requests)
  96. );
  97. #endif /* _TRACE_KVM_H */
  98. /* This part must be outside protection */
  99. #include <trace/define_trace.h>