1 /* SPDX-License-Identifier: GPL-2.0 */
3 #define TRACE_SYSTEM asoc
5 #if !defined(_TRACE_ASOC_H) || defined(TRACE_HEADER_MULTI_READ)
8 #include <linux/ktime.h>
9 #include <linux/tracepoint.h>
10 #include <sound/jack.h>
12 #define DAPM_DIRECT "(direct)"
13 #define DAPM_ARROW(dir) (((dir) == SND_SOC_DAPM_DIR_OUT) ? "->" : "<-")
15 TRACE_DEFINE_ENUM(SND_SOC_DAPM_DIR_OUT);
19 struct snd_soc_dapm_widget;
20 struct snd_soc_dapm_path;
22 DECLARE_EVENT_CLASS(snd_soc_dapm,
24 TP_PROTO(struct snd_soc_dapm_context *dapm, int val),
29 __string( card_name, dapm->card->name)
30 __string( comp_name, dapm->component ? dapm->component->name : "(none)")
35 __assign_str(card_name);
36 __assign_str(comp_name);
40 TP_printk("card=%s component=%s val=%d",
41 __get_str(card_name), __get_str(comp_name), (int)__entry->val)
44 DEFINE_EVENT(snd_soc_dapm, snd_soc_bias_level_start,
46 TP_PROTO(struct snd_soc_dapm_context *dapm, int val),
52 DEFINE_EVENT(snd_soc_dapm, snd_soc_bias_level_done,
54 TP_PROTO(struct snd_soc_dapm_context *dapm, int val),
60 DECLARE_EVENT_CLASS(snd_soc_dapm_basic,
62 TP_PROTO(struct snd_soc_card *card, int event),
67 __string( name, card->name )
73 __entry->event = event;
76 TP_printk("card=%s event=%d", __get_str(name), (int)__entry->event)
79 DEFINE_EVENT(snd_soc_dapm_basic, snd_soc_dapm_start,
81 TP_PROTO(struct snd_soc_card *card, int event),
87 DEFINE_EVENT(snd_soc_dapm_basic, snd_soc_dapm_done,
89 TP_PROTO(struct snd_soc_card *card, int event),
95 DECLARE_EVENT_CLASS(snd_soc_dapm_widget,
97 TP_PROTO(struct snd_soc_dapm_widget *w, int val),
102 __string( name, w->name )
111 TP_printk("widget=%s val=%d", __get_str(name),
115 DEFINE_EVENT(snd_soc_dapm_widget, snd_soc_dapm_widget_power,
117 TP_PROTO(struct snd_soc_dapm_widget *w, int val),
123 DEFINE_EVENT(snd_soc_dapm_widget, snd_soc_dapm_widget_event_start,
125 TP_PROTO(struct snd_soc_dapm_widget *w, int val),
131 DEFINE_EVENT(snd_soc_dapm_widget, snd_soc_dapm_widget_event_done,
133 TP_PROTO(struct snd_soc_dapm_widget *w, int val),
139 TRACE_EVENT(snd_soc_dapm_walk_done,
141 TP_PROTO(struct snd_soc_card *card),
146 __string( name, card->name )
147 __field( int, power_checks )
148 __field( int, path_checks )
149 __field( int, neighbour_checks )
154 __entry->power_checks = card->dapm_stats.power_checks;
155 __entry->path_checks = card->dapm_stats.path_checks;
156 __entry->neighbour_checks = card->dapm_stats.neighbour_checks;
159 TP_printk("%s: checks %d power, %d path, %d neighbour",
160 __get_str(name), (int)__entry->power_checks,
161 (int)__entry->path_checks, (int)__entry->neighbour_checks)
164 TRACE_EVENT(snd_soc_dapm_path,
166 TP_PROTO(struct snd_soc_dapm_widget *widget,
167 enum snd_soc_dapm_direction dir,
168 struct snd_soc_dapm_path *path),
170 TP_ARGS(widget, dir, path),
173 __string( wname, widget->name )
174 __string( pname, path->name ? path->name : DAPM_DIRECT)
175 __string( pnname, path->node[dir]->name )
176 __field( int, path_node )
177 __field( int, path_connect )
178 __field( int, path_dir )
184 __assign_str(pnname);
185 __entry->path_connect = path->connect;
186 __entry->path_node = (long)path->node[dir];
187 __entry->path_dir = dir;
190 TP_printk("%c%s %s %s %s %s",
191 (int) __entry->path_node &&
192 (int) __entry->path_connect ? '*' : ' ',
193 __get_str(wname), DAPM_ARROW(__entry->path_dir),
194 __get_str(pname), DAPM_ARROW(__entry->path_dir),
198 TRACE_EVENT(snd_soc_dapm_connected,
200 TP_PROTO(int paths, int stream),
202 TP_ARGS(paths, stream),
205 __field( int, paths )
206 __field( int, stream )
210 __entry->paths = paths;
211 __entry->stream = stream;
214 TP_printk("%s: found %d paths",
215 __entry->stream ? "capture" : "playback", __entry->paths)
218 TRACE_EVENT(snd_soc_jack_irq,
220 TP_PROTO(const char *name),
225 __string( name, name )
232 TP_printk("%s", __get_str(name))
235 TRACE_EVENT(snd_soc_jack_report,
237 TP_PROTO(struct snd_soc_jack *jack, int mask, int val),
239 TP_ARGS(jack, mask, val),
242 __string( name, jack->jack->id )
249 __entry->mask = mask;
253 TP_printk("jack=%s %x/%x", __get_str(name), (int)__entry->val,
257 TRACE_EVENT(snd_soc_jack_notify,
259 TP_PROTO(struct snd_soc_jack *jack, int val),
264 __string( name, jack->jack->id )
273 TP_printk("jack=%s %x", __get_str(name), (int)__entry->val)
276 #endif /* _TRACE_ASOC_H */
278 /* This part must be outside protection */
279 #include <trace/define_trace.h>