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
28
29
30
31
32
33
34 #ifndef MPI_SAS_H
35 #define MPI_SAS_H
36
37
38
39
40
41 #define MPI_SASSTATUS_SUCCESS (0x00)
42 #define MPI_SASSTATUS_UNKNOWN_ERROR (0x01)
43 #define MPI_SASSTATUS_INVALID_FRAME (0x02)
44 #define MPI_SASSTATUS_UTC_BAD_DEST (0x03)
45 #define MPI_SASSTATUS_UTC_BREAK_RECEIVED (0x04)
46 #define MPI_SASSTATUS_UTC_CONNECT_RATE_NOT_SUPPORTED (0x05)
47 #define MPI_SASSTATUS_UTC_PORT_LAYER_REQUEST (0x06)
48 #define MPI_SASSTATUS_UTC_PROTOCOL_NOT_SUPPORTED (0x07)
49 #define MPI_SASSTATUS_UTC_STP_RESOURCES_BUSY (0x08)
50 #define MPI_SASSTATUS_UTC_WRONG_DESTINATION (0x09)
51 #define MPI_SASSTATUS_SHORT_INFORMATION_UNIT (0x0A)
52 #define MPI_SASSTATUS_LONG_INFORMATION_UNIT (0x0B)
53 #define MPI_SASSTATUS_XFER_RDY_INCORRECT_WRITE_DATA (0x0C)
54 #define MPI_SASSTATUS_XFER_RDY_REQUEST_OFFSET_ERROR (0x0D)
55 #define MPI_SASSTATUS_XFER_RDY_NOT_EXPECTED (0x0E)
56 #define MPI_SASSTATUS_DATA_INCORRECT_DATA_LENGTH (0x0F)
57 #define MPI_SASSTATUS_DATA_TOO_MUCH_READ_DATA (0x10)
58 #define MPI_SASSTATUS_DATA_OFFSET_ERROR (0x11)
59 #define MPI_SASSTATUS_SDSF_NAK_RECEIVED (0x12)
60 #define MPI_SASSTATUS_SDSF_CONNECTION_FAILED (0x13)
61 #define MPI_SASSTATUS_INITIATOR_RESPONSE_TIMEOUT (0x14)
62
63
64
65
66
67
68 #define MPI_SAS_DEVICE_INFO_PRODUCT_SPECIFIC (0xF0000000)
69
70 #define MPI_SAS_DEVICE_INFO_SEP (0x00004000)
71 #define MPI_SAS_DEVICE_INFO_ATAPI_DEVICE (0x00002000)
72 #define MPI_SAS_DEVICE_INFO_LSI_DEVICE (0x00001000)
73 #define MPI_SAS_DEVICE_INFO_DIRECT_ATTACH (0x00000800)
74 #define MPI_SAS_DEVICE_INFO_SSP_TARGET (0x00000400)
75 #define MPI_SAS_DEVICE_INFO_STP_TARGET (0x00000200)
76 #define MPI_SAS_DEVICE_INFO_SMP_TARGET (0x00000100)
77 #define MPI_SAS_DEVICE_INFO_SATA_DEVICE (0x00000080)
78 #define MPI_SAS_DEVICE_INFO_SSP_INITIATOR (0x00000040)
79 #define MPI_SAS_DEVICE_INFO_STP_INITIATOR (0x00000020)
80 #define MPI_SAS_DEVICE_INFO_SMP_INITIATOR (0x00000010)
81 #define MPI_SAS_DEVICE_INFO_SATA_HOST (0x00000008)
82
83 #define MPI_SAS_DEVICE_INFO_MASK_DEVICE_TYPE (0x00000007)
84 #define MPI_SAS_DEVICE_INFO_NO_DEVICE (0x00000000)
85 #define MPI_SAS_DEVICE_INFO_END_DEVICE (0x00000001)
86 #define MPI_SAS_DEVICE_INFO_EDGE_EXPANDER (0x00000002)
87 #define MPI_SAS_DEVICE_INFO_FANOUT_EXPANDER (0x00000003)
88
89
90
91
92
93
94
95
96
97
98
99
100
101 typedef struct _MSG_SMP_PASSTHROUGH_REQUEST
102 {
103 U8 PassthroughFlags;
104 U8 PhysicalPort;
105 U8 ChainOffset;
106 U8 Function;
107 U16 RequestDataLength;
108 U8 ConnectionRate;
109 U8 MsgFlags;
110 U32 MsgContext;
111 U32 Reserved1;
112 U64 SASAddress;
113 U32 Reserved2;
114 U32 Reserved3;
115 SGE_SIMPLE_UNION SGL;
116 } MSG_SMP_PASSTHROUGH_REQUEST, MPI_POINTER PTR_MSG_SMP_PASSTHROUGH_REQUEST,
117 SmpPassthroughRequest_t, MPI_POINTER pSmpPassthroughRequest_t;
118
119
120 #define MPI_SMP_PT_REQ_PT_FLAGS_IMMEDIATE (0x80)
121
122
123 #define MPI_SMP_PT_REQ_CONNECT_RATE_NEGOTIATED (0x00)
124 #define MPI_SMP_PT_REQ_CONNECT_RATE_1_5 (0x08)
125 #define MPI_SMP_PT_REQ_CONNECT_RATE_3_0 (0x09)
126
127
128
129 typedef struct _MSG_SMP_PASSTHROUGH_REPLY
130 {
131 U8 PassthroughFlags;
132 U8 PhysicalPort;
133 U8 MsgLength;
134 U8 Function;
135 U16 ResponseDataLength;
136 U8 Reserved1;
137 U8 MsgFlags;
138 U32 MsgContext;
139 U8 Reserved2;
140 U8 SASStatus;
141 U16 IOCStatus;
142 U32 IOCLogInfo;
143 U32 Reserved3;
144 U8 ResponseData[4];
145 } MSG_SMP_PASSTHROUGH_REPLY, MPI_POINTER PTR_MSG_SMP_PASSTHROUGH_REPLY,
146 SmpPassthroughReply_t, MPI_POINTER pSmpPassthroughReply_t;
147
148 #define MPI_SMP_PT_REPLY_PT_FLAGS_IMMEDIATE (0x80)
149
150
151
152
153
154
155 typedef struct _MSG_SATA_PASSTHROUGH_REQUEST
156 {
157 U8 TargetID;
158 U8 Bus;
159 U8 ChainOffset;
160 U8 Function;
161 U16 PassthroughFlags;
162 U8 ConnectionRate;
163 U8 MsgFlags;
164 U32 MsgContext;
165 U32 Reserved1;
166 U32 Reserved2;
167 U32 Reserved3;
168 U32 DataLength;
169 U8 CommandFIS[20];
170 SGE_SIMPLE_UNION SGL;
171 } MSG_SATA_PASSTHROUGH_REQUEST, MPI_POINTER PTR_MSG_SATA_PASSTHROUGH_REQUEST,
172 SataPassthroughRequest_t, MPI_POINTER pSataPassthroughRequest_t;
173
174
175 #define MPI_SATA_PT_REQ_PT_FLAGS_RESET_DEVICE (0x0200)
176 #define MPI_SATA_PT_REQ_PT_FLAGS_EXECUTE_DIAG (0x0100)
177 #define MPI_SATA_PT_REQ_PT_FLAGS_DMA_QUEUED (0x0080)
178 #define MPI_SATA_PT_REQ_PT_FLAGS_PACKET_COMMAND (0x0040)
179 #define MPI_SATA_PT_REQ_PT_FLAGS_DMA (0x0020)
180 #define MPI_SATA_PT_REQ_PT_FLAGS_PIO (0x0010)
181 #define MPI_SATA_PT_REQ_PT_FLAGS_UNSPECIFIED_VU (0x0004)
182 #define MPI_SATA_PT_REQ_PT_FLAGS_WRITE (0x0002)
183 #define MPI_SATA_PT_REQ_PT_FLAGS_READ (0x0001)
184
185
186 #define MPI_SATA_PT_REQ_CONNECT_RATE_NEGOTIATED (0x00)
187 #define MPI_SATA_PT_REQ_CONNECT_RATE_1_5 (0x08)
188 #define MPI_SATA_PT_REQ_CONNECT_RATE_3_0 (0x09)
189
190
191
192 typedef struct _MSG_SATA_PASSTHROUGH_REPLY
193 {
194 U8 TargetID;
195 U8 Bus;
196 U8 MsgLength;
197 U8 Function;
198 U16 PassthroughFlags;
199 U8 Reserved1;
200 U8 MsgFlags;
201 U32 MsgContext;
202 U8 Reserved2;
203 U8 SASStatus;
204 U16 IOCStatus;
205 U32 IOCLogInfo;
206 U8 StatusFIS[20];
207 U32 StatusControlRegisters;
208 U32 TransferCount;
209 } MSG_SATA_PASSTHROUGH_REPLY, MPI_POINTER PTR_MSG_SATA_PASSTHROUGH_REPLY,
210 SataPassthroughReply_t, MPI_POINTER pSataPassthroughReply_t;
211
212
213
214
215
216
217
218
219 typedef struct _MSG_SAS_IOUNIT_CONTROL_REQUEST
220 {
221 U8 Operation;
222 U8 Reserved1;
223 U8 ChainOffset;
224 U8 Function;
225 U16 DevHandle;
226 U8 IOCParameter;
227 U8 MsgFlags;
228 U32 MsgContext;
229 U8 TargetID;
230 U8 Bus;
231 U8 PhyNum;
232 U8 PrimFlags;
233 U32 Primitive;
234 U64 SASAddress;
235 U32 IOCParameterValue;
236 } MSG_SAS_IOUNIT_CONTROL_REQUEST, MPI_POINTER PTR_MSG_SAS_IOUNIT_CONTROL_REQUEST,
237 SasIoUnitControlRequest_t, MPI_POINTER pSasIoUnitControlRequest_t;
238
239
240 #define MPI_SAS_OP_CLEAR_NOT_PRESENT (0x01)
241 #define MPI_SAS_OP_CLEAR_ALL_PERSISTENT (0x02)
242 #define MPI_SAS_OP_PHY_LINK_RESET (0x06)
243 #define MPI_SAS_OP_PHY_HARD_RESET (0x07)
244 #define MPI_SAS_OP_PHY_CLEAR_ERROR_LOG (0x08)
245 #define MPI_SAS_OP_MAP_CURRENT (0x09)
246 #define MPI_SAS_OP_SEND_PRIMITIVE (0x0A)
247 #define MPI_SAS_OP_FORCE_FULL_DISCOVERY (0x0B)
248 #define MPI_SAS_OP_TRANSMIT_PORT_SELECT_SIGNAL (0x0C)
249 #define MPI_SAS_OP_TRANSMIT_REMOVE_DEVICE (0x0D)
250 #define MPI_SAS_OP_REMOVE_DEVICE (0x0D)
251 #define MPI_SAS_OP_SET_IOC_PARAMETER (0x0E)
252 #define MPI_SAS_OP_PRODUCT_SPECIFIC_MIN (0x80)
253
254
255 #define MPI_SAS_PRIMFLAGS_SINGLE (0x08)
256 #define MPI_SAS_PRIMFLAGS_TRIPLE (0x02)
257 #define MPI_SAS_PRIMFLAGS_REDUNDANT (0x01)
258
259
260
261 typedef struct _MSG_SAS_IOUNIT_CONTROL_REPLY
262 {
263 U8 Operation;
264 U8 Reserved1;
265 U8 MsgLength;
266 U8 Function;
267 U16 DevHandle;
268 U8 IOCParameter;
269 U8 MsgFlags;
270 U32 MsgContext;
271 U16 Reserved4;
272 U16 IOCStatus;
273 U32 IOCLogInfo;
274 } MSG_SAS_IOUNIT_CONTROL_REPLY, MPI_POINTER PTR_MSG_SAS_IOUNIT_CONTROL_REPLY,
275 SasIoUnitControlReply_t, MPI_POINTER pSasIoUnitControlReply_t;
276
277 #endif
278
279