1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun #undef TRACE_SYSTEM 3*4882a593Smuzhiyun #define TRACE_SYSTEM nmi 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun #if !defined(_TRACE_NMI_H) || defined(TRACE_HEADER_MULTI_READ) 6*4882a593Smuzhiyun #define _TRACE_NMI_H 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #include <linux/ktime.h> 9*4882a593Smuzhiyun #include <linux/tracepoint.h> 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun TRACE_EVENT(nmi_handler, 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun TP_PROTO(void *handler, s64 delta_ns, int handled), 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun TP_ARGS(handler, delta_ns, handled), 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun TP_STRUCT__entry( 18*4882a593Smuzhiyun __field( void *, handler ) 19*4882a593Smuzhiyun __field( s64, delta_ns) 20*4882a593Smuzhiyun __field( int, handled ) 21*4882a593Smuzhiyun ), 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun TP_fast_assign( 24*4882a593Smuzhiyun __entry->handler = handler; 25*4882a593Smuzhiyun __entry->delta_ns = delta_ns; 26*4882a593Smuzhiyun __entry->handled = handled; 27*4882a593Smuzhiyun ), 28*4882a593Smuzhiyun 29*4882a593Smuzhiyun TP_printk("%ps() delta_ns: %lld handled: %d", 30*4882a593Smuzhiyun __entry->handler, 31*4882a593Smuzhiyun __entry->delta_ns, 32*4882a593Smuzhiyun __entry->handled) 33*4882a593Smuzhiyun ); 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun #endif /* _TRACE_NMI_H */ 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun /* This part ust be outside protection */ 38*4882a593Smuzhiyun #include <trace/define_trace.h> 39