xref: /linux/include/trace/events/timer_migration.h (revision f58f45c1e5b92975e91754f5407250085a6ae7cf)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 #undef TRACE_SYSTEM
4 #define TRACE_SYSTEM timer_migration
5 
6 #if !defined(_TRACE_TIMER_MIGRATION_H) || defined(TRACE_HEADER_MULTI_READ)
7 #define _TRACE_TIMER_MIGRATION_H
8 
9 #include <linux/tracepoint.h>
10 
11 /* Group events */
12 TRACE_EVENT(tmigr_group_set,
13 
14 	TP_PROTO(struct tmigr_group *group),
15 
16 	TP_ARGS(group),
17 
18 	TP_STRUCT__entry(
19 		__field( void *,	group		)
20 		__field( unsigned int,	lvl		)
21 		__field( unsigned int,	numa_node	)
22 	),
23 
24 	TP_fast_assign(
25 		__entry->group		= group;
26 		__entry->lvl		= group->level;
27 		__entry->numa_node	= group->numa_node;
28 	),
29 
30 	TP_printk("group=%p lvl=%d numa=%d",
31 		  __entry->group, __entry->lvl, __entry->numa_node)
32 );
33 
34 TRACE_EVENT(tmigr_connect_child_parent,
35 
36 	TP_PROTO(struct tmigr_group *child),
37 
38 	TP_ARGS(child),
39 
40 	TP_STRUCT__entry(
41 		__field( void *,	child		)
42 		__field( void *,	parent		)
43 		__field( unsigned int,	lvl		)
44 		__field( unsigned int,	numa_node	)
45 		__field( unsigned int,	num_children	)
46 		__field( u32,		childmask	)
47 	),
48 
49 	TP_fast_assign(
50 		__entry->child		= child;
51 		__entry->parent		= child->parent;
52 		__entry->lvl		= child->parent->level;
53 		__entry->numa_node	= child->parent->numa_node;
54 		__entry->num_children	= child->parent->num_children;
55 		__entry->childmask	= child->childmask;
56 	),
57 
58 	TP_printk("group=%p childmask=%0x parent=%p lvl=%d numa=%d num_children=%d",
59 		  __entry->child,  __entry->childmask, __entry->parent,
60 		  __entry->lvl, __entry->numa_node, __entry->num_children)
61 );
62 
63 TRACE_EVENT(tmigr_connect_cpu_parent,
64 
65 	TP_PROTO(struct tmigr_cpu *tmc),
66 
67 	TP_ARGS(tmc),
68 
69 	TP_STRUCT__entry(
70 		__field( void *,	parent		)
71 		__field( unsigned int,	cpu		)
72 		__field( unsigned int,	lvl		)
73 		__field( unsigned int,	numa_node	)
74 		__field( unsigned int,	num_children	)
75 		__field( u32,		childmask	)
76 	),
77 
78 	TP_fast_assign(
79 		__entry->parent		= tmc->tmgroup;
80 		__entry->cpu		= tmc->cpuevt.cpu;
81 		__entry->lvl		= tmc->tmgroup->level;
82 		__entry->numa_node	= tmc->tmgroup->numa_node;
83 		__entry->num_children	= tmc->tmgroup->num_children;
84 		__entry->childmask	= tmc->childmask;
85 	),
86 
87 	TP_printk("cpu=%d childmask=%0x parent=%p lvl=%d numa=%d num_children=%d",
88 		  __entry->cpu,	 __entry->childmask, __entry->parent,
89 		  __entry->lvl, __entry->numa_node, __entry->num_children)
90 );
91 
92 DECLARE_EVENT_CLASS(tmigr_group_and_cpu,
93 
94 	TP_PROTO(struct tmigr_group *group, union tmigr_state state, u32 childmask),
95 
96 	TP_ARGS(group, state, childmask),
97 
98 	TP_STRUCT__entry(
99 		__field( void *,	group		)
100 		__field( void *,	parent		)
101 		__field( unsigned int,	lvl		)
102 		__field( unsigned int,	numa_node	)
103 		__field( u32,		childmask	)
104 		__field( u8,		active		)
105 		__field( u8,		migrator	)
106 	),
107 
108 	TP_fast_assign(
109 		__entry->group		= group;
110 		__entry->parent		= group->parent;
111 		__entry->lvl		= group->level;
112 		__entry->numa_node	= group->numa_node;
113 		__entry->childmask	= childmask;
114 		__entry->active		= state.active;
115 		__entry->migrator	= state.migrator;
116 	),
117 
118 	TP_printk("group=%p lvl=%d numa=%d active=%0x migrator=%0x "
119 		  "parent=%p childmask=%0x",
120 		  __entry->group, __entry->lvl, __entry->numa_node,
121 		  __entry->active, __entry->migrator,
122 		  __entry->parent, __entry->childmask)
123 );
124 
125 DEFINE_EVENT(tmigr_group_and_cpu, tmigr_group_set_cpu_inactive,
126 
127 	TP_PROTO(struct tmigr_group *group, union tmigr_state state, u32 childmask),
128 
129 	TP_ARGS(group, state, childmask)
130 );
131 
132 DEFINE_EVENT(tmigr_group_and_cpu, tmigr_group_set_cpu_active,
133 
134 	TP_PROTO(struct tmigr_group *group, union tmigr_state state, u32 childmask),
135 
136 	TP_ARGS(group, state, childmask)
137 );
138 
139 /* CPU events*/
140 DECLARE_EVENT_CLASS(tmigr_cpugroup,
141 
142 	TP_PROTO(struct tmigr_cpu *tmc),
143 
144 	TP_ARGS(tmc),
145 
146 	TP_STRUCT__entry(
147 		__field( u64,		wakeup	)
148 		__field( void *,	parent	)
149 		__field( unsigned int,	cpu	)
150 
151 	),
152 
153 	TP_fast_assign(
154 		__entry->wakeup		= tmc->wakeup;
155 		__entry->parent		= tmc->tmgroup;
156 		__entry->cpu		= tmc->cpuevt.cpu;
157 	),
158 
159 	TP_printk("cpu=%d parent=%p wakeup=%llu", __entry->cpu, __entry->parent, __entry->wakeup)
160 );
161 
162 DEFINE_EVENT(tmigr_cpugroup, tmigr_cpu_new_timer,
163 
164 	TP_PROTO(struct tmigr_cpu *tmc),
165 
166 	TP_ARGS(tmc)
167 );
168 
169 DEFINE_EVENT(tmigr_cpugroup, tmigr_cpu_active,
170 
171 	TP_PROTO(struct tmigr_cpu *tmc),
172 
173 	TP_ARGS(tmc)
174 );
175 
176 DEFINE_EVENT(tmigr_cpugroup, tmigr_cpu_online,
177 
178 	TP_PROTO(struct tmigr_cpu *tmc),
179 
180 	TP_ARGS(tmc)
181 );
182 
183 DEFINE_EVENT(tmigr_cpugroup, tmigr_cpu_offline,
184 
185 	TP_PROTO(struct tmigr_cpu *tmc),
186 
187 	TP_ARGS(tmc)
188 );
189 
190 DEFINE_EVENT(tmigr_cpugroup, tmigr_handle_remote_cpu,
191 
192 	TP_PROTO(struct tmigr_cpu *tmc),
193 
194 	TP_ARGS(tmc)
195 );
196 
197 DECLARE_EVENT_CLASS(tmigr_idle,
198 
199 	TP_PROTO(struct tmigr_cpu *tmc, u64 nextevt),
200 
201 	TP_ARGS(tmc, nextevt),
202 
203 	TP_STRUCT__entry(
204 		__field( u64,		nextevt)
205 		__field( u64,		wakeup)
206 		__field( void *,	parent)
207 		__field( unsigned int,	cpu)
208 	),
209 
210 	TP_fast_assign(
211 		__entry->nextevt	= nextevt;
212 		__entry->wakeup		= tmc->wakeup;
213 		__entry->parent		= tmc->tmgroup;
214 		__entry->cpu		= tmc->cpuevt.cpu;
215 	),
216 
217 	TP_printk("cpu=%d parent=%p nextevt=%llu wakeup=%llu",
218 		  __entry->cpu, __entry->parent, __entry->nextevt, __entry->wakeup)
219 );
220 
221 DEFINE_EVENT(tmigr_idle, tmigr_cpu_idle,
222 
223 	TP_PROTO(struct tmigr_cpu *tmc, u64 nextevt),
224 
225 	TP_ARGS(tmc, nextevt)
226 );
227 
228 DEFINE_EVENT(tmigr_idle, tmigr_cpu_new_timer_idle,
229 
230 	TP_PROTO(struct tmigr_cpu *tmc, u64 nextevt),
231 
232 	TP_ARGS(tmc, nextevt)
233 );
234 
235 TRACE_EVENT(tmigr_update_events,
236 
237 	TP_PROTO(struct tmigr_group *child, struct tmigr_group *group,
238 		 union tmigr_state childstate,	union tmigr_state groupstate,
239 		 u64 nextevt),
240 
241 	TP_ARGS(child, group, childstate, groupstate, nextevt),
242 
243 	TP_STRUCT__entry(
244 		__field( void *,	child			)
245 		__field( void *,	group			)
246 		__field( u64,		nextevt			)
247 		__field( u64,		group_next_expiry	)
248 		__field( u64,		child_evt_expiry	)
249 		__field( unsigned int,	group_lvl		)
250 		__field( unsigned int,	child_evtcpu		)
251 		__field( u8,		child_active		)
252 		__field( u8,		group_active		)
253 	),
254 
255 	TP_fast_assign(
256 		__entry->child			= child;
257 		__entry->group			= group;
258 		__entry->nextevt		= nextevt;
259 		__entry->group_next_expiry	= group->next_expiry;
260 		__entry->child_evt_expiry	= child ? child->groupevt.nextevt.expires : 0;
261 		__entry->group_lvl		= group->level;
262 		__entry->child_evtcpu		= child ? child->groupevt.cpu : 0;
263 		__entry->child_active		= childstate.active;
264 		__entry->group_active		= groupstate.active;
265 	),
266 
267 	TP_printk("child=%p group=%p group_lvl=%d child_active=%0x group_active=%0x "
268 		  "nextevt=%llu next_expiry=%llu child_evt_expiry=%llu child_evtcpu=%d",
269 		  __entry->child, __entry->group, __entry->group_lvl, __entry->child_active,
270 		  __entry->group_active,
271 		  __entry->nextevt, __entry->group_next_expiry, __entry->child_evt_expiry,
272 		  __entry->child_evtcpu)
273 );
274 
275 TRACE_EVENT(tmigr_handle_remote,
276 
277 	TP_PROTO(struct tmigr_group *group),
278 
279 	TP_ARGS(group),
280 
281 	TP_STRUCT__entry(
282 		__field( void * ,	group	)
283 		__field( unsigned int ,	lvl	)
284 	),
285 
286 	TP_fast_assign(
287 		__entry->group		= group;
288 		__entry->lvl		= group->level;
289 	),
290 
291 	TP_printk("group=%p lvl=%d",
292 		   __entry->group, __entry->lvl)
293 );
294 
295 #endif /*  _TRACE_TIMER_MIGRATION_H */
296 
297 /* This part must be outside protection */
298 #include <trace/define_trace.h>
299