xref: /openbmc/linux/include/trace/events/mce.h (revision 5828c46f2c07b97d758da6dc6afd5c374768d44d)
18968f9d3SHidetoshi Seto #undef TRACE_SYSTEM
28968f9d3SHidetoshi Seto #define TRACE_SYSTEM mce
38968f9d3SHidetoshi Seto 
48968f9d3SHidetoshi Seto #if !defined(_TRACE_MCE_H) || defined(TRACE_HEADER_MULTI_READ)
58968f9d3SHidetoshi Seto #define _TRACE_MCE_H
68968f9d3SHidetoshi Seto 
78968f9d3SHidetoshi Seto #include <linux/ktime.h>
88968f9d3SHidetoshi Seto #include <linux/tracepoint.h>
98968f9d3SHidetoshi Seto #include <asm/mce.h>
108968f9d3SHidetoshi Seto 
118968f9d3SHidetoshi Seto TRACE_EVENT(mce_record,
128968f9d3SHidetoshi Seto 
138968f9d3SHidetoshi Seto 	TP_PROTO(struct mce *m),
148968f9d3SHidetoshi Seto 
158968f9d3SHidetoshi Seto 	TP_ARGS(m),
168968f9d3SHidetoshi Seto 
178968f9d3SHidetoshi Seto 	TP_STRUCT__entry(
188968f9d3SHidetoshi Seto 		__field(	u64,		mcgcap		)
198968f9d3SHidetoshi Seto 		__field(	u64,		mcgstatus	)
208968f9d3SHidetoshi Seto 		__field(	u64,		status		)
218968f9d3SHidetoshi Seto 		__field(	u64,		addr		)
228968f9d3SHidetoshi Seto 		__field(	u64,		misc		)
23db819d60SYazen Ghannam 		__field(	u64,		synd		)
24*5828c46fSYazen Ghannam 		__field(	u64,		ipid		)
258968f9d3SHidetoshi Seto 		__field(	u64,		ip		)
268968f9d3SHidetoshi Seto 		__field(	u64,		tsc		)
278968f9d3SHidetoshi Seto 		__field(	u64,		walltime	)
288968f9d3SHidetoshi Seto 		__field(	u32,		cpu		)
298968f9d3SHidetoshi Seto 		__field(	u32,		cpuid		)
308968f9d3SHidetoshi Seto 		__field(	u32,		apicid		)
318968f9d3SHidetoshi Seto 		__field(	u32,		socketid	)
32ad440ad6SDavid Sharp 		__field(	u8,		cs		)
33ad440ad6SDavid Sharp 		__field(	u8,		bank		)
348968f9d3SHidetoshi Seto 		__field(	u8,		cpuvendor	)
358968f9d3SHidetoshi Seto 	),
368968f9d3SHidetoshi Seto 
378968f9d3SHidetoshi Seto 	TP_fast_assign(
388968f9d3SHidetoshi Seto 		__entry->mcgcap		= m->mcgcap;
398968f9d3SHidetoshi Seto 		__entry->mcgstatus	= m->mcgstatus;
408968f9d3SHidetoshi Seto 		__entry->status		= m->status;
418968f9d3SHidetoshi Seto 		__entry->addr		= m->addr;
428968f9d3SHidetoshi Seto 		__entry->misc		= m->misc;
43db819d60SYazen Ghannam 		__entry->synd		= m->synd;
44*5828c46fSYazen Ghannam 		__entry->ipid		= m->ipid;
458968f9d3SHidetoshi Seto 		__entry->ip		= m->ip;
468968f9d3SHidetoshi Seto 		__entry->tsc		= m->tsc;
478968f9d3SHidetoshi Seto 		__entry->walltime	= m->time;
488968f9d3SHidetoshi Seto 		__entry->cpu		= m->extcpu;
498968f9d3SHidetoshi Seto 		__entry->cpuid		= m->cpuid;
508968f9d3SHidetoshi Seto 		__entry->apicid		= m->apicid;
518968f9d3SHidetoshi Seto 		__entry->socketid	= m->socketid;
52ad440ad6SDavid Sharp 		__entry->cs		= m->cs;
53ad440ad6SDavid Sharp 		__entry->bank		= m->bank;
548968f9d3SHidetoshi Seto 		__entry->cpuvendor	= m->cpuvendor;
558968f9d3SHidetoshi Seto 	),
568968f9d3SHidetoshi Seto 
57*5828c46fSYazen Ghannam 	TP_printk("CPU: %d, MCGc/s: %llx/%llx, MC%d: %016Lx, IPID: %016Lx, ADDR/MISC/SYND: %016Lx/%016Lx/%016Lx, RIP: %02x:<%016Lx>, TSC: %llx, PROCESSOR: %u:%x, TIME: %llu, SOCKET: %u, APIC: %x",
588968f9d3SHidetoshi Seto 		__entry->cpu,
598968f9d3SHidetoshi Seto 		__entry->mcgcap, __entry->mcgstatus,
608968f9d3SHidetoshi Seto 		__entry->bank, __entry->status,
61*5828c46fSYazen Ghannam 		__entry->ipid,
62db819d60SYazen Ghannam 		__entry->addr, __entry->misc, __entry->synd,
638968f9d3SHidetoshi Seto 		__entry->cs, __entry->ip,
648968f9d3SHidetoshi Seto 		__entry->tsc,
658968f9d3SHidetoshi Seto 		__entry->cpuvendor, __entry->cpuid,
668968f9d3SHidetoshi Seto 		__entry->walltime,
678968f9d3SHidetoshi Seto 		__entry->socketid,
688968f9d3SHidetoshi Seto 		__entry->apicid)
698968f9d3SHidetoshi Seto );
708968f9d3SHidetoshi Seto 
718968f9d3SHidetoshi Seto #endif /* _TRACE_MCE_H */
728968f9d3SHidetoshi Seto 
738968f9d3SHidetoshi Seto /* This part must be outside protection */
748968f9d3SHidetoshi Seto #include <trace/define_trace.h>
75