Merge tag 'trace-printf-v6.13' of git://git.kernel.org/pub/scm/linux/kernel/git/trace...
[drm/drm-misc.git] / include / trace / events / clk.h
blob759f7371a6dc39c66ff7e82f52a6fff90270429e
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * Copyright (c) 2014-2015, The Linux Foundation. All rights reserved.
4 */
5 #undef TRACE_SYSTEM
6 #define TRACE_SYSTEM clk
8 #if !defined(_TRACE_CLK_H) || defined(TRACE_HEADER_MULTI_READ)
9 #define _TRACE_CLK_H
11 #include <linux/tracepoint.h>
13 struct clk_core;
15 DECLARE_EVENT_CLASS(clk,
17 TP_PROTO(struct clk_core *core),
19 TP_ARGS(core),
21 TP_STRUCT__entry(
22 __string( name, core->name )
25 TP_fast_assign(
26 __assign_str(name);
29 TP_printk("%s", __get_str(name))
32 DEFINE_EVENT(clk, clk_enable,
34 TP_PROTO(struct clk_core *core),
36 TP_ARGS(core)
39 DEFINE_EVENT(clk, clk_enable_complete,
41 TP_PROTO(struct clk_core *core),
43 TP_ARGS(core)
46 DEFINE_EVENT(clk, clk_disable,
48 TP_PROTO(struct clk_core *core),
50 TP_ARGS(core)
53 DEFINE_EVENT(clk, clk_disable_complete,
55 TP_PROTO(struct clk_core *core),
57 TP_ARGS(core)
60 DEFINE_EVENT(clk, clk_prepare,
62 TP_PROTO(struct clk_core *core),
64 TP_ARGS(core)
67 DEFINE_EVENT(clk, clk_prepare_complete,
69 TP_PROTO(struct clk_core *core),
71 TP_ARGS(core)
74 DEFINE_EVENT(clk, clk_unprepare,
76 TP_PROTO(struct clk_core *core),
78 TP_ARGS(core)
81 DEFINE_EVENT(clk, clk_unprepare_complete,
83 TP_PROTO(struct clk_core *core),
85 TP_ARGS(core)
88 DECLARE_EVENT_CLASS(clk_rate,
90 TP_PROTO(struct clk_core *core, unsigned long rate),
92 TP_ARGS(core, rate),
94 TP_STRUCT__entry(
95 __string( name, core->name )
96 __field(unsigned long, rate )
99 TP_fast_assign(
100 __assign_str(name);
101 __entry->rate = rate;
104 TP_printk("%s %lu", __get_str(name), (unsigned long)__entry->rate)
107 DEFINE_EVENT(clk_rate, clk_set_rate,
109 TP_PROTO(struct clk_core *core, unsigned long rate),
111 TP_ARGS(core, rate)
114 DEFINE_EVENT(clk_rate, clk_set_rate_complete,
116 TP_PROTO(struct clk_core *core, unsigned long rate),
118 TP_ARGS(core, rate)
121 DEFINE_EVENT(clk_rate, clk_set_min_rate,
123 TP_PROTO(struct clk_core *core, unsigned long rate),
125 TP_ARGS(core, rate)
128 DEFINE_EVENT(clk_rate, clk_set_max_rate,
130 TP_PROTO(struct clk_core *core, unsigned long rate),
132 TP_ARGS(core, rate)
135 DECLARE_EVENT_CLASS(clk_rate_range,
137 TP_PROTO(struct clk_core *core, unsigned long min, unsigned long max),
139 TP_ARGS(core, min, max),
141 TP_STRUCT__entry(
142 __string( name, core->name )
143 __field(unsigned long, min )
144 __field(unsigned long, max )
147 TP_fast_assign(
148 __assign_str(name);
149 __entry->min = min;
150 __entry->max = max;
153 TP_printk("%s min %lu max %lu", __get_str(name),
154 (unsigned long)__entry->min,
155 (unsigned long)__entry->max)
158 DEFINE_EVENT(clk_rate_range, clk_set_rate_range,
160 TP_PROTO(struct clk_core *core, unsigned long min, unsigned long max),
162 TP_ARGS(core, min, max)
165 DECLARE_EVENT_CLASS(clk_parent,
167 TP_PROTO(struct clk_core *core, struct clk_core *parent),
169 TP_ARGS(core, parent),
171 TP_STRUCT__entry(
172 __string( name, core->name )
173 __string( pname, parent ? parent->name : "none" )
176 TP_fast_assign(
177 __assign_str(name);
178 __assign_str(pname);
181 TP_printk("%s %s", __get_str(name), __get_str(pname))
184 DEFINE_EVENT(clk_parent, clk_set_parent,
186 TP_PROTO(struct clk_core *core, struct clk_core *parent),
188 TP_ARGS(core, parent)
191 DEFINE_EVENT(clk_parent, clk_set_parent_complete,
193 TP_PROTO(struct clk_core *core, struct clk_core *parent),
195 TP_ARGS(core, parent)
198 DECLARE_EVENT_CLASS(clk_phase,
200 TP_PROTO(struct clk_core *core, int phase),
202 TP_ARGS(core, phase),
204 TP_STRUCT__entry(
205 __string( name, core->name )
206 __field( int, phase )
209 TP_fast_assign(
210 __assign_str(name);
211 __entry->phase = phase;
214 TP_printk("%s %d", __get_str(name), (int)__entry->phase)
217 DEFINE_EVENT(clk_phase, clk_set_phase,
219 TP_PROTO(struct clk_core *core, int phase),
221 TP_ARGS(core, phase)
224 DEFINE_EVENT(clk_phase, clk_set_phase_complete,
226 TP_PROTO(struct clk_core *core, int phase),
228 TP_ARGS(core, phase)
231 DECLARE_EVENT_CLASS(clk_duty_cycle,
233 TP_PROTO(struct clk_core *core, struct clk_duty *duty),
235 TP_ARGS(core, duty),
237 TP_STRUCT__entry(
238 __string( name, core->name )
239 __field( unsigned int, num )
240 __field( unsigned int, den )
243 TP_fast_assign(
244 __assign_str(name);
245 __entry->num = duty->num;
246 __entry->den = duty->den;
249 TP_printk("%s %u/%u", __get_str(name), (unsigned int)__entry->num,
250 (unsigned int)__entry->den)
253 DEFINE_EVENT(clk_duty_cycle, clk_set_duty_cycle,
255 TP_PROTO(struct clk_core *core, struct clk_duty *duty),
257 TP_ARGS(core, duty)
260 DEFINE_EVENT(clk_duty_cycle, clk_set_duty_cycle_complete,
262 TP_PROTO(struct clk_core *core, struct clk_duty *duty),
264 TP_ARGS(core, duty)
267 DECLARE_EVENT_CLASS(clk_rate_request,
269 TP_PROTO(struct clk_rate_request *req),
271 TP_ARGS(req),
273 TP_STRUCT__entry(
274 __string( name, req->core ? req->core->name : "none")
275 __string( pname, req->best_parent_hw ? clk_hw_get_name(req->best_parent_hw) : "none" )
276 __field(unsigned long, min )
277 __field(unsigned long, max )
278 __field(unsigned long, prate )
281 TP_fast_assign(
282 __assign_str(name);
283 __assign_str(pname);
284 __entry->min = req->min_rate;
285 __entry->max = req->max_rate;
286 __entry->prate = req->best_parent_rate;
289 TP_printk("%s min %lu max %lu, parent %s (%lu)", __get_str(name),
290 (unsigned long)__entry->min,
291 (unsigned long)__entry->max,
292 __get_str(pname),
293 (unsigned long)__entry->prate)
296 DEFINE_EVENT(clk_rate_request, clk_rate_request_start,
298 TP_PROTO(struct clk_rate_request *req),
300 TP_ARGS(req)
303 DEFINE_EVENT(clk_rate_request, clk_rate_request_done,
305 TP_PROTO(struct clk_rate_request *req),
307 TP_ARGS(req)
310 #endif /* _TRACE_CLK_H */
312 /* This part must be outside protection */
313 #include <trace/define_trace.h>