Linux Audio

Check our new training course

Loading...
v6.13.7
 1/* SPDX-License-Identifier: GPL-2.0 */
 2#undef TRACE_SYSTEM
 3#define TRACE_SYSTEM mce
 4
 5#if !defined(_TRACE_MCE_H) || defined(TRACE_HEADER_MULTI_READ)
 6#define _TRACE_MCE_H
 7
 8#include <linux/ktime.h>
 9#include <linux/tracepoint.h>
10#include <asm/mce.h>
11
12/*
13 * MCE Event Record.
14 *
15 * Only very relevant and transient information which cannot be
16 * gathered from a system by any other means or which can only be
17 * acquired arduously should be added to this record.
18 */
19
20TRACE_EVENT(mce_record,
21
22	TP_PROTO(struct mce_hw_err *err),
23
24	TP_ARGS(err),
25
26	TP_STRUCT__entry(
27		__field(	u64,		mcgcap		)
28		__field(	u64,		mcgstatus	)
29		__field(	u64,		status		)
30		__field(	u64,		addr		)
31		__field(	u64,		misc		)
32		__field(	u64,		synd		)
33		__field(	u64,		ipid		)
34		__field(	u64,		ip		)
35		__field(	u64,		tsc		)
36		__field(	u64,		ppin		)
37		__field(	u64,		walltime	)
38		__field(	u32,		cpu		)
39		__field(	u32,		cpuid		)
40		__field(	u32,		apicid		)
41		__field(	u32,		socketid	)
42		__field(	u8,		cs		)
43		__field(	u8,		bank		)
44		__field(	u8,		cpuvendor	)
45		__field(	u32,		microcode	)
46		__dynamic_array(u8, v_data, sizeof(err->vendor))
47	),
48
49	TP_fast_assign(
50		__entry->mcgcap		= err->m.mcgcap;
51		__entry->mcgstatus	= err->m.mcgstatus;
52		__entry->status		= err->m.status;
53		__entry->addr		= err->m.addr;
54		__entry->misc		= err->m.misc;
55		__entry->synd		= err->m.synd;
56		__entry->ipid		= err->m.ipid;
57		__entry->ip		= err->m.ip;
58		__entry->tsc		= err->m.tsc;
59		__entry->ppin		= err->m.ppin;
60		__entry->walltime	= err->m.time;
61		__entry->cpu		= err->m.extcpu;
62		__entry->cpuid		= err->m.cpuid;
63		__entry->apicid		= err->m.apicid;
64		__entry->socketid	= err->m.socketid;
65		__entry->cs		= err->m.cs;
66		__entry->bank		= err->m.bank;
67		__entry->cpuvendor	= err->m.cpuvendor;
68		__entry->microcode	= err->m.microcode;
69		memcpy(__get_dynamic_array(v_data), &err->vendor, sizeof(err->vendor));
70	),
71
72	TP_printk("CPU: %d, MCGc/s: %llx/%llx, MC%d: %016llx, IPID: %016llx, ADDR: %016llx, MISC: %016llx, SYND: %016llx, RIP: %02x:<%016llx>, TSC: %llx, PPIN: %llx, vendor: %u, CPUID: %x, time: %llu, socket: %u, APIC: %x, microcode: %x, vendor data: %s",
73		__entry->cpu,
74		__entry->mcgcap, __entry->mcgstatus,
75		__entry->bank, __entry->status,
76		__entry->ipid,
77		__entry->addr,
78		__entry->misc,
79		__entry->synd,
80		__entry->cs, __entry->ip,
81		__entry->tsc,
82		__entry->ppin,
83		__entry->cpuvendor,
84		__entry->cpuid,
85		__entry->walltime,
86		__entry->socketid,
87		__entry->apicid,
88		__entry->microcode,
89		__print_dynamic_array(v_data, sizeof(u8)))
90);
91
92#endif /* _TRACE_MCE_H */
93
94/* This part must be outside protection */
95#include <trace/define_trace.h>
v3.1
 
 1#undef TRACE_SYSTEM
 2#define TRACE_SYSTEM mce
 3
 4#if !defined(_TRACE_MCE_H) || defined(TRACE_HEADER_MULTI_READ)
 5#define _TRACE_MCE_H
 6
 7#include <linux/ktime.h>
 8#include <linux/tracepoint.h>
 9#include <asm/mce.h>
10
 
 
 
 
 
 
 
 
11TRACE_EVENT(mce_record,
12
13	TP_PROTO(struct mce *m),
14
15	TP_ARGS(m),
16
17	TP_STRUCT__entry(
18		__field(	u64,		mcgcap		)
19		__field(	u64,		mcgstatus	)
20		__field(	u64,		status		)
21		__field(	u64,		addr		)
22		__field(	u64,		misc		)
 
 
23		__field(	u64,		ip		)
24		__field(	u64,		tsc		)
 
25		__field(	u64,		walltime	)
26		__field(	u32,		cpu		)
27		__field(	u32,		cpuid		)
28		__field(	u32,		apicid		)
29		__field(	u32,		socketid	)
30		__field(	u8,		cs		)
31		__field(	u8,		bank		)
32		__field(	u8,		cpuvendor	)
 
 
33	),
34
35	TP_fast_assign(
36		__entry->mcgcap		= m->mcgcap;
37		__entry->mcgstatus	= m->mcgstatus;
38		__entry->status		= m->status;
39		__entry->addr		= m->addr;
40		__entry->misc		= m->misc;
41		__entry->ip		= m->ip;
42		__entry->tsc		= m->tsc;
43		__entry->walltime	= m->time;
44		__entry->cpu		= m->extcpu;
45		__entry->cpuid		= m->cpuid;
46		__entry->apicid		= m->apicid;
47		__entry->socketid	= m->socketid;
48		__entry->cs		= m->cs;
49		__entry->bank		= m->bank;
50		__entry->cpuvendor	= m->cpuvendor;
 
 
 
 
 
51	),
52
53	TP_printk("CPU: %d, MCGc/s: %llx/%llx, MC%d: %016Lx, ADDR/MISC: %016Lx/%016Lx, RIP: %02x:<%016Lx>, TSC: %llx, PROCESSOR: %u:%x, TIME: %llu, SOCKET: %u, APIC: %x",
54		__entry->cpu,
55		__entry->mcgcap, __entry->mcgstatus,
56		__entry->bank, __entry->status,
57		__entry->addr, __entry->misc,
 
 
 
58		__entry->cs, __entry->ip,
59		__entry->tsc,
60		__entry->cpuvendor, __entry->cpuid,
 
 
61		__entry->walltime,
62		__entry->socketid,
63		__entry->apicid)
 
 
64);
65
66#endif /* _TRACE_MCE_H */
67
68/* This part must be outside protection */
69#include <trace/define_trace.h>