2009-06-17 20:22:14 +08:00
|
|
|
#if !defined(_TRACE_KVM_MAIN_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
|
|
#define _TRACE_KVM_MAIN_H
|
|
|
|
|
|
|
|
#include <linux/tracepoint.h>
|
|
|
|
|
|
|
|
#undef TRACE_SYSTEM
|
|
|
|
#define TRACE_SYSTEM kvm
|
|
|
|
#define TRACE_INCLUDE_FILE kvm
|
|
|
|
|
|
|
|
#if defined(__KVM_HAVE_IOAPIC)
|
|
|
|
TRACE_EVENT(kvm_set_irq,
|
2009-07-01 17:09:41 +08:00
|
|
|
TP_PROTO(unsigned int gsi, int level, int irq_source_id),
|
|
|
|
TP_ARGS(gsi, level, irq_source_id),
|
2009-06-17 20:22:14 +08:00
|
|
|
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field( unsigned int, gsi )
|
2009-07-01 17:09:41 +08:00
|
|
|
__field( int, level )
|
|
|
|
__field( int, irq_source_id )
|
2009-06-17 20:22:14 +08:00
|
|
|
),
|
|
|
|
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->gsi = gsi;
|
2009-07-01 17:09:41 +08:00
|
|
|
__entry->level = level;
|
|
|
|
__entry->irq_source_id = irq_source_id;
|
2009-06-17 20:22:14 +08:00
|
|
|
),
|
|
|
|
|
2009-07-01 17:09:41 +08:00
|
|
|
TP_printk("gsi %u level %d source %d",
|
|
|
|
__entry->gsi, __entry->level, __entry->irq_source_id)
|
2009-06-17 20:22:14 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
#define kvm_irqchips \
|
|
|
|
{KVM_IRQCHIP_PIC_MASTER, "PIC master"}, \
|
|
|
|
{KVM_IRQCHIP_PIC_SLAVE, "PIC slave"}, \
|
|
|
|
{KVM_IRQCHIP_IOAPIC, "IOAPIC"}
|
|
|
|
|
|
|
|
TRACE_EVENT(kvm_ack_irq,
|
|
|
|
TP_PROTO(unsigned int irqchip, unsigned int pin),
|
|
|
|
TP_ARGS(irqchip, pin),
|
|
|
|
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field( unsigned int, irqchip )
|
|
|
|
__field( unsigned int, pin )
|
|
|
|
),
|
|
|
|
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->irqchip = irqchip;
|
|
|
|
__entry->pin = pin;
|
|
|
|
),
|
|
|
|
|
|
|
|
TP_printk("irqchip %s pin %u",
|
|
|
|
__print_symbolic(__entry->irqchip, kvm_irqchips),
|
|
|
|
__entry->pin)
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* defined(__KVM_HAVE_IOAPIC) */
|
2009-07-01 21:01:02 +08:00
|
|
|
|
|
|
|
#define KVM_TRACE_MMIO_READ_UNSATISFIED 0
|
|
|
|
#define KVM_TRACE_MMIO_READ 1
|
|
|
|
#define KVM_TRACE_MMIO_WRITE 2
|
|
|
|
|
|
|
|
#define kvm_trace_symbol_mmio \
|
|
|
|
{ KVM_TRACE_MMIO_READ_UNSATISFIED, "unsatisfied-read" }, \
|
|
|
|
{ KVM_TRACE_MMIO_READ, "read" }, \
|
|
|
|
{ KVM_TRACE_MMIO_WRITE, "write" }
|
|
|
|
|
|
|
|
TRACE_EVENT(kvm_mmio,
|
|
|
|
TP_PROTO(int type, int len, u64 gpa, u64 val),
|
|
|
|
TP_ARGS(type, len, gpa, val),
|
|
|
|
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field( u32, type )
|
|
|
|
__field( u32, len )
|
|
|
|
__field( u64, gpa )
|
|
|
|
__field( u64, val )
|
|
|
|
),
|
|
|
|
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->type = type;
|
|
|
|
__entry->len = len;
|
|
|
|
__entry->gpa = gpa;
|
|
|
|
__entry->val = val;
|
|
|
|
),
|
|
|
|
|
|
|
|
TP_printk("mmio %s len %u gpa 0x%llx val 0x%llx",
|
|
|
|
__print_symbolic(__entry->type, kvm_trace_symbol_mmio),
|
|
|
|
__entry->len, __entry->gpa, __entry->val)
|
|
|
|
);
|
|
|
|
|
2009-06-17 20:22:14 +08:00
|
|
|
#endif /* _TRACE_KVM_MAIN_H */
|
|
|
|
|
|
|
|
/* This part must be outside protection */
|
|
|
|
#include <trace/define_trace.h>
|