blob: ba3b3f575983f3fc9587a5c120f99dca8be9c449 [file]
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* Copyright (c) 2026, Microsoft Corporation.
*
* Tracepoint declarations for mshv driver.
*/
#undef TRACE_SYSTEM
#define TRACE_SYSTEM mshv
#if !defined(__MSHV_TRACE_H) || defined(TRACE_HEADER_MULTI_READ)
#define _MSHV_TRACE_H_
#include <linux/tracepoint.h>
#undef TRACE_INCLUDE_PATH
#define TRACE_INCLUDE_PATH ../../drivers/hv
#undef TRACE_INCLUDE_FILE
#define TRACE_INCLUDE_FILE mshv_trace
TRACE_EVENT(mshv_create_partition,
TP_PROTO(u64 partition_id, int vm_fd),
TP_ARGS(partition_id, vm_fd),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(int, vm_fd)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vm_fd = vm_fd;
),
TP_printk("partition_id=%llu vm_fd=%d",
__entry->partition_id,
__entry->vm_fd
)
);
TRACE_EVENT(mshv_hvcall_create_partition,
TP_PROTO(u64 flags, s64 partition_id),
TP_ARGS(flags, partition_id),
TP_STRUCT__entry(
__field(u64, flags)
__field(s64, partition_id)
),
TP_fast_assign(
__entry->flags = flags;
__entry->partition_id = partition_id;
),
TP_printk("flags=%#llx partition_id=%lld",
__entry->flags,
__entry->partition_id
)
);
TRACE_EVENT(mshv_hvcall_initialize_partition,
TP_PROTO(u64 partition_id, u64 status),
TP_ARGS(partition_id, status),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u64, status)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->status = status;
),
TP_printk("partition_id=%llu status=%#llx",
__entry->partition_id,
__entry->status
)
);
TRACE_EVENT(mshv_partition_release,
TP_PROTO(u64 partition_id),
TP_ARGS(partition_id),
TP_STRUCT__entry(
__field(u64, partition_id)
),
TP_fast_assign(
__entry->partition_id = partition_id;
),
TP_printk("partition_id=%llu",
__entry->partition_id
)
);
TRACE_EVENT(mshv_destroy_partition,
TP_PROTO(u64 partition_id),
TP_ARGS(partition_id),
TP_STRUCT__entry(
__field(u64, partition_id)
),
TP_fast_assign(
__entry->partition_id = partition_id;
),
TP_printk("partition_id=%llu",
__entry->partition_id
)
);
TRACE_EVENT(mshv_hvcall_finalize_partition,
TP_PROTO(u64 partition_id, u64 status),
TP_ARGS(partition_id, status),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u64, status)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->status = status;
),
TP_printk("partition_id=%llu status=%#llx ",
__entry->partition_id,
__entry->status
)
);
TRACE_EVENT(mshv_hvcall_withdraw_memory,
TP_PROTO(u64 partition_id, u64 withdrawn, u64 status),
TP_ARGS(partition_id, withdrawn, status),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u64, withdrawn)
__field(u64, status)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->withdrawn = withdrawn;
__entry->status = status;
),
TP_printk("partition_id=%llu withdrawn=%llu status=%#llx",
__entry->partition_id,
__entry->withdrawn,
__entry->status
)
);
TRACE_EVENT(mshv_hvcall_delete_partition,
TP_PROTO(u64 partition_id, u64 status),
TP_ARGS(partition_id, status),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u64, status)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->status = status;
),
TP_printk("partition_id=%llu status=%#llx",
__entry->partition_id,
__entry->status
)
);
TRACE_EVENT(mshv_create_vp,
TP_PROTO(u64 partition_id, u32 vp_index, long vp_fd),
TP_ARGS(partition_id, vp_index, vp_fd),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
__field(long, vp_fd)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
__entry->vp_fd = vp_fd;
),
TP_printk("partition_id=%llu vp_index=%u vp_fd=%ld",
__entry->partition_id,
__entry->vp_index,
__entry->vp_fd
)
);
TRACE_EVENT(mshv_hvcall_map_vp_state_page,
TP_PROTO(u64 partition_id, u32 vp_index, u32 page_type, u64 status),
TP_ARGS(partition_id, vp_index, page_type, status),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
__field(u32, page_type)
__field(u64, status)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
__entry->page_type = page_type;
__entry->status = status;
),
TP_printk("partition_id=%llu vp_index=%u page_type=%u status=%#llx",
__entry->partition_id,
__entry->vp_index,
__entry->page_type,
__entry->status
)
);
TRACE_EVENT(mshv_drain_vp_signals,
TP_PROTO(u64 partition_id, u32 vp_index),
TP_ARGS(partition_id, vp_index),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
),
TP_printk("partition_id=%llu vp_index=%u",
__entry->partition_id,
__entry->vp_index
)
);
TRACE_EVENT(mshv_disable_vp_dispatch,
TP_PROTO(u64 partition_id, u32 vp_index, int ret),
TP_ARGS(partition_id, vp_index, ret),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
__field(int, ret)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
__entry->ret = ret;
),
TP_printk("partition_id=%llu vp_index=%u ret=%d",
__entry->partition_id,
__entry->vp_index,
__entry->ret
)
);
TRACE_EVENT(mshv_vp_release,
TP_PROTO(u64 partition_id, u32 vp_index),
TP_ARGS(partition_id, vp_index),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
),
TP_printk("partition_id=%llu vp_index=%u",
__entry->partition_id,
__entry->vp_index
)
);
TRACE_EVENT(mshv_run_vp_entry,
TP_PROTO(u64 partition_id, u32 vp_index),
TP_ARGS(partition_id, vp_index),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
),
TP_printk("partition_id=%llu vp_index=%u",
__entry->partition_id,
__entry->vp_index
)
);
TRACE_EVENT(mshv_run_vp_exit,
TP_PROTO(u64 partition_id, u32 vp_index, u64 hv_message_type, long ret),
TP_ARGS(partition_id, vp_index, hv_message_type, ret),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
__field(u64, hv_message_type)
__field(long, ret)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
__entry->hv_message_type = hv_message_type;
__entry->ret = ret;
),
TP_printk("partition_id=%llu vp_index=%u hv_message_type=%#llx ret=%ld",
__entry->partition_id,
__entry->vp_index,
__entry->hv_message_type,
__entry->ret
)
);
TRACE_EVENT(mshv_vp_clear_explicit_suspend,
TP_PROTO(u64 partition_id, u32 vp_index, int ret),
TP_ARGS(partition_id, vp_index, ret),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
__field(int, ret)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
__entry->ret = ret;
),
TP_printk("partition_id=%llu vp_index=%u ret=%d",
__entry->partition_id,
__entry->vp_index,
__entry->ret
)
);
TRACE_EVENT(mshv_xfer_to_guest_mode_work,
TP_PROTO(u64 partition_id, u32 vp_index, unsigned long thread_info_flag, long ret),
TP_ARGS(partition_id, vp_index, thread_info_flag, ret),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
__field(unsigned long, thread_info_flag)
__field(long, ret)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
__entry->thread_info_flag = thread_info_flag;
__entry->ret = ret;
),
TP_printk("partition_id=%llu vp_index=%u thread_info_flag=%#lx ret=%ld",
__entry->partition_id,
__entry->vp_index,
__entry->thread_info_flag,
__entry->ret
)
);
TRACE_EVENT(mshv_hvcall_dispatch_vp,
TP_PROTO(u64 partition_id, u32 vp_index, u32 flags,
u32 dispatch_state, u32 dispatch_event, u64 irq_vectors, u64 status),
TP_ARGS(partition_id, vp_index, flags, dispatch_state, dispatch_event, irq_vectors,
status),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
__field(u32, flags)
__field(u32, dispatch_state)
__field(u32, dispatch_event)
__field(u64, irq_vectors)
__field(u64, status)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
__entry->flags = flags;
__entry->dispatch_state = dispatch_state;
__entry->dispatch_event = dispatch_event;
__entry->irq_vectors = irq_vectors;
__entry->status = status;
),
TP_printk("partition_id=%llu vp_index=%u flags=%#x dispatch_state=%#x dispatch_event=%#x irq_vectors=%#016llx status=%#llx",
__entry->partition_id,
__entry->vp_index,
__entry->flags,
__entry->dispatch_state,
__entry->dispatch_event,
__entry->irq_vectors,
__entry->status
)
);
TRACE_EVENT(mshv_update_routing_table,
TP_PROTO(u64 partition_id, void *old, void *new, u32 numents),
TP_ARGS(partition_id, old, new, numents),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(struct mshv_girq_routing_table *, old)
__field(struct mshv_girq_routing_table *, new)
__field(u32, numents)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->old = old;
__entry->new = new;
__entry->numents = numents;
),
TP_printk("partition_id=%llu old=%p new=%p numents=%u",
__entry->partition_id,
__entry->old,
__entry->new,
__entry->numents
)
);
TRACE_EVENT(mshv_map_user_memory,
TP_PROTO(u64 partition_id, u64 start_uaddr, u64 start_gfn, u64 nr_pages, u32 map_flags,
long ret),
TP_ARGS(partition_id, start_uaddr, start_gfn, nr_pages, map_flags, ret),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u64, start_uaddr)
__field(u64, start_gfn)
__field(u64, nr_pages)
__field(u32, map_flags)
__field(long, ret)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->start_uaddr = start_uaddr;
__entry->start_gfn = start_gfn;
__entry->nr_pages = nr_pages;
__entry->map_flags = map_flags;
__entry->ret = ret;
),
TP_printk("partition_id=%llu start_uaddr=%#llx start_gfn=%#llx nr_pages=%llu map_flags=%#x ret=%ld",
__entry->partition_id,
__entry->start_uaddr,
__entry->start_gfn,
__entry->nr_pages,
__entry->map_flags,
__entry->ret
)
);
TRACE_EVENT(mshv_assign_ioeventfd,
TP_PROTO(u64 partition_id, u64 addr, u64 length, u64 datamatch, bool wildcard,
void *eventfd, int ret),
TP_ARGS(partition_id, addr, length, datamatch, wildcard, eventfd, ret),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u64, addr)
__field(u64, length)
__field(u64, datamatch)
__field(bool, wildcard)
__field(struct eventfd_ctx *, eventfd)
__field(int, ret)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->addr = addr;
__entry->length = length;
__entry->datamatch = datamatch;
__entry->wildcard = wildcard;
__entry->eventfd = eventfd;
__entry->ret = ret;
),
TP_printk("partition_id=%llu addr=%#016llx length=%#llx datamatch=%#llx wildcard=%d eventfd=%p ret=%d",
__entry->partition_id,
__entry->addr,
__entry->length,
__entry->datamatch,
__entry->wildcard,
__entry->eventfd,
__entry->ret
)
);
TRACE_EVENT(mshv_deassign_ioeventfd,
TP_PROTO(u64 partition_id, u64 addr, u64 length, u64 datamatch, bool wildcard,
void *eventfd),
TP_ARGS(partition_id, addr, length, datamatch, wildcard, eventfd),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u64, addr)
__field(u64, length)
__field(u64, datamatch)
__field(bool, wildcard)
__field(struct eventfd_ctx *, eventfd)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->addr = addr;
__entry->length = length;
__entry->datamatch = datamatch;
__entry->wildcard = wildcard;
__entry->eventfd = eventfd;
),
TP_printk("partition_id=%llu addr=%#016llx length=%#llx datamatch=%#llx wildcard=%d eventfd=%p",
__entry->partition_id,
__entry->addr,
__entry->length,
__entry->datamatch,
__entry->wildcard,
__entry->eventfd
)
);
TRACE_EVENT(mshv_vp_wait_for_hv_kick,
TP_PROTO(u64 partition_id, u32 vp_index, bool kicked_by_hv, bool blocked,
bool irq_pending),
TP_ARGS(partition_id, vp_index, kicked_by_hv, blocked, irq_pending),
TP_STRUCT__entry(
__field(u64, partition_id)
__field(u32, vp_index)
__field(bool, kicked_by_hv)
__field(bool, blocked)
__field(bool, irq_pending)
),
TP_fast_assign(
__entry->partition_id = partition_id;
__entry->vp_index = vp_index;
__entry->kicked_by_hv = kicked_by_hv;
__entry->blocked = blocked;
__entry->irq_pending = irq_pending;
),
TP_printk("partition_id=%llu vp_index=%u kicked_by_hv=%d blocked=%d irq_pending=%d",
__entry->partition_id,
__entry->vp_index,
__entry->kicked_by_hv,
__entry->blocked,
__entry->irq_pending
)
);
#endif /* _MSHV_TRACE_H_ */
/* This part must be outside protection */
#include <trace/define_trace.h>