2 #define TRACE_SYSTEM x86_fpu
4 #if !defined(_TRACE_FPU_H) || defined(TRACE_HEADER_MULTI_READ)
7 #include <linux/tracepoint.h>
9 DECLARE_EVENT_CLASS(x86_fpu,
10 TP_PROTO(struct fpu *fpu),
14 __field(struct fpu *, fpu)
15 __field(bool, initialized)
16 __field(u64, xfeatures)
17 __field(u64, xcomp_bv)
22 __entry->initialized = fpu->initialized;
23 if (boot_cpu_has(X86_FEATURE_OSXSAVE)) {
24 __entry->xfeatures = fpu->state.xsave.header.xfeatures;
25 __entry->xcomp_bv = fpu->state.xsave.header.xcomp_bv;
28 TP_printk("x86/fpu: %p initialized: %d xfeatures: %llx xcomp_bv: %llx",
36 DEFINE_EVENT(x86_fpu, x86_fpu_state,
37 TP_PROTO(struct fpu *fpu),
41 DEFINE_EVENT(x86_fpu, x86_fpu_before_save,
42 TP_PROTO(struct fpu *fpu),
46 DEFINE_EVENT(x86_fpu, x86_fpu_after_save,
47 TP_PROTO(struct fpu *fpu),
51 DEFINE_EVENT(x86_fpu, x86_fpu_before_restore,
52 TP_PROTO(struct fpu *fpu),
56 DEFINE_EVENT(x86_fpu, x86_fpu_after_restore,
57 TP_PROTO(struct fpu *fpu),
61 DEFINE_EVENT(x86_fpu, x86_fpu_regs_activated,
62 TP_PROTO(struct fpu *fpu),
66 DEFINE_EVENT(x86_fpu, x86_fpu_regs_deactivated,
67 TP_PROTO(struct fpu *fpu),
71 DEFINE_EVENT(x86_fpu, x86_fpu_activate_state,
72 TP_PROTO(struct fpu *fpu),
76 DEFINE_EVENT(x86_fpu, x86_fpu_deactivate_state,
77 TP_PROTO(struct fpu *fpu),
81 DEFINE_EVENT(x86_fpu, x86_fpu_init_state,
82 TP_PROTO(struct fpu *fpu),
86 DEFINE_EVENT(x86_fpu, x86_fpu_dropped,
87 TP_PROTO(struct fpu *fpu),
91 DEFINE_EVENT(x86_fpu, x86_fpu_copy_src,
92 TP_PROTO(struct fpu *fpu),
96 DEFINE_EVENT(x86_fpu, x86_fpu_copy_dst,
97 TP_PROTO(struct fpu *fpu),
101 DEFINE_EVENT(x86_fpu, x86_fpu_xstate_check_failed,
102 TP_PROTO(struct fpu *fpu),
106 #undef TRACE_INCLUDE_PATH
107 #define TRACE_INCLUDE_PATH asm/trace/
108 #undef TRACE_INCLUDE_FILE
109 #define TRACE_INCLUDE_FILE fpu
110 #endif /* _TRACE_FPU_H */
112 /* This part must be outside protection */
113 #include <trace/define_trace.h>