sd_trace.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Copyright (C) 2022 Western Digital Corporation or its affiliates.
  4. */
  5. #undef TRACE_SYSTEM
  6. #define TRACE_SYSTEM sd
  7. #undef TRACE_INCLUDE_FILE
  8. #define TRACE_INCLUDE_FILE sd_trace
  9. #if !defined(_SD_TRACE_H) || defined(TRACE_HEADER_MULTI_READ)
  10. #include <scsi/scsi_cmnd.h>
  11. #include <scsi/scsi_host.h>
  12. #include <linux/tracepoint.h>
  13. TRACE_EVENT(scsi_prepare_zone_append,
  14. TP_PROTO(struct scsi_cmnd *cmnd, sector_t lba,
  15. unsigned int wp_offset),
  16. TP_ARGS(cmnd, lba, wp_offset),
  17. TP_STRUCT__entry(
  18. __field( unsigned int, host_no )
  19. __field( unsigned int, channel )
  20. __field( unsigned int, id )
  21. __field( unsigned int, lun )
  22. __field( sector_t, lba )
  23. __field( unsigned int, wp_offset )
  24. ),
  25. TP_fast_assign(
  26. __entry->host_no = cmnd->device->host->host_no;
  27. __entry->channel = cmnd->device->channel;
  28. __entry->id = cmnd->device->id;
  29. __entry->lun = cmnd->device->lun;
  30. __entry->lba = lba;
  31. __entry->wp_offset = wp_offset;
  32. ),
  33. TP_printk("host_no=%u, channel=%u id=%u lun=%u lba=%llu wp_offset=%u",
  34. __entry->host_no, __entry->channel, __entry->id,
  35. __entry->lun, __entry->lba, __entry->wp_offset)
  36. );
  37. TRACE_EVENT(scsi_zone_wp_update,
  38. TP_PROTO(struct scsi_cmnd *cmnd, sector_t rq_sector,
  39. unsigned int wp_offset, unsigned int good_bytes),
  40. TP_ARGS(cmnd, rq_sector, wp_offset, good_bytes),
  41. TP_STRUCT__entry(
  42. __field( unsigned int, host_no )
  43. __field( unsigned int, channel )
  44. __field( unsigned int, id )
  45. __field( unsigned int, lun )
  46. __field( sector_t, rq_sector )
  47. __field( unsigned int, wp_offset )
  48. __field( unsigned int, good_bytes )
  49. ),
  50. TP_fast_assign(
  51. __entry->host_no = cmnd->device->host->host_no;
  52. __entry->channel = cmnd->device->channel;
  53. __entry->id = cmnd->device->id;
  54. __entry->lun = cmnd->device->lun;
  55. __entry->rq_sector = rq_sector;
  56. __entry->wp_offset = wp_offset;
  57. __entry->good_bytes = good_bytes;
  58. ),
  59. TP_printk("host_no=%u, channel=%u id=%u lun=%u rq_sector=%llu" \
  60. " wp_offset=%u good_bytes=%u",
  61. __entry->host_no, __entry->channel, __entry->id,
  62. __entry->lun, __entry->rq_sector, __entry->wp_offset,
  63. __entry->good_bytes)
  64. );
  65. #endif /* _SD_TRACE_H */
  66. /* This part must be outside protection */
  67. #undef TRACE_INCLUDE_PATH
  68. #define TRACE_INCLUDE_PATH ../../drivers/scsi
  69. #include <trace/define_trace.h>