virtio_scsi.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. #ifndef _LINUX_VIRTIO_SCSI_H
  2. #define _LINUX_VIRTIO_SCSI_H
  3. /* This header is BSD licensed so anyone can use the definitions to implement
  4. * compatible drivers/servers. */
  5. #define VIRTIO_SCSI_CDB_SIZE 32
  6. #define VIRTIO_SCSI_SENSE_SIZE 96
  7. /* SCSI command request, followed by data-out */
  8. struct virtio_scsi_cmd_req {
  9. u8 lun[8]; /* Logical Unit Number */
  10. u64 tag; /* Command identifier */
  11. u8 task_attr; /* Task attribute */
  12. u8 prio;
  13. u8 crn;
  14. u8 cdb[VIRTIO_SCSI_CDB_SIZE];
  15. } __packed;
  16. /* Response, followed by sense data and data-in */
  17. struct virtio_scsi_cmd_resp {
  18. u32 sense_len; /* Sense data length */
  19. u32 resid; /* Residual bytes in data buffer */
  20. u16 status_qualifier; /* Status qualifier */
  21. u8 status; /* Command completion status */
  22. u8 response; /* Response values */
  23. u8 sense[VIRTIO_SCSI_SENSE_SIZE];
  24. } __packed;
  25. /* Task Management Request */
  26. struct virtio_scsi_ctrl_tmf_req {
  27. u32 type;
  28. u32 subtype;
  29. u8 lun[8];
  30. u64 tag;
  31. } __packed;
  32. struct virtio_scsi_ctrl_tmf_resp {
  33. u8 response;
  34. } __packed;
  35. /* Asynchronous notification query/subscription */
  36. struct virtio_scsi_ctrl_an_req {
  37. u32 type;
  38. u8 lun[8];
  39. u32 event_requested;
  40. } __packed;
  41. struct virtio_scsi_ctrl_an_resp {
  42. u32 event_actual;
  43. u8 response;
  44. } __packed;
  45. struct virtio_scsi_event {
  46. u32 event;
  47. u8 lun[8];
  48. u32 reason;
  49. } __packed;
  50. struct virtio_scsi_config {
  51. u32 num_queues;
  52. u32 seg_max;
  53. u32 max_sectors;
  54. u32 cmd_per_lun;
  55. u32 event_info_size;
  56. u32 sense_size;
  57. u32 cdb_size;
  58. u16 max_channel;
  59. u16 max_target;
  60. u32 max_lun;
  61. } __packed;
  62. /* Response codes */
  63. #define VIRTIO_SCSI_S_OK 0
  64. #define VIRTIO_SCSI_S_OVERRUN 1
  65. #define VIRTIO_SCSI_S_ABORTED 2
  66. #define VIRTIO_SCSI_S_BAD_TARGET 3
  67. #define VIRTIO_SCSI_S_RESET 4
  68. #define VIRTIO_SCSI_S_BUSY 5
  69. #define VIRTIO_SCSI_S_TRANSPORT_FAILURE 6
  70. #define VIRTIO_SCSI_S_TARGET_FAILURE 7
  71. #define VIRTIO_SCSI_S_NEXUS_FAILURE 8
  72. #define VIRTIO_SCSI_S_FAILURE 9
  73. #define VIRTIO_SCSI_S_FUNCTION_SUCCEEDED 10
  74. #define VIRTIO_SCSI_S_FUNCTION_REJECTED 11
  75. #define VIRTIO_SCSI_S_INCORRECT_LUN 12
  76. /* Controlq type codes. */
  77. #define VIRTIO_SCSI_T_TMF 0
  78. #define VIRTIO_SCSI_T_AN_QUERY 1
  79. #define VIRTIO_SCSI_T_AN_SUBSCRIBE 2
  80. /* Valid TMF subtypes. */
  81. #define VIRTIO_SCSI_T_TMF_ABORT_TASK 0
  82. #define VIRTIO_SCSI_T_TMF_ABORT_TASK_SET 1
  83. #define VIRTIO_SCSI_T_TMF_CLEAR_ACA 2
  84. #define VIRTIO_SCSI_T_TMF_CLEAR_TASK_SET 3
  85. #define VIRTIO_SCSI_T_TMF_I_T_NEXUS_RESET 4
  86. #define VIRTIO_SCSI_T_TMF_LOGICAL_UNIT_RESET 5
  87. #define VIRTIO_SCSI_T_TMF_QUERY_TASK 6
  88. #define VIRTIO_SCSI_T_TMF_QUERY_TASK_SET 7
  89. /* Events. */
  90. #define VIRTIO_SCSI_T_EVENTS_MISSED 0x80000000
  91. #define VIRTIO_SCSI_T_NO_EVENT 0
  92. #define VIRTIO_SCSI_T_TRANSPORT_RESET 1
  93. #define VIRTIO_SCSI_T_ASYNC_NOTIFY 2
  94. #define VIRTIO_SCSI_S_SIMPLE 0
  95. #define VIRTIO_SCSI_S_ORDERED 1
  96. #define VIRTIO_SCSI_S_HEAD 2
  97. #define VIRTIO_SCSI_S_ACA 3
  98. #endif /* _LINUX_VIRTIO_SCSI_H */