mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-11 08:14:27 +08:00
d136e27326
irq_entry, irq_exit, timer_interrupt_entry and timer_interrupt_exit all do the same thing so use DECLARE_EVENT_CLASS to avoid duplicating everything 4 times. This saves quite a lot of space in both instruction text and data: text data bss dec hex filename 9265 19622 16 28903 70e7 arch/powerpc/kernel/irq.o 6817 19019 16 25852 64fc arch/powerpc/kernel/irq.o Signed-off-by: Anton Blanchard <anton@samba.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
111 lines
1.9 KiB
C
111 lines
1.9 KiB
C
#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;
|
|
|
|
DECLARE_EVENT_CLASS(ppc64_interrupt_class,
|
|
|
|
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)
|
|
);
|
|
|
|
DEFINE_EVENT(ppc64_interrupt_class, irq_entry,
|
|
|
|
TP_PROTO(struct pt_regs *regs),
|
|
|
|
TP_ARGS(regs)
|
|
);
|
|
|
|
DEFINE_EVENT(ppc64_interrupt_class, irq_exit,
|
|
|
|
TP_PROTO(struct pt_regs *regs),
|
|
|
|
TP_ARGS(regs)
|
|
);
|
|
|
|
DEFINE_EVENT(ppc64_interrupt_class, timer_interrupt_entry,
|
|
|
|
TP_PROTO(struct pt_regs *regs),
|
|
|
|
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),
|
|
|
|
TP_STRUCT__entry(
|
|
__field(unsigned long, opcode)
|
|
),
|
|
|
|
TP_fast_assign(
|
|
__entry->opcode = opcode;
|
|
),
|
|
|
|
TP_printk("opcode=%lu", __entry->opcode),
|
|
|
|
hcall_tracepoint_regfunc, hcall_tracepoint_unregfunc
|
|
);
|
|
|
|
TRACE_EVENT_FN(hcall_exit,
|
|
|
|
TP_PROTO(unsigned long opcode, unsigned long retval,
|
|
unsigned long *retbuf),
|
|
|
|
TP_ARGS(opcode, retval, retbuf),
|
|
|
|
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),
|
|
|
|
hcall_tracepoint_regfunc, hcall_tracepoint_unregfunc
|
|
);
|
|
#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>
|