xref: /freebsd-src/sys/dev/mpr/mpi/mpi2_targ.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
1991554f2SKenneth D. Merry /*-
2*8736c018SKashyap D Desai  *  Copyright 2000-2020 Broadcom Inc. All rights reserved.
3991554f2SKenneth D. Merry  *
4991554f2SKenneth D. Merry  * Redistribution and use in source and binary forms, with or without
5991554f2SKenneth D. Merry  * modification, are permitted provided that the following conditions
6991554f2SKenneth D. Merry  * are met:
7991554f2SKenneth D. Merry  * 1. Redistributions of source code must retain the above copyright
8991554f2SKenneth D. Merry  *    notice, this list of conditions and the following disclaimer.
9991554f2SKenneth D. Merry  * 2. Redistributions in binary form must reproduce the above copyright
10991554f2SKenneth D. Merry  *    notice, this list of conditions and the following disclaimer in the
11991554f2SKenneth D. Merry  *    documentation and/or other materials provided with the distribution.
12991554f2SKenneth D. Merry  * 3. Neither the name of the author nor the names of any co-contributors
13991554f2SKenneth D. Merry  *    may be used to endorse or promote products derived from this software
14991554f2SKenneth D. Merry  *    without specific prior written permission.
15991554f2SKenneth D. Merry  *
16991554f2SKenneth D. Merry  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17991554f2SKenneth D. Merry  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18991554f2SKenneth D. Merry  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19991554f2SKenneth D. Merry  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20991554f2SKenneth D. Merry  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21991554f2SKenneth D. Merry  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22991554f2SKenneth D. Merry  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23991554f2SKenneth D. Merry  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24991554f2SKenneth D. Merry  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25991554f2SKenneth D. Merry  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26991554f2SKenneth D. Merry  * SUCH DAMAGE.
27991554f2SKenneth D. Merry  *
28*8736c018SKashyap D Desai  * Broadcom Inc. (LSI) MPT-Fusion Host Adapter FreeBSD
29991554f2SKenneth D. Merry  */
30991554f2SKenneth D. Merry 
31991554f2SKenneth D. Merry /*
32*8736c018SKashyap D Desai  *  Copyright 2000-2020 Broadcom Inc. All rights reserved.
33991554f2SKenneth D. Merry  *
34991554f2SKenneth D. Merry  *
35991554f2SKenneth D. Merry  *           Name:  mpi2_targ.h
36991554f2SKenneth D. Merry  *          Title:  MPI Target mode messages and structures
37991554f2SKenneth D. Merry  *  Creation Date:  September 8, 2006
38991554f2SKenneth D. Merry  *
3928ae62b0SStephen McConnell  *  mpi2_targ.h Version: 02.00.09
40991554f2SKenneth D. Merry  *
41991554f2SKenneth D. Merry  *  NOTE: Names (typedefs, defines, etc.) beginning with an MPI25 or Mpi25
42991554f2SKenneth D. Merry  *        prefix are for use only on MPI v2.5 products, and must not be used
43991554f2SKenneth D. Merry  *        with MPI v2.0 products. Unless otherwise noted, names beginning with
44991554f2SKenneth D. Merry  *        MPI2 or Mpi2 are for use with both MPI v2.0 and MPI v2.5 products.
45991554f2SKenneth D. Merry  *
46991554f2SKenneth D. Merry  *  Version History
47991554f2SKenneth D. Merry  *  ---------------
48991554f2SKenneth D. Merry  *
49991554f2SKenneth D. Merry  *  Date      Version   Description
50991554f2SKenneth D. Merry  *  --------  --------  ------------------------------------------------------
51991554f2SKenneth D. Merry  *  04-30-07  02.00.00  Corresponds to Fusion-MPT MPI Specification Rev A.
52991554f2SKenneth D. Merry  *  08-31-07  02.00.01  Added Command Buffer Data Location Address Space bits to
53991554f2SKenneth D. Merry  *                      BufferPostFlags field of CommandBufferPostBase Request.
54991554f2SKenneth D. Merry  *  02-29-08  02.00.02  Modified various names to make them 32-character unique.
55991554f2SKenneth D. Merry  *  10-02-08  02.00.03  Removed NextCmdBufferOffset from
56991554f2SKenneth D. Merry  *                      MPI2_TARGET_CMD_BUF_POST_BASE_REQUEST.
57991554f2SKenneth D. Merry  *                      Target Status Send Request only takes a single SGE for
58991554f2SKenneth D. Merry  *                      response data.
59991554f2SKenneth D. Merry  *  02-10-10  02.00.04  Added comment to MPI2_TARGET_SSP_RSP_IU structure.
60991554f2SKenneth D. Merry  *  11-18-11  02.00.05  Incorporating additions for MPI v2.5.
61991554f2SKenneth D. Merry  *  11-27-12  02.00.06  Added InitiatorDevHandle field to MPI2_TARGET_MODE_ABORT
62991554f2SKenneth D. Merry  *                      request message structure.
63991554f2SKenneth D. Merry  *                      Added AbortType MPI2_TARGET_MODE_ABORT_DEVHANDLE and
64991554f2SKenneth D. Merry  *                      MPI2_TARGET_MODE_ABORT_ALL_COMMANDS.
6528ae62b0SStephen McConnell  *  06-13-14  02.00.07  Added MinMSIxIndex and MaxMSIxIndex fields to
6628ae62b0SStephen McConnell  *                      MPI2_TARGET_CMD_BUF_POST_BASE_REQUEST.
6728ae62b0SStephen McConnell  *  11-18-14  02.00.08  Updated copyright information.
6828ae62b0SStephen McConnell  *  03-16-15  02.00.09  Updated for MPI v2.6.
6928ae62b0SStephen McConnell  *                      Added MPI26_TARGET_ASSIST_IOFLAGS_ESCAPE_PASSTHROUGH.
70991554f2SKenneth D. Merry  *  --------------------------------------------------------------------------
71991554f2SKenneth D. Merry  */
72991554f2SKenneth D. Merry 
73991554f2SKenneth D. Merry #ifndef MPI2_TARG_H
74991554f2SKenneth D. Merry #define MPI2_TARG_H
75991554f2SKenneth D. Merry 
76991554f2SKenneth D. Merry /******************************************************************************
77991554f2SKenneth D. Merry *
78991554f2SKenneth D. Merry *        SCSI Target Messages
79991554f2SKenneth D. Merry *
80991554f2SKenneth D. Merry *******************************************************************************/
81991554f2SKenneth D. Merry 
82991554f2SKenneth D. Merry /****************************************************************************
83991554f2SKenneth D. Merry *  Target Command Buffer Post Base Request
84991554f2SKenneth D. Merry ****************************************************************************/
85991554f2SKenneth D. Merry 
86991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_CMD_BUF_POST_BASE_REQUEST
87991554f2SKenneth D. Merry {
88991554f2SKenneth D. Merry     U8                      BufferPostFlags;        /* 0x00 */
89991554f2SKenneth D. Merry     U8                      Reserved1;              /* 0x01 */
90991554f2SKenneth D. Merry     U8                      ChainOffset;            /* 0x02 */
91991554f2SKenneth D. Merry     U8                      Function;               /* 0x03 */
92991554f2SKenneth D. Merry     U16                     TotalCmdBuffers;        /* 0x04 */
93991554f2SKenneth D. Merry     U8                      Reserved;               /* 0x06 */
94991554f2SKenneth D. Merry     U8                      MsgFlags;               /* 0x07 */
95991554f2SKenneth D. Merry     U8                      VP_ID;                  /* 0x08 */
96991554f2SKenneth D. Merry     U8                      VF_ID;                  /* 0x09 */
97991554f2SKenneth D. Merry     U16                     Reserved2;              /* 0x0A */
98991554f2SKenneth D. Merry     U32                     Reserved3;              /* 0x0C */
99991554f2SKenneth D. Merry     U16                     CmdBufferLength;        /* 0x10 */
10028ae62b0SStephen McConnell     U8                      MinMSIxIndex;           /* 0x12 */ /* MPI 2.5 and newer only; Reserved in MPI 2.0 */
10128ae62b0SStephen McConnell     U8                      MaxMSIxIndex;           /* 0x13 */ /* MPI 2.5 and newer only; Reserved in MPI 2.0 */
102991554f2SKenneth D. Merry     U32                     BaseAddressLow;         /* 0x14 */
103991554f2SKenneth D. Merry     U32                     BaseAddressHigh;        /* 0x18 */
104991554f2SKenneth D. Merry } MPI2_TARGET_CMD_BUF_POST_BASE_REQUEST,
105991554f2SKenneth D. Merry   MPI2_POINTER PTR_MPI2_TARGET_CMD_BUF_POST_BASE_REQUEST,
106991554f2SKenneth D. Merry   Mpi2TargetCmdBufferPostBaseRequest_t,
107991554f2SKenneth D. Merry   MPI2_POINTER pMpi2TargetCmdBufferPostBaseRequest_t;
108991554f2SKenneth D. Merry 
109991554f2SKenneth D. Merry /* values for the BufferPostflags field */
110991554f2SKenneth D. Merry #define MPI2_CMD_BUF_POST_BASE_ADDRESS_SPACE_MASK            (0x0C)
111991554f2SKenneth D. Merry #define MPI2_CMD_BUF_POST_BASE_SYSTEM_ADDRESS_SPACE          (0x00)
112991554f2SKenneth D. Merry #define MPI2_CMD_BUF_POST_BASE_IOCDDR_ADDRESS_SPACE          (0x04)
11328ae62b0SStephen McConnell #define MPI2_CMD_BUF_POST_BASE_IOCPLB_ADDRESS_SPACE          (0x08) /* only for MPI v2.5 and earlier */
11428ae62b0SStephen McConnell #define MPI26_CMD_BUF_POST_BASE_IOCCTL_ADDRESS_SPACE         (0x08) /* for MPI v2.6 only */
11528ae62b0SStephen McConnell #define MPI2_CMD_BUF_POST_BASE_IOCPLBNTA_ADDRESS_SPACE       (0x0C) /* only for MPI v2.5 and earlier */
116991554f2SKenneth D. Merry 
117991554f2SKenneth D. Merry #define MPI2_CMD_BUF_POST_BASE_FLAGS_AUTO_POST_ALL           (0x01)
118991554f2SKenneth D. Merry 
119991554f2SKenneth D. Merry /****************************************************************************
120991554f2SKenneth D. Merry *  Target Command Buffer Post List Request
121991554f2SKenneth D. Merry ****************************************************************************/
122991554f2SKenneth D. Merry 
123991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_CMD_BUF_POST_LIST_REQUEST
124991554f2SKenneth D. Merry {
125991554f2SKenneth D. Merry     U16                     Reserved;               /* 0x00 */
126991554f2SKenneth D. Merry     U8                      ChainOffset;            /* 0x02 */
127991554f2SKenneth D. Merry     U8                      Function;               /* 0x03 */
128991554f2SKenneth D. Merry     U16                     CmdBufferCount;         /* 0x04 */
129991554f2SKenneth D. Merry     U8                      Reserved1;              /* 0x06 */
130991554f2SKenneth D. Merry     U8                      MsgFlags;               /* 0x07 */
131991554f2SKenneth D. Merry     U8                      VP_ID;                  /* 0x08 */
132991554f2SKenneth D. Merry     U8                      VF_ID;                  /* 0x09 */
133991554f2SKenneth D. Merry     U16                     Reserved2;              /* 0x0A */
134991554f2SKenneth D. Merry     U32                     Reserved3;              /* 0x0C */
135991554f2SKenneth D. Merry     U16                     IoIndex[2];             /* 0x10 */
136991554f2SKenneth D. Merry } MPI2_TARGET_CMD_BUF_POST_LIST_REQUEST,
137991554f2SKenneth D. Merry   MPI2_POINTER PTR_MPI2_TARGET_CMD_BUF_POST_LIST_REQUEST,
138991554f2SKenneth D. Merry   Mpi2TargetCmdBufferPostListRequest_t,
139991554f2SKenneth D. Merry   MPI2_POINTER pMpi2TargetCmdBufferPostListRequest_t;
140991554f2SKenneth D. Merry 
141991554f2SKenneth D. Merry /****************************************************************************
142991554f2SKenneth D. Merry *  Target Command Buffer Post Base List Reply
143991554f2SKenneth D. Merry ****************************************************************************/
144991554f2SKenneth D. Merry 
145991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_BUF_POST_BASE_LIST_REPLY
146991554f2SKenneth D. Merry {
147991554f2SKenneth D. Merry     U8                      Flags;                  /* 0x00 */
148991554f2SKenneth D. Merry     U8                      Reserved;               /* 0x01 */
149991554f2SKenneth D. Merry     U8                      MsgLength;              /* 0x02 */
150991554f2SKenneth D. Merry     U8                      Function;               /* 0x03 */
151991554f2SKenneth D. Merry     U16                     Reserved1;              /* 0x04 */
152991554f2SKenneth D. Merry     U8                      Reserved2;              /* 0x06 */
153991554f2SKenneth D. Merry     U8                      MsgFlags;               /* 0x07 */
154991554f2SKenneth D. Merry     U8                      VP_ID;                  /* 0x08 */
155991554f2SKenneth D. Merry     U8                      VF_ID;                  /* 0x09 */
156991554f2SKenneth D. Merry     U16                     Reserved3;              /* 0x0A */
157991554f2SKenneth D. Merry     U16                     Reserved4;              /* 0x0C */
158991554f2SKenneth D. Merry     U16                     IOCStatus;              /* 0x0E */
159991554f2SKenneth D. Merry     U32                     IOCLogInfo;             /* 0x10 */
160991554f2SKenneth D. Merry     U16                     IoIndex;                /* 0x14 */
161991554f2SKenneth D. Merry     U16                     Reserved5;              /* 0x16 */
162991554f2SKenneth D. Merry     U32                     Reserved6;              /* 0x18 */
163991554f2SKenneth D. Merry } MPI2_TARGET_BUF_POST_BASE_LIST_REPLY,
164991554f2SKenneth D. Merry   MPI2_POINTER PTR_MPI2_TARGET_BUF_POST_BASE_LIST_REPLY,
165991554f2SKenneth D. Merry   Mpi2TargetCmdBufferPostBaseListReply_t,
166991554f2SKenneth D. Merry   MPI2_POINTER pMpi2TargetCmdBufferPostBaseListReply_t;
167991554f2SKenneth D. Merry 
168991554f2SKenneth D. Merry /* Flags defines */
169991554f2SKenneth D. Merry #define MPI2_CMD_BUF_POST_REPLY_IOINDEX_VALID       (0x01)
170991554f2SKenneth D. Merry 
171991554f2SKenneth D. Merry /****************************************************************************
172991554f2SKenneth D. Merry *  Command Buffer Formats (with 16 byte CDB)
173991554f2SKenneth D. Merry ****************************************************************************/
174991554f2SKenneth D. Merry 
175991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_SSP_CMD_BUFFER
176991554f2SKenneth D. Merry {
177991554f2SKenneth D. Merry     U8      FrameType;                                  /* 0x00 */
178991554f2SKenneth D. Merry     U8      Reserved1;                                  /* 0x01 */
179991554f2SKenneth D. Merry     U16     InitiatorConnectionTag;                     /* 0x02 */
180991554f2SKenneth D. Merry     U32     HashedSourceSASAddress;                     /* 0x04 */
181991554f2SKenneth D. Merry     U16     Reserved2;                                  /* 0x08 */
182991554f2SKenneth D. Merry     U16     Flags;                                      /* 0x0A */
183991554f2SKenneth D. Merry     U32     Reserved3;                                  /* 0x0C */
184991554f2SKenneth D. Merry     U16     Tag;                                        /* 0x10 */
185991554f2SKenneth D. Merry     U16     TargetPortTransferTag;                      /* 0x12 */
186991554f2SKenneth D. Merry     U32     DataOffset;                                 /* 0x14 */
187991554f2SKenneth D. Merry     /* COMMAND information unit starts here */
188991554f2SKenneth D. Merry     U8      LogicalUnitNumber[8];                       /* 0x18 */
189991554f2SKenneth D. Merry     U8      Reserved4;                                  /* 0x20 */
190991554f2SKenneth D. Merry     U8      TaskAttribute; /* lower 3 bits */           /* 0x21 */
191991554f2SKenneth D. Merry     U8      Reserved5;                                  /* 0x22 */
192991554f2SKenneth D. Merry     U8      AdditionalCDBLength; /* upper 5 bits */     /* 0x23 */
193991554f2SKenneth D. Merry     U8      CDB[16];                                    /* 0x24 */
194991554f2SKenneth D. Merry     /* Additional CDB bytes extend past the CDB field */
195991554f2SKenneth D. Merry } MPI2_TARGET_SSP_CMD_BUFFER, MPI2_POINTER PTR_MPI2_TARGET_SSP_CMD_BUFFER,
196991554f2SKenneth D. Merry   Mpi2TargetSspCmdBuffer, MPI2_POINTER pMp2iTargetSspCmdBuffer;
197991554f2SKenneth D. Merry 
198991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_SSP_TASK_BUFFER
199991554f2SKenneth D. Merry {
200991554f2SKenneth D. Merry     U8      FrameType;                                  /* 0x00 */
201991554f2SKenneth D. Merry     U8      Reserved1;                                  /* 0x01 */
202991554f2SKenneth D. Merry     U16     InitiatorConnectionTag;                     /* 0x02 */
203991554f2SKenneth D. Merry     U32     HashedSourceSASAddress;                     /* 0x04 */
204991554f2SKenneth D. Merry     U16     Reserved2;                                  /* 0x08 */
205991554f2SKenneth D. Merry     U16     Flags;                                      /* 0x0A */
206991554f2SKenneth D. Merry     U32     Reserved3;                                  /* 0x0C */
207991554f2SKenneth D. Merry     U16     Tag;                                        /* 0x10 */
208991554f2SKenneth D. Merry     U16     TargetPortTransferTag;                      /* 0x12 */
209991554f2SKenneth D. Merry     U32     DataOffset;                                 /* 0x14 */
210991554f2SKenneth D. Merry     /* TASK information unit starts here */
211991554f2SKenneth D. Merry     U8      LogicalUnitNumber[8];                       /* 0x18 */
212991554f2SKenneth D. Merry     U16     Reserved4;                                  /* 0x20 */
213991554f2SKenneth D. Merry     U8      TaskManagementFunction;                     /* 0x22 */
214991554f2SKenneth D. Merry     U8      Reserved5;                                  /* 0x23 */
215991554f2SKenneth D. Merry     U16     ManagedTaskTag;                             /* 0x24 */
216991554f2SKenneth D. Merry     U16     Reserved6;                                  /* 0x26 */
217991554f2SKenneth D. Merry     U32     Reserved7;                                  /* 0x28 */
218991554f2SKenneth D. Merry     U32     Reserved8;                                  /* 0x2C */
219991554f2SKenneth D. Merry     U32     Reserved9;                                  /* 0x30 */
220991554f2SKenneth D. Merry } MPI2_TARGET_SSP_TASK_BUFFER, MPI2_POINTER PTR_MPI2_TARGET_SSP_TASK_BUFFER,
221991554f2SKenneth D. Merry   Mpi2TargetSspTaskBuffer, MPI2_POINTER pMpi2TargetSspTaskBuffer;
222991554f2SKenneth D. Merry 
223991554f2SKenneth D. Merry /* mask and shift for HashedSourceSASAddress field */
224991554f2SKenneth D. Merry #define MPI2_TARGET_HASHED_SAS_ADDRESS_MASK     (0xFFFFFF00)
225991554f2SKenneth D. Merry #define MPI2_TARGET_HASHED_SAS_ADDRESS_SHIFT    (8)
226991554f2SKenneth D. Merry 
227991554f2SKenneth D. Merry /****************************************************************************
228991554f2SKenneth D. Merry *   MPI v2.0 Target Assist Request
229991554f2SKenneth D. Merry ****************************************************************************/
230991554f2SKenneth D. Merry 
231991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_ASSIST_REQUEST
232991554f2SKenneth D. Merry {
233991554f2SKenneth D. Merry     U8                  Reserved1;                          /* 0x00 */
234991554f2SKenneth D. Merry     U8                  TargetAssistFlags;                  /* 0x01 */
235991554f2SKenneth D. Merry     U8                  ChainOffset;                        /* 0x02 */
236991554f2SKenneth D. Merry     U8                  Function;                           /* 0x03 */
237991554f2SKenneth D. Merry     U16                 QueueTag;                           /* 0x04 */
238991554f2SKenneth D. Merry     U8                  Reserved2;                          /* 0x06 */
239991554f2SKenneth D. Merry     U8                  MsgFlags;                           /* 0x07 */
240991554f2SKenneth D. Merry     U8                  VP_ID;                              /* 0x08 */
241991554f2SKenneth D. Merry     U8                  VF_ID;                              /* 0x09 */
242991554f2SKenneth D. Merry     U16                 Reserved3;                          /* 0x0A */
243991554f2SKenneth D. Merry     U16                 IoIndex;                            /* 0x0C */
244991554f2SKenneth D. Merry     U16                 InitiatorConnectionTag;             /* 0x0E */
245991554f2SKenneth D. Merry     U16                 SGLFlags;                           /* 0x10 */
246991554f2SKenneth D. Merry     U8                  SequenceNumber;                     /* 0x12 */
247991554f2SKenneth D. Merry     U8                  Reserved4;                          /* 0x13 */
248991554f2SKenneth D. Merry     U8                  SGLOffset0;                         /* 0x14 */
249991554f2SKenneth D. Merry     U8                  SGLOffset1;                         /* 0x15 */
250991554f2SKenneth D. Merry     U8                  SGLOffset2;                         /* 0x16 */
251991554f2SKenneth D. Merry     U8                  SGLOffset3;                         /* 0x17 */
252991554f2SKenneth D. Merry     U32                 SkipCount;                          /* 0x18 */
253991554f2SKenneth D. Merry     U32                 DataLength;                         /* 0x1C */
254991554f2SKenneth D. Merry     U32                 BidirectionalDataLength;            /* 0x20 */
255991554f2SKenneth D. Merry     U16                 IoFlags;                            /* 0x24 */
256991554f2SKenneth D. Merry     U16                 EEDPFlags;                          /* 0x26 */
257991554f2SKenneth D. Merry     U32                 EEDPBlockSize;                      /* 0x28 */
258991554f2SKenneth D. Merry     U32                 SecondaryReferenceTag;              /* 0x2C */
259991554f2SKenneth D. Merry     U16                 SecondaryApplicationTag;            /* 0x30 */
260991554f2SKenneth D. Merry     U16                 ApplicationTagTranslationMask;      /* 0x32 */
261991554f2SKenneth D. Merry     U32                 PrimaryReferenceTag;                /* 0x34 */
262991554f2SKenneth D. Merry     U16                 PrimaryApplicationTag;              /* 0x38 */
263991554f2SKenneth D. Merry     U16                 PrimaryApplicationTagMask;          /* 0x3A */
264991554f2SKenneth D. Merry     U32                 RelativeOffset;                     /* 0x3C */
265991554f2SKenneth D. Merry     U32                 Reserved5;                          /* 0x40 */
266991554f2SKenneth D. Merry     U32                 Reserved6;                          /* 0x44 */
267991554f2SKenneth D. Merry     U32                 Reserved7;                          /* 0x48 */
268991554f2SKenneth D. Merry     U32                 Reserved8;                          /* 0x4C */
269991554f2SKenneth D. Merry     MPI2_SGE_IO_UNION   SGL[1];                             /* 0x50 */
270991554f2SKenneth D. Merry } MPI2_TARGET_ASSIST_REQUEST, MPI2_POINTER PTR_MPI2_TARGET_ASSIST_REQUEST,
271991554f2SKenneth D. Merry   Mpi2TargetAssistRequest_t, MPI2_POINTER pMpi2TargetAssistRequest_t;
272991554f2SKenneth D. Merry 
273991554f2SKenneth D. Merry /* Target Assist TargetAssistFlags bits */
274991554f2SKenneth D. Merry 
275991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_FLAGS_REPOST_CMD_BUFFER      (0x80)
276991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_FLAGS_TLR                    (0x10)
277991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_FLAGS_RETRANSMIT             (0x04)
278991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_FLAGS_AUTO_STATUS            (0x02)
279991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_FLAGS_DATA_DIRECTION         (0x01)
280991554f2SKenneth D. Merry 
281991554f2SKenneth D. Merry /* Target Assist SGLFlags bits */
282991554f2SKenneth D. Merry 
283991554f2SKenneth D. Merry /* base values for Data Location Address Space */
284991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_ADDR_MASK           (0x0C)
285991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_SYSTEM_ADDR         (0x00)
286991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_IOCDDR_ADDR         (0x04)
287991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_IOCPLB_ADDR         (0x08)
288991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_PLBNTA_ADDR         (0x0C)
289991554f2SKenneth D. Merry 
290991554f2SKenneth D. Merry /* base values for Type */
291991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_TYPE_MASK           (0x03)
292991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_MPI_TYPE            (0x00)
293991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_32IEEE_TYPE         (0x01)
294991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_64IEEE_TYPE         (0x02)
295991554f2SKenneth D. Merry 
296991554f2SKenneth D. Merry /* shift values for each sub-field */
297991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_SGL3_SHIFT          (12)
298991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_SGL2_SHIFT          (8)
299991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_SGL1_SHIFT          (4)
300991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_SGLFLAGS_SGL0_SHIFT          (0)
301991554f2SKenneth D. Merry 
302991554f2SKenneth D. Merry /* Target Assist IoFlags bits */
303991554f2SKenneth D. Merry 
304991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_IOFLAGS_BIDIRECTIONAL        (0x0800)
305991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_IOFLAGS_MULTICAST            (0x0400)
306991554f2SKenneth D. Merry #define MPI2_TARGET_ASSIST_IOFLAGS_RECEIVE_FIRST        (0x0200)
307991554f2SKenneth D. Merry 
308991554f2SKenneth D. Merry /* Target Assist EEDPFlags bits */
309991554f2SKenneth D. Merry 
310991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_INC_PRI_REFTAG            (0x8000)
311991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_INC_SEC_REFTAG            (0x4000)
312991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_INC_PRI_APPTAG            (0x2000)
313991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_INC_SEC_APPTAG            (0x1000)
314991554f2SKenneth D. Merry 
315991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_CHECK_REFTAG              (0x0400)
316991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_CHECK_APPTAG              (0x0200)
317991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_CHECK_GUARD               (0x0100)
318991554f2SKenneth D. Merry 
319991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_PASSTHRU_REFTAG           (0x0008)
320991554f2SKenneth D. Merry 
321991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_MASK_OP                   (0x0007)
322991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_NOOP_OP                   (0x0000)
323991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_CHECK_OP                  (0x0001)
324991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_STRIP_OP                  (0x0002)
325991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_CHECK_REMOVE_OP           (0x0003)
326991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_INSERT_OP                 (0x0004)
327991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_REPLACE_OP                (0x0006)
328991554f2SKenneth D. Merry #define MPI2_TA_EEDPFLAGS_CHECK_REGEN_OP            (0x0007)
329991554f2SKenneth D. Merry 
330991554f2SKenneth D. Merry /****************************************************************************
331991554f2SKenneth D. Merry *   MPI v2.5 Target Assist Request
332991554f2SKenneth D. Merry ****************************************************************************/
333991554f2SKenneth D. Merry 
334991554f2SKenneth D. Merry typedef struct _MPI25_TARGET_ASSIST_REQUEST
335991554f2SKenneth D. Merry {
336991554f2SKenneth D. Merry     U8                  Reserved1;                          /* 0x00 */
337991554f2SKenneth D. Merry     U8                  TargetAssistFlags;                  /* 0x01 */
338991554f2SKenneth D. Merry     U8                  ChainOffset;                        /* 0x02 */
339991554f2SKenneth D. Merry     U8                  Function;                           /* 0x03 */
340991554f2SKenneth D. Merry     U16                 QueueTag;                           /* 0x04 */
341991554f2SKenneth D. Merry     U8                  Reserved2;                          /* 0x06 */
342991554f2SKenneth D. Merry     U8                  MsgFlags;                           /* 0x07 */
343991554f2SKenneth D. Merry     U8                  VP_ID;                              /* 0x08 */
344991554f2SKenneth D. Merry     U8                  VF_ID;                              /* 0x09 */
345991554f2SKenneth D. Merry     U16                 Reserved3;                          /* 0x0A */
346991554f2SKenneth D. Merry     U16                 IoIndex;                            /* 0x0C */
347991554f2SKenneth D. Merry     U16                 InitiatorConnectionTag;             /* 0x0E */
348991554f2SKenneth D. Merry     U8                  DMAFlags;                           /* 0x10 */
349991554f2SKenneth D. Merry     U8                  Reserved9;                          /* 0x11 */
350991554f2SKenneth D. Merry     U8                  SequenceNumber;                     /* 0x12 */
351991554f2SKenneth D. Merry     U8                  Reserved4;                          /* 0x13 */
352991554f2SKenneth D. Merry     U8                  SGLOffset0;                         /* 0x14 */
353991554f2SKenneth D. Merry     U8                  SGLOffset1;                         /* 0x15 */
354991554f2SKenneth D. Merry     U8                  SGLOffset2;                         /* 0x16 */
355991554f2SKenneth D. Merry     U8                  SGLOffset3;                         /* 0x17 */
356991554f2SKenneth D. Merry     U32                 SkipCount;                          /* 0x18 */
357991554f2SKenneth D. Merry     U32                 DataLength;                         /* 0x1C */
358991554f2SKenneth D. Merry     U32                 BidirectionalDataLength;            /* 0x20 */
359991554f2SKenneth D. Merry     U16                 IoFlags;                            /* 0x24 */
360991554f2SKenneth D. Merry     U16                 EEDPFlags;                          /* 0x26 */
361991554f2SKenneth D. Merry     U16                 EEDPBlockSize;                      /* 0x28 */
362991554f2SKenneth D. Merry     U16                 Reserved10;                         /* 0x2A */
363991554f2SKenneth D. Merry     U32                 SecondaryReferenceTag;              /* 0x2C */
364991554f2SKenneth D. Merry     U16                 SecondaryApplicationTag;            /* 0x30 */
365991554f2SKenneth D. Merry     U16                 ApplicationTagTranslationMask;      /* 0x32 */
366991554f2SKenneth D. Merry     U32                 PrimaryReferenceTag;                /* 0x34 */
367991554f2SKenneth D. Merry     U16                 PrimaryApplicationTag;              /* 0x38 */
368991554f2SKenneth D. Merry     U16                 PrimaryApplicationTagMask;          /* 0x3A */
369991554f2SKenneth D. Merry     U32                 RelativeOffset;                     /* 0x3C */
370991554f2SKenneth D. Merry     U32                 Reserved5;                          /* 0x40 */
371991554f2SKenneth D. Merry     U32                 Reserved6;                          /* 0x44 */
372991554f2SKenneth D. Merry     U32                 Reserved7;                          /* 0x48 */
373991554f2SKenneth D. Merry     U32                 Reserved8;                          /* 0x4C */
374991554f2SKenneth D. Merry     MPI25_SGE_IO_UNION  SGL;                                /* 0x50 */
375991554f2SKenneth D. Merry } MPI25_TARGET_ASSIST_REQUEST, MPI2_POINTER PTR_MPI25_TARGET_ASSIST_REQUEST,
376991554f2SKenneth D. Merry   Mpi25TargetAssistRequest_t, MPI2_POINTER pMpi25TargetAssistRequest_t;
377991554f2SKenneth D. Merry 
378991554f2SKenneth D. Merry /* use MPI2_TARGET_ASSIST_FLAGS_ defines for the Flags field */
379991554f2SKenneth D. Merry 
380991554f2SKenneth D. Merry /* Defines for the DMAFlags field
381991554f2SKenneth D. Merry  *  Each setting affects 4 SGLS, from SGL0 to SGL3.
382991554f2SKenneth D. Merry  *      D = Data
383991554f2SKenneth D. Merry  *      C = Cache DIF
384991554f2SKenneth D. Merry  *      I = Interleaved
385991554f2SKenneth D. Merry  *      H = Host DIF
386991554f2SKenneth D. Merry  */
387991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_MASK                   (0x0F)
388991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_D_D_D                (0x00)
389991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_D_D_C                (0x01)
390991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_D_D_I                (0x02)
391991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_D_C_C                (0x03)
392991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_D_C_I                (0x04)
393991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_D_I_I                (0x05)
394991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_C_C_C                (0x06)
395991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_C_C_I                (0x07)
396991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_C_I_I                (0x08)
397991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_I_I_I                (0x09)
398991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_H_D_D                (0x0A)
399991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_H_D_C                (0x0B)
400991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_H_D_I                (0x0C)
401991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_H_C_C                (0x0D)
402991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_H_C_I                (0x0E)
403991554f2SKenneth D. Merry #define MPI25_TA_DMAFLAGS_OP_D_H_I_I                (0x0F)
404991554f2SKenneth D. Merry 
405991554f2SKenneth D. Merry /* defines for the IoFlags field */
40628ae62b0SStephen McConnell #define MPI26_TARGET_ASSIST_IOFLAGS_ESCAPE_PASSTHROUGH  (0x2000) /* MPI v2.6 and later */
407991554f2SKenneth D. Merry #define MPI25_TARGET_ASSIST_IOFLAGS_BIDIRECTIONAL       (0x0800)
408991554f2SKenneth D. Merry #define MPI25_TARGET_ASSIST_IOFLAGS_RECEIVE_FIRST       (0x0200)
409991554f2SKenneth D. Merry 
410991554f2SKenneth D. Merry /* defines for the EEDPFlags field */
411991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_INC_PRI_REFTAG               (0x8000)
412991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_INC_SEC_REFTAG               (0x4000)
413991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_INC_PRI_APPTAG               (0x2000)
414991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_INC_SEC_APPTAG               (0x1000)
415991554f2SKenneth D. Merry 
416991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_CHECK_REFTAG                 (0x0400)
417991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_CHECK_APPTAG                 (0x0200)
418991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_CHECK_GUARD                  (0x0100)
419991554f2SKenneth D. Merry 
420991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_ESCAPE_MODE_MASK             (0x00C0)
421991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_COMPATIBLE_MODE              (0x0000)
422991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_DO_NOT_DISABLE_MODE          (0x0040)
423991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_APPTAG_DISABLE_MODE          (0x0080)
424991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_APPTAG_REFTAG_DISABLE_MODE   (0x00C0)
425991554f2SKenneth D. Merry 
426991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_HOST_GUARD_METHOD_MASK       (0x0030)
427991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_T10_CRC_HOST_GUARD           (0x0000)
428991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_IP_CHKSUM_HOST_GUARD         (0x0010)
429991554f2SKenneth D. Merry 
430991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_PASSTHRU_REFTAG              (0x0008)
431991554f2SKenneth D. Merry 
432991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_MASK_OP                      (0x0007)
433991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_NOOP_OP                      (0x0000)
434991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_CHECK_OP                     (0x0001)
435991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_STRIP_OP                     (0x0002)
436991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_CHECK_REMOVE_OP              (0x0003)
437991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_INSERT_OP                    (0x0004)
438991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_REPLACE_OP                   (0x0006)
439991554f2SKenneth D. Merry #define MPI25_TA_EEDPFLAGS_CHECK_REGEN_OP               (0x0007)
440991554f2SKenneth D. Merry 
441991554f2SKenneth D. Merry /****************************************************************************
442991554f2SKenneth D. Merry *  Target Status Send Request
443991554f2SKenneth D. Merry ****************************************************************************/
444991554f2SKenneth D. Merry 
445991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_STATUS_SEND_REQUEST
446991554f2SKenneth D. Merry {
447991554f2SKenneth D. Merry     U8                      Reserved1;                  /* 0x00 */
448991554f2SKenneth D. Merry     U8                      StatusFlags;                /* 0x01 */
449991554f2SKenneth D. Merry     U8                      ChainOffset;                /* 0x02 */
450991554f2SKenneth D. Merry     U8                      Function;                   /* 0x03 */
451991554f2SKenneth D. Merry     U16                     QueueTag;                   /* 0x04 */
452991554f2SKenneth D. Merry     U8                      Reserved2;                  /* 0x06 */
453991554f2SKenneth D. Merry     U8                      MsgFlags;                   /* 0x07 */
454991554f2SKenneth D. Merry     U8                      VP_ID;                      /* 0x08 */
455991554f2SKenneth D. Merry     U8                      VF_ID;                      /* 0x09 */
456991554f2SKenneth D. Merry     U16                     Reserved3;                  /* 0x0A */
457991554f2SKenneth D. Merry     U16                     IoIndex;                    /* 0x0C */
458991554f2SKenneth D. Merry     U16                     InitiatorConnectionTag;     /* 0x0E */
459991554f2SKenneth D. Merry     U16                     SGLFlags;                   /* 0x10 */ /* MPI v2.0 only. Reserved on MPI v2.5. */
460991554f2SKenneth D. Merry     U16                     Reserved4;                  /* 0x12 */
461991554f2SKenneth D. Merry     U8                      SGLOffset0;                 /* 0x14 */
462991554f2SKenneth D. Merry     U8                      Reserved5;                  /* 0x15 */
463991554f2SKenneth D. Merry     U16                     Reserved6;                  /* 0x16 */
464991554f2SKenneth D. Merry     U32                     Reserved7;                  /* 0x18 */
465991554f2SKenneth D. Merry     U32                     Reserved8;                  /* 0x1C */
466991554f2SKenneth D. Merry     MPI2_SIMPLE_SGE_UNION   StatusDataSGE;              /* 0x20 */ /* MPI v2.5: This must be an IEEE Simple Element 64. */
467991554f2SKenneth D. Merry } MPI2_TARGET_STATUS_SEND_REQUEST,
468991554f2SKenneth D. Merry   MPI2_POINTER PTR_MPI2_TARGET_STATUS_SEND_REQUEST,
469991554f2SKenneth D. Merry   Mpi2TargetStatusSendRequest_t, MPI2_POINTER pMpi2TargetStatusSendRequest_t;
470991554f2SKenneth D. Merry 
471991554f2SKenneth D. Merry /* Target Status Send StatusFlags bits */
472991554f2SKenneth D. Merry 
473991554f2SKenneth D. Merry #define MPI2_TSS_FLAGS_REPOST_CMD_BUFFER            (0x80)
474991554f2SKenneth D. Merry #define MPI2_TSS_FLAGS_RETRANSMIT                   (0x04)
475991554f2SKenneth D. Merry #define MPI2_TSS_FLAGS_AUTO_GOOD_STATUS             (0x01)
476991554f2SKenneth D. Merry 
477991554f2SKenneth D. Merry /* Target Status Send SGLFlags bits - MPI v2.0 only */
478991554f2SKenneth D. Merry /* Data Location Address Space */
479991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_ADDR_MASK                 (0x0C)
480991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_SYSTEM_ADDR               (0x00)
481991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_IOCDDR_ADDR               (0x04)
482991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_IOCPLB_ADDR               (0x08)
483991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_IOCPLBNTA_ADDR            (0x0C)
484991554f2SKenneth D. Merry /* Type */
485991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_TYPE_MASK                 (0x03)
486991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_MPI_TYPE                  (0x00)
487991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_IEEE32_TYPE               (0x01)
488991554f2SKenneth D. Merry #define MPI2_TSS_SGLFLAGS_IEEE64_TYPE               (0x02)
489991554f2SKenneth D. Merry 
490991554f2SKenneth D. Merry /*
491991554f2SKenneth D. Merry  * NOTE: The SSP status IU is big-endian. When used on a little-endian system,
492991554f2SKenneth D. Merry  * this structure properly orders the bytes.
493991554f2SKenneth D. Merry  */
494991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_SSP_RSP_IU
495991554f2SKenneth D. Merry {
496991554f2SKenneth D. Merry     U32     Reserved0[6]; /* reserved for SSP header */ /* 0x00 */
497991554f2SKenneth D. Merry 
498991554f2SKenneth D. Merry     /* start of RESPONSE information unit */
499991554f2SKenneth D. Merry     U32     Reserved1;                                  /* 0x18 */
500991554f2SKenneth D. Merry     U32     Reserved2;                                  /* 0x1C */
501991554f2SKenneth D. Merry     U16     Reserved3;                                  /* 0x20 */
502991554f2SKenneth D. Merry     U8      DataPres; /* lower 2 bits */                /* 0x22 */
503991554f2SKenneth D. Merry     U8      Status;                                     /* 0x23 */
504991554f2SKenneth D. Merry     U32     Reserved4;                                  /* 0x24 */
505991554f2SKenneth D. Merry     U32     SenseDataLength;                            /* 0x28 */
506991554f2SKenneth D. Merry     U32     ResponseDataLength;                         /* 0x2C */
507991554f2SKenneth D. Merry 
508991554f2SKenneth D. Merry     /* start of Response or Sense Data (size may vary dynamically) */
509991554f2SKenneth D. Merry     U8      ResponseSenseData[4];                       /* 0x30 */
510991554f2SKenneth D. Merry } MPI2_TARGET_SSP_RSP_IU, MPI2_POINTER PTR_MPI2_TARGET_SSP_RSP_IU,
511991554f2SKenneth D. Merry   Mpi2TargetSspRspIu_t, MPI2_POINTER pMpi2TargetSspRspIu_t;
512991554f2SKenneth D. Merry 
513991554f2SKenneth D. Merry /****************************************************************************
514991554f2SKenneth D. Merry *  Target Standard Reply - used with Target Assist or Target Status Send
515991554f2SKenneth D. Merry ****************************************************************************/
516991554f2SKenneth D. Merry 
517991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_STANDARD_REPLY
518991554f2SKenneth D. Merry {
519991554f2SKenneth D. Merry     U16                     Reserved;                   /* 0x00 */
520991554f2SKenneth D. Merry     U8                      MsgLength;                  /* 0x02 */
521991554f2SKenneth D. Merry     U8                      Function;                   /* 0x03 */
522991554f2SKenneth D. Merry     U16                     Reserved1;                  /* 0x04 */
523991554f2SKenneth D. Merry     U8                      Reserved2;                  /* 0x06 */
524991554f2SKenneth D. Merry     U8                      MsgFlags;                   /* 0x07 */
525991554f2SKenneth D. Merry     U8                      VP_ID;                      /* 0x08 */
526991554f2SKenneth D. Merry     U8                      VF_ID;                      /* 0x09 */
527991554f2SKenneth D. Merry     U16                     Reserved3;                  /* 0x0A */
528991554f2SKenneth D. Merry     U16                     Reserved4;                  /* 0x0C */
529991554f2SKenneth D. Merry     U16                     IOCStatus;                  /* 0x0E */
530991554f2SKenneth D. Merry     U32                     IOCLogInfo;                 /* 0x10 */
531991554f2SKenneth D. Merry     U16                     IoIndex;                    /* 0x14 */
532991554f2SKenneth D. Merry     U16                     Reserved5;                  /* 0x16 */
533991554f2SKenneth D. Merry     U32                     TransferCount;              /* 0x18 */
534991554f2SKenneth D. Merry     U32                     BidirectionalTransferCount; /* 0x1C */
535991554f2SKenneth D. Merry } MPI2_TARGET_STANDARD_REPLY, MPI2_POINTER PTR_MPI2_TARGET_STANDARD_REPLY,
536991554f2SKenneth D. Merry   Mpi2TargetErrorReply_t, MPI2_POINTER pMpi2TargetErrorReply_t;
537991554f2SKenneth D. Merry 
538991554f2SKenneth D. Merry /****************************************************************************
539991554f2SKenneth D. Merry *  Target Mode Abort Request
540991554f2SKenneth D. Merry ****************************************************************************/
541991554f2SKenneth D. Merry 
542991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_MODE_ABORT_REQUEST
543991554f2SKenneth D. Merry {
544991554f2SKenneth D. Merry     U8                      AbortType;                  /* 0x00 */
545991554f2SKenneth D. Merry     U8                      Reserved1;                  /* 0x01 */
546991554f2SKenneth D. Merry     U8                      ChainOffset;                /* 0x02 */
547991554f2SKenneth D. Merry     U8                      Function;                   /* 0x03 */
548991554f2SKenneth D. Merry     U16                     Reserved2;                  /* 0x04 */
549991554f2SKenneth D. Merry     U8                      Reserved3;                  /* 0x06 */
550991554f2SKenneth D. Merry     U8                      MsgFlags;                   /* 0x07 */
551991554f2SKenneth D. Merry     U8                      VP_ID;                      /* 0x08 */
552991554f2SKenneth D. Merry     U8                      VF_ID;                      /* 0x09 */
553991554f2SKenneth D. Merry     U16                     Reserved4;                  /* 0x0A */
554991554f2SKenneth D. Merry     U16                     IoIndexToAbort;             /* 0x0C */
555991554f2SKenneth D. Merry     U16                     InitiatorDevHandle;         /* 0x0E */
556991554f2SKenneth D. Merry     U32                     MidToAbort;                 /* 0x10 */
557991554f2SKenneth D. Merry } MPI2_TARGET_MODE_ABORT, MPI2_POINTER PTR_MPI2_TARGET_MODE_ABORT,
558991554f2SKenneth D. Merry   Mpi2TargetModeAbort_t, MPI2_POINTER pMpi2TargetModeAbort_t;
559991554f2SKenneth D. Merry 
560991554f2SKenneth D. Merry /* Target Mode Abort AbortType values */
561991554f2SKenneth D. Merry 
562991554f2SKenneth D. Merry #define MPI2_TARGET_MODE_ABORT_ALL_CMD_BUFFERS      (0x00)
563991554f2SKenneth D. Merry #define MPI2_TARGET_MODE_ABORT_ALL_IO               (0x01)
564991554f2SKenneth D. Merry #define MPI2_TARGET_MODE_ABORT_EXACT_IO             (0x02)
565991554f2SKenneth D. Merry #define MPI2_TARGET_MODE_ABORT_EXACT_IO_REQUEST     (0x03)
566991554f2SKenneth D. Merry #define MPI2_TARGET_MODE_ABORT_IO_REQUEST_AND_IO    (0x04)
567991554f2SKenneth D. Merry #define MPI2_TARGET_MODE_ABORT_DEVHANDLE            (0x05)
568991554f2SKenneth D. Merry #define MPI2_TARGET_MODE_ABORT_ALL_COMMANDS         (0x06)
569991554f2SKenneth D. Merry 
570991554f2SKenneth D. Merry /****************************************************************************
571991554f2SKenneth D. Merry *  Target Mode Abort Reply
572991554f2SKenneth D. Merry ****************************************************************************/
573991554f2SKenneth D. Merry 
574991554f2SKenneth D. Merry typedef struct _MPI2_TARGET_MODE_ABORT_REPLY
575991554f2SKenneth D. Merry {
576991554f2SKenneth D. Merry     U16                     Reserved;                   /* 0x00 */
577991554f2SKenneth D. Merry     U8                      MsgLength;                  /* 0x02 */
578991554f2SKenneth D. Merry     U8                      Function;                   /* 0x03 */
579991554f2SKenneth D. Merry     U16                     Reserved1;                  /* 0x04 */
580991554f2SKenneth D. Merry     U8                      Reserved2;                  /* 0x06 */
581991554f2SKenneth D. Merry     U8                      MsgFlags;                   /* 0x07 */
582991554f2SKenneth D. Merry     U8                      VP_ID;                      /* 0x08 */
583991554f2SKenneth D. Merry     U8                      VF_ID;                      /* 0x09 */
584991554f2SKenneth D. Merry     U16                     Reserved3;                  /* 0x0A */
585991554f2SKenneth D. Merry     U16                     Reserved4;                  /* 0x0C */
586991554f2SKenneth D. Merry     U16                     IOCStatus;                  /* 0x0E */
587991554f2SKenneth D. Merry     U32                     IOCLogInfo;                 /* 0x10 */
588991554f2SKenneth D. Merry     U32                     AbortCount;                 /* 0x14 */
589991554f2SKenneth D. Merry } MPI2_TARGET_MODE_ABORT_REPLY, MPI2_POINTER PTR_MPI2_TARGET_MODE_ABORT_REPLY,
590991554f2SKenneth D. Merry   Mpi2TargetModeAbortReply_t, MPI2_POINTER pMpi2TargetModeAbortReply_t;
591991554f2SKenneth D. Merry 
592991554f2SKenneth D. Merry #endif
593