mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-26 16:56:07 +00:00 
			
		
		
		
	 6f26353ca2
			
		
	
	
		6f26353ca2
		
	
	
	
	
		
			
			While most users of the hcall tracepoints will only want the opcode and return code, some will want all the arguments. To avoid the complexity of using varargs we pass a pointer to the register save area, which contains all the arguments. Signed-off-by: Anton Blanchard <anton@samba.org> Signed-off-by: Paul Mackerras <paulus@samba.org>
		
			
				
	
	
		
			134 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
		
			2.1 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;
 | |
| 
 | |
| TRACE_EVENT(irq_entry,
 | |
| 
 | |
| 	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)
 | |
| );
 | |
| 
 | |
| TRACE_EVENT(irq_exit,
 | |
| 
 | |
| 	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)
 | |
| );
 | |
| 
 | |
| TRACE_EVENT(timer_interrupt_entry,
 | |
| 
 | |
| 	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)
 | |
| );
 | |
| 
 | |
| TRACE_EVENT(timer_interrupt_exit,
 | |
| 
 | |
| 	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)
 | |
| );
 | |
| 
 | |
| #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>
 |