-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
riscv: Add tracepoints for SBI calls and returns
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>
- Loading branch information
Samuel Holland
authored and
Palmer Dabbelt
committed
Jul 10, 2024
1 parent
a43fe27
commit 56c1c1a
Showing
2 changed files
with
61 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
/* 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> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters