1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 #ifndef _LINUX_VIRTIO_SCSI_H
28 #define _LINUX_VIRTIO_SCSI_H
29
30 #include <linux/virtio_types.h>
31
32
33 #define VIRTIO_SCSI_CDB_DEFAULT_SIZE 32
34 #define VIRTIO_SCSI_SENSE_DEFAULT_SIZE 96
35
36 #ifndef VIRTIO_SCSI_CDB_SIZE
37 #define VIRTIO_SCSI_CDB_SIZE VIRTIO_SCSI_CDB_DEFAULT_SIZE
38 #endif
39 #ifndef VIRTIO_SCSI_SENSE_SIZE
40 #define VIRTIO_SCSI_SENSE_SIZE VIRTIO_SCSI_SENSE_DEFAULT_SIZE
41 #endif
42
43
44 struct virtio_scsi_cmd_req {
45 __u8 lun[8];
46 __virtio64 tag;
47 __u8 task_attr;
48 __u8 prio;
49 __u8 crn;
50 __u8 cdb[VIRTIO_SCSI_CDB_SIZE];
51 } __attribute__((packed));
52
53
54 struct virtio_scsi_cmd_req_pi {
55 __u8 lun[8];
56 __virtio64 tag;
57 __u8 task_attr;
58 __u8 prio;
59 __u8 crn;
60 __virtio32 pi_bytesout;
61 __virtio32 pi_bytesin;
62 __u8 cdb[VIRTIO_SCSI_CDB_SIZE];
63 } __attribute__((packed));
64
65
66 struct virtio_scsi_cmd_resp {
67 __virtio32 sense_len;
68 __virtio32 resid;
69 __virtio16 status_qualifier;
70 __u8 status;
71 __u8 response;
72 __u8 sense[VIRTIO_SCSI_SENSE_SIZE];
73 } __attribute__((packed));
74
75
76 struct virtio_scsi_ctrl_tmf_req {
77 __virtio32 type;
78 __virtio32 subtype;
79 __u8 lun[8];
80 __virtio64 tag;
81 } __attribute__((packed));
82
83 struct virtio_scsi_ctrl_tmf_resp {
84 __u8 response;
85 } __attribute__((packed));
86
87
88 struct virtio_scsi_ctrl_an_req {
89 __virtio32 type;
90 __u8 lun[8];
91 __virtio32 event_requested;
92 } __attribute__((packed));
93
94 struct virtio_scsi_ctrl_an_resp {
95 __virtio32 event_actual;
96 __u8 response;
97 } __attribute__((packed));
98
99 struct virtio_scsi_event {
100 __virtio32 event;
101 __u8 lun[8];
102 __virtio32 reason;
103 } __attribute__((packed));
104
105 struct virtio_scsi_config {
106 __u32 num_queues;
107 __u32 seg_max;
108 __u32 max_sectors;
109 __u32 cmd_per_lun;
110 __u32 event_info_size;
111 __u32 sense_size;
112 __u32 cdb_size;
113 __u16 max_channel;
114 __u16 max_target;
115 __u32 max_lun;
116 } __attribute__((packed));
117
118
119 #define VIRTIO_SCSI_F_INOUT 0
120 #define VIRTIO_SCSI_F_HOTPLUG 1
121 #define VIRTIO_SCSI_F_CHANGE 2
122 #define VIRTIO_SCSI_F_T10_PI 3
123
124
125 #define VIRTIO_SCSI_S_OK 0
126 #define VIRTIO_SCSI_S_OVERRUN 1
127 #define VIRTIO_SCSI_S_ABORTED 2
128 #define VIRTIO_SCSI_S_BAD_TARGET 3
129 #define VIRTIO_SCSI_S_RESET 4
130 #define VIRTIO_SCSI_S_BUSY 5
131 #define VIRTIO_SCSI_S_TRANSPORT_FAILURE 6
132 #define VIRTIO_SCSI_S_TARGET_FAILURE 7
133 #define VIRTIO_SCSI_S_NEXUS_FAILURE 8
134 #define VIRTIO_SCSI_S_FAILURE 9
135 #define VIRTIO_SCSI_S_FUNCTION_SUCCEEDED 10
136 #define VIRTIO_SCSI_S_FUNCTION_REJECTED 11
137 #define VIRTIO_SCSI_S_INCORRECT_LUN 12
138
139
140 #define VIRTIO_SCSI_T_TMF 0
141 #define VIRTIO_SCSI_T_AN_QUERY 1
142 #define VIRTIO_SCSI_T_AN_SUBSCRIBE 2
143
144
145 #define VIRTIO_SCSI_T_TMF_ABORT_TASK 0
146 #define VIRTIO_SCSI_T_TMF_ABORT_TASK_SET 1
147 #define VIRTIO_SCSI_T_TMF_CLEAR_ACA 2
148 #define VIRTIO_SCSI_T_TMF_CLEAR_TASK_SET 3
149 #define VIRTIO_SCSI_T_TMF_I_T_NEXUS_RESET 4
150 #define VIRTIO_SCSI_T_TMF_LOGICAL_UNIT_RESET 5
151 #define VIRTIO_SCSI_T_TMF_QUERY_TASK 6
152 #define VIRTIO_SCSI_T_TMF_QUERY_TASK_SET 7
153
154
155 #define VIRTIO_SCSI_T_EVENTS_MISSED 0x80000000
156 #define VIRTIO_SCSI_T_NO_EVENT 0
157 #define VIRTIO_SCSI_T_TRANSPORT_RESET 1
158 #define VIRTIO_SCSI_T_ASYNC_NOTIFY 2
159 #define VIRTIO_SCSI_T_PARAM_CHANGE 3
160
161
162 #define VIRTIO_SCSI_EVT_RESET_HARD 0
163 #define VIRTIO_SCSI_EVT_RESET_RESCAN 1
164 #define VIRTIO_SCSI_EVT_RESET_REMOVED 2
165
166 #define VIRTIO_SCSI_S_SIMPLE 0
167 #define VIRTIO_SCSI_S_ORDERED 1
168 #define VIRTIO_SCSI_S_HEAD 2
169 #define VIRTIO_SCSI_S_ACA 3
170
171
172 #endif