v3d_trace.h 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /* Copyright (C) 2015-2018 Broadcom */
  3. #if !defined(_V3D_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ)
  4. #define _V3D_TRACE_H_
  5. #include <linux/stringify.h>
  6. #include <linux/types.h>
  7. #include <linux/tracepoint.h>
  8. #undef TRACE_SYSTEM
  9. #define TRACE_SYSTEM v3d
  10. #define TRACE_INCLUDE_FILE v3d_trace
  11. TRACE_EVENT(v3d_submit_cl_ioctl,
  12. TP_PROTO(struct drm_device *dev, u32 ct1qba, u32 ct1qea),
  13. TP_ARGS(dev, ct1qba, ct1qea),
  14. TP_STRUCT__entry(
  15. __field(u32, dev)
  16. __field(u32, ct1qba)
  17. __field(u32, ct1qea)
  18. ),
  19. TP_fast_assign(
  20. __entry->dev = dev->primary->index;
  21. __entry->ct1qba = ct1qba;
  22. __entry->ct1qea = ct1qea;
  23. ),
  24. TP_printk("dev=%u, RCL 0x%08x..0x%08x",
  25. __entry->dev,
  26. __entry->ct1qba,
  27. __entry->ct1qea)
  28. );
  29. TRACE_EVENT(v3d_submit_cl,
  30. TP_PROTO(struct drm_device *dev, bool is_render,
  31. uint64_t seqno,
  32. u32 ctnqba, u32 ctnqea),
  33. TP_ARGS(dev, is_render, seqno, ctnqba, ctnqea),
  34. TP_STRUCT__entry(
  35. __field(u32, dev)
  36. __field(bool, is_render)
  37. __field(u64, seqno)
  38. __field(u32, ctnqba)
  39. __field(u32, ctnqea)
  40. ),
  41. TP_fast_assign(
  42. __entry->dev = dev->primary->index;
  43. __entry->is_render = is_render;
  44. __entry->seqno = seqno;
  45. __entry->ctnqba = ctnqba;
  46. __entry->ctnqea = ctnqea;
  47. ),
  48. TP_printk("dev=%u, %s, seqno=%llu, 0x%08x..0x%08x",
  49. __entry->dev,
  50. __entry->is_render ? "RCL" : "BCL",
  51. __entry->seqno,
  52. __entry->ctnqba,
  53. __entry->ctnqea)
  54. );
  55. TRACE_EVENT(v3d_bcl_irq,
  56. TP_PROTO(struct drm_device *dev,
  57. uint64_t seqno),
  58. TP_ARGS(dev, seqno),
  59. TP_STRUCT__entry(
  60. __field(u32, dev)
  61. __field(u64, seqno)
  62. ),
  63. TP_fast_assign(
  64. __entry->dev = dev->primary->index;
  65. __entry->seqno = seqno;
  66. ),
  67. TP_printk("dev=%u, seqno=%llu",
  68. __entry->dev,
  69. __entry->seqno)
  70. );
  71. TRACE_EVENT(v3d_rcl_irq,
  72. TP_PROTO(struct drm_device *dev,
  73. uint64_t seqno),
  74. TP_ARGS(dev, seqno),
  75. TP_STRUCT__entry(
  76. __field(u32, dev)
  77. __field(u64, seqno)
  78. ),
  79. TP_fast_assign(
  80. __entry->dev = dev->primary->index;
  81. __entry->seqno = seqno;
  82. ),
  83. TP_printk("dev=%u, seqno=%llu",
  84. __entry->dev,
  85. __entry->seqno)
  86. );
  87. TRACE_EVENT(v3d_tfu_irq,
  88. TP_PROTO(struct drm_device *dev,
  89. uint64_t seqno),
  90. TP_ARGS(dev, seqno),
  91. TP_STRUCT__entry(
  92. __field(u32, dev)
  93. __field(u64, seqno)
  94. ),
  95. TP_fast_assign(
  96. __entry->dev = dev->primary->index;
  97. __entry->seqno = seqno;
  98. ),
  99. TP_printk("dev=%u, seqno=%llu",
  100. __entry->dev,
  101. __entry->seqno)
  102. );
  103. TRACE_EVENT(v3d_csd_irq,
  104. TP_PROTO(struct drm_device *dev,
  105. uint64_t seqno),
  106. TP_ARGS(dev, seqno),
  107. TP_STRUCT__entry(
  108. __field(u32, dev)
  109. __field(u64, seqno)
  110. ),
  111. TP_fast_assign(
  112. __entry->dev = dev->primary->index;
  113. __entry->seqno = seqno;
  114. ),
  115. TP_printk("dev=%u, seqno=%llu",
  116. __entry->dev,
  117. __entry->seqno)
  118. );
  119. TRACE_EVENT(v3d_submit_tfu_ioctl,
  120. TP_PROTO(struct drm_device *dev, u32 iia),
  121. TP_ARGS(dev, iia),
  122. TP_STRUCT__entry(
  123. __field(u32, dev)
  124. __field(u32, iia)
  125. ),
  126. TP_fast_assign(
  127. __entry->dev = dev->primary->index;
  128. __entry->iia = iia;
  129. ),
  130. TP_printk("dev=%u, IIA 0x%08x",
  131. __entry->dev,
  132. __entry->iia)
  133. );
  134. TRACE_EVENT(v3d_submit_tfu,
  135. TP_PROTO(struct drm_device *dev,
  136. uint64_t seqno),
  137. TP_ARGS(dev, seqno),
  138. TP_STRUCT__entry(
  139. __field(u32, dev)
  140. __field(u64, seqno)
  141. ),
  142. TP_fast_assign(
  143. __entry->dev = dev->primary->index;
  144. __entry->seqno = seqno;
  145. ),
  146. TP_printk("dev=%u, seqno=%llu",
  147. __entry->dev,
  148. __entry->seqno)
  149. );
  150. TRACE_EVENT(v3d_submit_csd_ioctl,
  151. TP_PROTO(struct drm_device *dev, u32 cfg5, u32 cfg6),
  152. TP_ARGS(dev, cfg5, cfg6),
  153. TP_STRUCT__entry(
  154. __field(u32, dev)
  155. __field(u32, cfg5)
  156. __field(u32, cfg6)
  157. ),
  158. TP_fast_assign(
  159. __entry->dev = dev->primary->index;
  160. __entry->cfg5 = cfg5;
  161. __entry->cfg6 = cfg6;
  162. ),
  163. TP_printk("dev=%u, CFG5 0x%08x, CFG6 0x%08x",
  164. __entry->dev,
  165. __entry->cfg5,
  166. __entry->cfg6)
  167. );
  168. TRACE_EVENT(v3d_submit_csd,
  169. TP_PROTO(struct drm_device *dev,
  170. uint64_t seqno),
  171. TP_ARGS(dev, seqno),
  172. TP_STRUCT__entry(
  173. __field(u32, dev)
  174. __field(u64, seqno)
  175. ),
  176. TP_fast_assign(
  177. __entry->dev = dev->primary->index;
  178. __entry->seqno = seqno;
  179. ),
  180. TP_printk("dev=%u, seqno=%llu",
  181. __entry->dev,
  182. __entry->seqno)
  183. );
  184. TRACE_EVENT(v3d_cache_clean_begin,
  185. TP_PROTO(struct drm_device *dev),
  186. TP_ARGS(dev),
  187. TP_STRUCT__entry(
  188. __field(u32, dev)
  189. ),
  190. TP_fast_assign(
  191. __entry->dev = dev->primary->index;
  192. ),
  193. TP_printk("dev=%u",
  194. __entry->dev)
  195. );
  196. TRACE_EVENT(v3d_cache_clean_end,
  197. TP_PROTO(struct drm_device *dev),
  198. TP_ARGS(dev),
  199. TP_STRUCT__entry(
  200. __field(u32, dev)
  201. ),
  202. TP_fast_assign(
  203. __entry->dev = dev->primary->index;
  204. ),
  205. TP_printk("dev=%u",
  206. __entry->dev)
  207. );
  208. TRACE_EVENT(v3d_reset_begin,
  209. TP_PROTO(struct drm_device *dev),
  210. TP_ARGS(dev),
  211. TP_STRUCT__entry(
  212. __field(u32, dev)
  213. ),
  214. TP_fast_assign(
  215. __entry->dev = dev->primary->index;
  216. ),
  217. TP_printk("dev=%u",
  218. __entry->dev)
  219. );
  220. TRACE_EVENT(v3d_reset_end,
  221. TP_PROTO(struct drm_device *dev),
  222. TP_ARGS(dev),
  223. TP_STRUCT__entry(
  224. __field(u32, dev)
  225. ),
  226. TP_fast_assign(
  227. __entry->dev = dev->primary->index;
  228. ),
  229. TP_printk("dev=%u",
  230. __entry->dev)
  231. );
  232. #endif /* _V3D_TRACE_H_ */
  233. /* This part must be outside protection */
  234. #undef TRACE_INCLUDE_PATH
  235. #define TRACE_INCLUDE_PATH .
  236. #include <trace/define_trace.h>