6d2e957986
BugLink: https://bugs.launchpad.net/bugs/2085849 [ Upstream commit 56c1c1a09ab93c7b7c957860f01f8600d6c03143 ] These are useful for measuring the latency of SBI calls. The SBI HSM extension is excluded because those functions are called from contexts such as cpuidle where instrumentation is not allowed. Reviewed-by: Andrew Jones <ajones@ventanamicro.com> Signed-off-by: Samuel Holland <samuel.holland@sifive.com> Link: https://lore.kernel.org/r/20240321230131.1838105-1-samuel.holland@sifive.com Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com> Stable-dep-of: 1ff95eb2bebd ("riscv: Fix RISCV_ALTERNATIVE_EARLY") Signed-off-by: Sasha Levin <sashal@kernel.org> Signed-off-by: Manuel Diewald <manuel.diewald@canonical.com> Signed-off-by: Roxana Nicolescu <roxana.nicolescu@canonical.com>
55 lines
1.0 KiB
C
55 lines
1.0 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#undef TRACE_SYSTEM
|
|
#define TRACE_SYSTEM riscv
|
|
|
|
#if !defined(_TRACE_RISCV_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
#define _TRACE_RISCV_H
|
|
|
|
#include <linux/tracepoint.h>
|
|
|
|
TRACE_EVENT_CONDITION(sbi_call,
|
|
TP_PROTO(int ext, int fid),
|
|
TP_ARGS(ext, fid),
|
|
TP_CONDITION(ext != SBI_EXT_HSM),
|
|
|
|
TP_STRUCT__entry(
|
|
__field(int, ext)
|
|
__field(int, fid)
|
|
),
|
|
|
|
TP_fast_assign(
|
|
__entry->ext = ext;
|
|
__entry->fid = fid;
|
|
),
|
|
|
|
TP_printk("ext=0x%x fid=%d", __entry->ext, __entry->fid)
|
|
);
|
|
|
|
TRACE_EVENT_CONDITION(sbi_return,
|
|
TP_PROTO(int ext, long error, long value),
|
|
TP_ARGS(ext, error, value),
|
|
TP_CONDITION(ext != SBI_EXT_HSM),
|
|
|
|
TP_STRUCT__entry(
|
|
__field(long, error)
|
|
__field(long, value)
|
|
),
|
|
|
|
TP_fast_assign(
|
|
__entry->error = error;
|
|
__entry->value = value;
|
|
),
|
|
|
|
TP_printk("error=%ld value=0x%lx", __entry->error, __entry->value)
|
|
);
|
|
|
|
#endif /* _TRACE_RISCV_H */
|
|
|
|
#undef TRACE_INCLUDE_PATH
|
|
#undef TRACE_INCLUDE_FILE
|
|
|
|
#define TRACE_INCLUDE_PATH asm
|
|
#define TRACE_INCLUDE_FILE trace
|
|
|
|
#include <trace/define_trace.h>
|