virtgpu_trace.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #if !defined(_VIRTGPU_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ)
  3. #define _VIRTGPU_TRACE_H_
  4. #include <linux/tracepoint.h>
  5. #undef TRACE_SYSTEM
  6. #define TRACE_SYSTEM virtio_gpu
  7. #define TRACE_INCLUDE_FILE virtgpu_trace
  8. DECLARE_EVENT_CLASS(virtio_gpu_cmd,
  9. TP_PROTO(struct virtqueue *vq, struct virtio_gpu_ctrl_hdr *hdr),
  10. TP_ARGS(vq, hdr),
  11. TP_STRUCT__entry(
  12. __field(int, dev)
  13. __field(unsigned int, vq)
  14. __field(const char *, name)
  15. __field(u32, type)
  16. __field(u32, flags)
  17. __field(u64, fence_id)
  18. __field(u32, ctx_id)
  19. ),
  20. TP_fast_assign(
  21. __entry->dev = vq->vdev->index;
  22. __entry->vq = vq->index;
  23. __entry->name = vq->name;
  24. __entry->type = le32_to_cpu(hdr->type);
  25. __entry->flags = le32_to_cpu(hdr->flags);
  26. __entry->fence_id = le64_to_cpu(hdr->fence_id);
  27. __entry->ctx_id = le32_to_cpu(hdr->ctx_id);
  28. ),
  29. TP_printk("vdev=%d vq=%u name=%s type=0x%x flags=0x%x fence_id=%llu ctx_id=%u",
  30. __entry->dev, __entry->vq, __entry->name,
  31. __entry->type, __entry->flags, __entry->fence_id,
  32. __entry->ctx_id)
  33. );
  34. DEFINE_EVENT(virtio_gpu_cmd, virtio_gpu_cmd_queue,
  35. TP_PROTO(struct virtqueue *vq, struct virtio_gpu_ctrl_hdr *hdr),
  36. TP_ARGS(vq, hdr)
  37. );
  38. DEFINE_EVENT(virtio_gpu_cmd, virtio_gpu_cmd_response,
  39. TP_PROTO(struct virtqueue *vq, struct virtio_gpu_ctrl_hdr *hdr),
  40. TP_ARGS(vq, hdr)
  41. );
  42. #endif
  43. #undef TRACE_INCLUDE_PATH
  44. #define TRACE_INCLUDE_PATH ../../drivers/gpu/drm/virtio
  45. #include <trace/define_trace.h>