mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-30 15:44:13 +08:00
91195a90f1
Like other architectures, RISCV KVM also needs to add these event tracepoints to count the number of times kvm guest entry/exit. Signed-off-by: Shenlin Liang <liangshenlin@eswincomputing.com> Reviewed-by: Anup Patel <anup@brainfault.org> Tested-by: Atish Patra <atishp@rivosinc.com> Link: https://lore.kernel.org/r/20240422080833.8745-2-liangshenlin@eswincomputing.com Signed-off-by: Anup Patel <anup@brainfault.org>
68 lines
1.4 KiB
C
68 lines
1.4 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* Tracepoints for RISC-V KVM
|
|
*
|
|
* Copyright 2024 Beijing ESWIN Computing Technology Co., Ltd.
|
|
*
|
|
*/
|
|
#if !defined(_TRACE_KVM_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
#define _TRACE_KVM_H
|
|
|
|
#include <linux/tracepoint.h>
|
|
|
|
#undef TRACE_SYSTEM
|
|
#define TRACE_SYSTEM kvm
|
|
|
|
TRACE_EVENT(kvm_entry,
|
|
TP_PROTO(struct kvm_vcpu *vcpu),
|
|
TP_ARGS(vcpu),
|
|
|
|
TP_STRUCT__entry(
|
|
__field(unsigned long, pc)
|
|
),
|
|
|
|
TP_fast_assign(
|
|
__entry->pc = vcpu->arch.guest_context.sepc;
|
|
),
|
|
|
|
TP_printk("PC: 0x016%lx", __entry->pc)
|
|
);
|
|
|
|
TRACE_EVENT(kvm_exit,
|
|
TP_PROTO(struct kvm_cpu_trap *trap),
|
|
TP_ARGS(trap),
|
|
|
|
TP_STRUCT__entry(
|
|
__field(unsigned long, sepc)
|
|
__field(unsigned long, scause)
|
|
__field(unsigned long, stval)
|
|
__field(unsigned long, htval)
|
|
__field(unsigned long, htinst)
|
|
),
|
|
|
|
TP_fast_assign(
|
|
__entry->sepc = trap->sepc;
|
|
__entry->scause = trap->scause;
|
|
__entry->stval = trap->stval;
|
|
__entry->htval = trap->htval;
|
|
__entry->htinst = trap->htinst;
|
|
),
|
|
|
|
TP_printk("SEPC:0x%lx, SCAUSE:0x%lx, STVAL:0x%lx, HTVAL:0x%lx, HTINST:0x%lx",
|
|
__entry->sepc,
|
|
__entry->scause,
|
|
__entry->stval,
|
|
__entry->htval,
|
|
__entry->htinst)
|
|
);
|
|
|
|
#endif /* _TRACE_RSICV_KVM_H */
|
|
|
|
#undef TRACE_INCLUDE_PATH
|
|
#define TRACE_INCLUDE_PATH .
|
|
#undef TRACE_INCLUDE_FILE
|
|
#define TRACE_INCLUDE_FILE trace
|
|
|
|
/* This part must be outside protection */
|
|
#include <trace/define_trace.h>
|