asoc.h 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410
  1. #undef TRACE_SYSTEM
  2. #define TRACE_SYSTEM asoc
  3. #if !defined(_TRACE_ASOC_H) || defined(TRACE_HEADER_MULTI_READ)
  4. #define _TRACE_ASOC_H
  5. #include <linux/ktime.h>
  6. #include <linux/tracepoint.h>
  7. #define DAPM_DIRECT "(direct)"
  8. struct snd_soc_jack;
  9. struct snd_soc_codec;
  10. struct snd_soc_platform;
  11. struct snd_soc_card;
  12. struct snd_soc_dapm_widget;
  13. /*
  14. * Log register events
  15. */
  16. DECLARE_EVENT_CLASS(snd_soc_reg,
  17. TP_PROTO(struct snd_soc_codec *codec, unsigned int reg,
  18. unsigned int val),
  19. TP_ARGS(codec, reg, val),
  20. TP_STRUCT__entry(
  21. __string( name, codec->name )
  22. __field( int, id )
  23. __field( unsigned int, reg )
  24. __field( unsigned int, val )
  25. ),
  26. TP_fast_assign(
  27. __assign_str(name, codec->name);
  28. __entry->id = codec->id;
  29. __entry->reg = reg;
  30. __entry->val = val;
  31. ),
  32. TP_printk("codec=%s.%d reg=%x val=%x", __get_str(name),
  33. (int)__entry->id, (unsigned int)__entry->reg,
  34. (unsigned int)__entry->val)
  35. );
  36. DEFINE_EVENT(snd_soc_reg, snd_soc_reg_write,
  37. TP_PROTO(struct snd_soc_codec *codec, unsigned int reg,
  38. unsigned int val),
  39. TP_ARGS(codec, reg, val)
  40. );
  41. DEFINE_EVENT(snd_soc_reg, snd_soc_reg_read,
  42. TP_PROTO(struct snd_soc_codec *codec, unsigned int reg,
  43. unsigned int val),
  44. TP_ARGS(codec, reg, val)
  45. );
  46. DECLARE_EVENT_CLASS(snd_soc_preg,
  47. TP_PROTO(struct snd_soc_platform *platform, unsigned int reg,
  48. unsigned int val),
  49. TP_ARGS(platform, reg, val),
  50. TP_STRUCT__entry(
  51. __string( name, platform->name )
  52. __field( int, id )
  53. __field( unsigned int, reg )
  54. __field( unsigned int, val )
  55. ),
  56. TP_fast_assign(
  57. __assign_str(name, platform->name);
  58. __entry->id = platform->id;
  59. __entry->reg = reg;
  60. __entry->val = val;
  61. ),
  62. TP_printk("platform=%s.%d reg=%x val=%x", __get_str(name),
  63. (int)__entry->id, (unsigned int)__entry->reg,
  64. (unsigned int)__entry->val)
  65. );
  66. DEFINE_EVENT(snd_soc_preg, snd_soc_preg_write,
  67. TP_PROTO(struct snd_soc_platform *platform, unsigned int reg,
  68. unsigned int val),
  69. TP_ARGS(platform, reg, val)
  70. );
  71. DEFINE_EVENT(snd_soc_preg, snd_soc_preg_read,
  72. TP_PROTO(struct snd_soc_platform *platform, unsigned int reg,
  73. unsigned int val),
  74. TP_ARGS(platform, reg, val)
  75. );
  76. DECLARE_EVENT_CLASS(snd_soc_card,
  77. TP_PROTO(struct snd_soc_card *card, int val),
  78. TP_ARGS(card, val),
  79. TP_STRUCT__entry(
  80. __string( name, card->name )
  81. __field( int, val )
  82. ),
  83. TP_fast_assign(
  84. __assign_str(name, card->name);
  85. __entry->val = val;
  86. ),
  87. TP_printk("card=%s val=%d", __get_str(name), (int)__entry->val)
  88. );
  89. DEFINE_EVENT(snd_soc_card, snd_soc_bias_level_start,
  90. TP_PROTO(struct snd_soc_card *card, int val),
  91. TP_ARGS(card, val)
  92. );
  93. DEFINE_EVENT(snd_soc_card, snd_soc_bias_level_done,
  94. TP_PROTO(struct snd_soc_card *card, int val),
  95. TP_ARGS(card, val)
  96. );
  97. DECLARE_EVENT_CLASS(snd_soc_dapm_basic,
  98. TP_PROTO(struct snd_soc_card *card),
  99. TP_ARGS(card),
  100. TP_STRUCT__entry(
  101. __string( name, card->name )
  102. ),
  103. TP_fast_assign(
  104. __assign_str(name, card->name);
  105. ),
  106. TP_printk("card=%s", __get_str(name))
  107. );
  108. DEFINE_EVENT(snd_soc_dapm_basic, snd_soc_dapm_start,
  109. TP_PROTO(struct snd_soc_card *card),
  110. TP_ARGS(card)
  111. );
  112. DEFINE_EVENT(snd_soc_dapm_basic, snd_soc_dapm_done,
  113. TP_PROTO(struct snd_soc_card *card),
  114. TP_ARGS(card)
  115. );
  116. DECLARE_EVENT_CLASS(snd_soc_dapm_widget,
  117. TP_PROTO(struct snd_soc_dapm_widget *w, int val),
  118. TP_ARGS(w, val),
  119. TP_STRUCT__entry(
  120. __string( name, w->name )
  121. __field( int, val )
  122. ),
  123. TP_fast_assign(
  124. __assign_str(name, w->name);
  125. __entry->val = val;
  126. ),
  127. TP_printk("widget=%s val=%d", __get_str(name),
  128. (int)__entry->val)
  129. );
  130. DEFINE_EVENT(snd_soc_dapm_widget, snd_soc_dapm_widget_power,
  131. TP_PROTO(struct snd_soc_dapm_widget *w, int val),
  132. TP_ARGS(w, val)
  133. );
  134. DEFINE_EVENT(snd_soc_dapm_widget, snd_soc_dapm_widget_event_start,
  135. TP_PROTO(struct snd_soc_dapm_widget *w, int val),
  136. TP_ARGS(w, val)
  137. );
  138. DEFINE_EVENT(snd_soc_dapm_widget, snd_soc_dapm_widget_event_done,
  139. TP_PROTO(struct snd_soc_dapm_widget *w, int val),
  140. TP_ARGS(w, val)
  141. );
  142. TRACE_EVENT(snd_soc_dapm_walk_done,
  143. TP_PROTO(struct snd_soc_card *card),
  144. TP_ARGS(card),
  145. TP_STRUCT__entry(
  146. __string( name, card->name )
  147. __field( int, power_checks )
  148. __field( int, path_checks )
  149. __field( int, neighbour_checks )
  150. ),
  151. TP_fast_assign(
  152. __assign_str(name, card->name);
  153. __entry->power_checks = card->dapm_stats.power_checks;
  154. __entry->path_checks = card->dapm_stats.path_checks;
  155. __entry->neighbour_checks = card->dapm_stats.neighbour_checks;
  156. ),
  157. TP_printk("%s: checks %d power, %d path, %d neighbour",
  158. __get_str(name), (int)__entry->power_checks,
  159. (int)__entry->path_checks, (int)__entry->neighbour_checks)
  160. );
  161. TRACE_EVENT(snd_soc_dapm_output_path,
  162. TP_PROTO(struct snd_soc_dapm_widget *widget,
  163. struct snd_soc_dapm_path *path),
  164. TP_ARGS(widget, path),
  165. TP_STRUCT__entry(
  166. __string( wname, widget->name )
  167. __string( pname, path->name ? path->name : DAPM_DIRECT)
  168. __string( psname, path->sink->name )
  169. __field( int, path_sink )
  170. __field( int, path_connect )
  171. ),
  172. TP_fast_assign(
  173. __assign_str(wname, widget->name);
  174. __assign_str(pname, path->name ? path->name : DAPM_DIRECT);
  175. __assign_str(psname, path->sink->name);
  176. __entry->path_connect = path->connect;
  177. __entry->path_sink = (long)path->sink;
  178. ),
  179. TP_printk("%c%s -> %s -> %s\n",
  180. (int) __entry->path_sink &&
  181. (int) __entry->path_connect ? '*' : ' ',
  182. __get_str(wname), __get_str(pname), __get_str(psname))
  183. );
  184. TRACE_EVENT(snd_soc_dapm_input_path,
  185. TP_PROTO(struct snd_soc_dapm_widget *widget,
  186. struct snd_soc_dapm_path *path),
  187. TP_ARGS(widget, path),
  188. TP_STRUCT__entry(
  189. __string( wname, widget->name )
  190. __string( pname, path->name ? path->name : DAPM_DIRECT)
  191. __string( psname, path->source->name )
  192. __field( int, path_source )
  193. __field( int, path_connect )
  194. ),
  195. TP_fast_assign(
  196. __assign_str(wname, widget->name);
  197. __assign_str(pname, path->name ? path->name : DAPM_DIRECT);
  198. __assign_str(psname, path->source->name);
  199. __entry->path_connect = path->connect;
  200. __entry->path_source = (long)path->source;
  201. ),
  202. TP_printk("%c%s <- %s <- %s\n",
  203. (int) __entry->path_source &&
  204. (int) __entry->path_connect ? '*' : ' ',
  205. __get_str(wname), __get_str(pname), __get_str(psname))
  206. );
  207. TRACE_EVENT(snd_soc_dapm_connected,
  208. TP_PROTO(int paths, int stream),
  209. TP_ARGS(paths, stream),
  210. TP_STRUCT__entry(
  211. __field( int, paths )
  212. __field( int, stream )
  213. ),
  214. TP_fast_assign(
  215. __entry->paths = paths;
  216. __entry->stream = stream;
  217. ),
  218. TP_printk("%s: found %d paths\n",
  219. __entry->stream ? "capture" : "playback", __entry->paths)
  220. );
  221. TRACE_EVENT(snd_soc_jack_irq,
  222. TP_PROTO(const char *name),
  223. TP_ARGS(name),
  224. TP_STRUCT__entry(
  225. __string( name, name )
  226. ),
  227. TP_fast_assign(
  228. __assign_str(name, name);
  229. ),
  230. TP_printk("%s", __get_str(name))
  231. );
  232. TRACE_EVENT(snd_soc_jack_report,
  233. TP_PROTO(struct snd_soc_jack *jack, int mask, int val),
  234. TP_ARGS(jack, mask, val),
  235. TP_STRUCT__entry(
  236. __string( name, jack->jack->name )
  237. __field( int, mask )
  238. __field( int, val )
  239. ),
  240. TP_fast_assign(
  241. __assign_str(name, jack->jack->name);
  242. __entry->mask = mask;
  243. __entry->val = val;
  244. ),
  245. TP_printk("jack=%s %x/%x", __get_str(name), (int)__entry->val,
  246. (int)__entry->mask)
  247. );
  248. TRACE_EVENT(snd_soc_jack_notify,
  249. TP_PROTO(struct snd_soc_jack *jack, int val),
  250. TP_ARGS(jack, val),
  251. TP_STRUCT__entry(
  252. __string( name, jack->jack->name )
  253. __field( int, val )
  254. ),
  255. TP_fast_assign(
  256. __assign_str(name, jack->jack->name);
  257. __entry->val = val;
  258. ),
  259. TP_printk("jack=%s %x", __get_str(name), (int)__entry->val)
  260. );
  261. TRACE_EVENT(snd_soc_cache_sync,
  262. TP_PROTO(struct snd_soc_codec *codec, const char *type,
  263. const char *status),
  264. TP_ARGS(codec, type, status),
  265. TP_STRUCT__entry(
  266. __string( name, codec->name )
  267. __string( status, status )
  268. __string( type, type )
  269. __field( int, id )
  270. ),
  271. TP_fast_assign(
  272. __assign_str(name, codec->name);
  273. __assign_str(status, status);
  274. __assign_str(type, type);
  275. __entry->id = codec->id;
  276. ),
  277. TP_printk("codec=%s.%d type=%s status=%s", __get_str(name),
  278. (int)__entry->id, __get_str(type), __get_str(status))
  279. );
  280. #endif /* _TRACE_ASOC_H */
  281. /* This part must be outside protection */
  282. #include <trace/define_trace.h>