M7350/kernel/arch/powerpc/include/asm/trace.h

156 lines
2.7 KiB
C
Raw Permalink Normal View History

2024-09-09 08:52:07 +00:00
#undef TRACE_SYSTEM
#define TRACE_SYSTEM powerpc
#if !defined(_TRACE_POWERPC_H) || defined(TRACE_HEADER_MULTI_READ)
#define _TRACE_POWERPC_H
#include <linux/tracepoint.h>
struct pt_regs;
2024-09-09 08:57:42 +00:00
DECLARE_EVENT_CLASS(ppc64_interrupt_class,
2024-09-09 08:52:07 +00:00
TP_PROTO(struct pt_regs *regs),
TP_ARGS(regs),
TP_STRUCT__entry(
__field(struct pt_regs *, regs)
),
TP_fast_assign(
__entry->regs = regs;
),
TP_printk("pt_regs=%p", __entry->regs)
);
2024-09-09 08:57:42 +00:00
DEFINE_EVENT(ppc64_interrupt_class, irq_entry,
2024-09-09 08:52:07 +00:00
TP_PROTO(struct pt_regs *regs),
2024-09-09 08:57:42 +00:00
TP_ARGS(regs)
);
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
DEFINE_EVENT(ppc64_interrupt_class, irq_exit,
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
TP_PROTO(struct pt_regs *regs),
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
TP_ARGS(regs)
2024-09-09 08:52:07 +00:00
);
2024-09-09 08:57:42 +00:00
DEFINE_EVENT(ppc64_interrupt_class, timer_interrupt_entry,
2024-09-09 08:52:07 +00:00
TP_PROTO(struct pt_regs *regs),
2024-09-09 08:57:42 +00:00
TP_ARGS(regs)
);
DEFINE_EVENT(ppc64_interrupt_class, timer_interrupt_exit,
TP_PROTO(struct pt_regs *regs),
TP_ARGS(regs)
);
#ifdef CONFIG_PPC_PSERIES
extern void hcall_tracepoint_regfunc(void);
extern void hcall_tracepoint_unregfunc(void);
TRACE_EVENT_FN(hcall_entry,
TP_PROTO(unsigned long opcode, unsigned long *args),
TP_ARGS(opcode, args),
2024-09-09 08:52:07 +00:00
TP_STRUCT__entry(
2024-09-09 08:57:42 +00:00
__field(unsigned long, opcode)
2024-09-09 08:52:07 +00:00
),
TP_fast_assign(
2024-09-09 08:57:42 +00:00
__entry->opcode = opcode;
2024-09-09 08:52:07 +00:00
),
2024-09-09 08:57:42 +00:00
TP_printk("opcode=%lu", __entry->opcode),
hcall_tracepoint_regfunc, hcall_tracepoint_unregfunc
2024-09-09 08:52:07 +00:00
);
2024-09-09 08:57:42 +00:00
TRACE_EVENT_FN(hcall_exit,
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
TP_PROTO(unsigned long opcode, unsigned long retval,
unsigned long *retbuf),
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
TP_ARGS(opcode, retval, retbuf),
2024-09-09 08:52:07 +00:00
TP_STRUCT__entry(
2024-09-09 08:57:42 +00:00
__field(unsigned long, opcode)
__field(unsigned long, retval)
2024-09-09 08:52:07 +00:00
),
TP_fast_assign(
2024-09-09 08:57:42 +00:00
__entry->opcode = opcode;
__entry->retval = retval;
2024-09-09 08:52:07 +00:00
),
2024-09-09 08:57:42 +00:00
TP_printk("opcode=%lu retval=%lu", __entry->opcode, __entry->retval),
hcall_tracepoint_regfunc, hcall_tracepoint_unregfunc
2024-09-09 08:52:07 +00:00
);
2024-09-09 08:57:42 +00:00
#endif
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
#ifdef CONFIG_PPC_POWERNV
extern void opal_tracepoint_regfunc(void);
extern void opal_tracepoint_unregfunc(void);
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
TRACE_EVENT_FN(opal_entry,
2024-09-09 08:52:07 +00:00
TP_PROTO(unsigned long opcode, unsigned long *args),
TP_ARGS(opcode, args),
TP_STRUCT__entry(
__field(unsigned long, opcode)
),
TP_fast_assign(
__entry->opcode = opcode;
),
TP_printk("opcode=%lu", __entry->opcode),
2024-09-09 08:57:42 +00:00
opal_tracepoint_regfunc, opal_tracepoint_unregfunc
2024-09-09 08:52:07 +00:00
);
2024-09-09 08:57:42 +00:00
TRACE_EVENT_FN(opal_exit,
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
TP_PROTO(unsigned long opcode, unsigned long retval),
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
TP_ARGS(opcode, retval),
2024-09-09 08:52:07 +00:00
TP_STRUCT__entry(
__field(unsigned long, opcode)
__field(unsigned long, retval)
),
TP_fast_assign(
__entry->opcode = opcode;
__entry->retval = retval;
),
TP_printk("opcode=%lu retval=%lu", __entry->opcode, __entry->retval),
2024-09-09 08:57:42 +00:00
opal_tracepoint_regfunc, opal_tracepoint_unregfunc
2024-09-09 08:52:07 +00:00
);
#endif
#endif /* _TRACE_POWERPC_H */
#undef TRACE_INCLUDE_PATH
#undef TRACE_INCLUDE_FILE
#define TRACE_INCLUDE_PATH asm
#define TRACE_INCLUDE_FILE trace
#include <trace/define_trace.h>