xref: /freebsd/sys/dev/mpi3mr/mpi/mpi30_sas.h (revision 2d1d418e1e7bc8325bb052185c17c81a674d0c4e)
1*2d1d418eSSumit Saxena /*
2*2d1d418eSSumit Saxena  * SPDX-License-Identifier: BSD-2-Clause
3*2d1d418eSSumit Saxena  *
4*2d1d418eSSumit Saxena  * Copyright (c) 2016-2023, Broadcom Inc. All rights reserved.
5*2d1d418eSSumit Saxena  * Support: <fbsd-storage-driver.pdl@broadcom.com>
6*2d1d418eSSumit Saxena  *
7*2d1d418eSSumit Saxena  * Redistribution and use in source and binary forms, with or without
8*2d1d418eSSumit Saxena  * modification, are permitted provided that the following conditions are
9*2d1d418eSSumit Saxena  * met:
10*2d1d418eSSumit Saxena  *
11*2d1d418eSSumit Saxena  * 1. Redistributions of source code must retain the above copyright notice,
12*2d1d418eSSumit Saxena  *    this list of conditions and the following disclaimer.
13*2d1d418eSSumit Saxena  * 2. Redistributions in binary form must reproduce the above copyright notice,
14*2d1d418eSSumit Saxena  *    this list of conditions and the following disclaimer in the documentation and/or other
15*2d1d418eSSumit Saxena  *    materials provided with the distribution.
16*2d1d418eSSumit Saxena  * 3. Neither the name of the Broadcom Inc. nor the names of its contributors
17*2d1d418eSSumit Saxena  *    may be used to endorse or promote products derived from this software without
18*2d1d418eSSumit Saxena  *    specific prior written permission.
19*2d1d418eSSumit Saxena  *
20*2d1d418eSSumit Saxena  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21*2d1d418eSSumit Saxena  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22*2d1d418eSSumit Saxena  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23*2d1d418eSSumit Saxena  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
24*2d1d418eSSumit Saxena  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25*2d1d418eSSumit Saxena  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26*2d1d418eSSumit Saxena  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27*2d1d418eSSumit Saxena  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28*2d1d418eSSumit Saxena  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29*2d1d418eSSumit Saxena  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30*2d1d418eSSumit Saxena  * POSSIBILITY OF SUCH DAMAGE.
31*2d1d418eSSumit Saxena  *
32*2d1d418eSSumit Saxena  * The views and conclusions contained in the software and documentation are
33*2d1d418eSSumit Saxena  * those of the authors and should not be interpreted as representing
34*2d1d418eSSumit Saxena  * official policies,either expressed or implied, of the FreeBSD Project.
35*2d1d418eSSumit Saxena  *
36*2d1d418eSSumit Saxena  * Mail to: Broadcom Inc 1320 Ridder Park Dr, San Jose, CA 95131
37*2d1d418eSSumit Saxena  *
38*2d1d418eSSumit Saxena  * Broadcom Inc. (Broadcom) MPI3MR Adapter FreeBSD
39*2d1d418eSSumit Saxena  *
40*2d1d418eSSumit Saxena  */
41*2d1d418eSSumit Saxena 
42*2d1d418eSSumit Saxena #ifndef MPI30_SAS_H
43*2d1d418eSSumit Saxena #define MPI30_SAS_H     1
44*2d1d418eSSumit Saxena 
45*2d1d418eSSumit Saxena /*****************************************************************************
46*2d1d418eSSumit Saxena  *              SAS Device Info Definitions                                  *
47*2d1d418eSSumit Saxena  ****************************************************************************/
48*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_SSP_TARGET             (0x00000100)
49*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_STP_SATA_TARGET        (0x00000080)
50*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_SMP_TARGET             (0x00000040)
51*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_SSP_INITIATOR          (0x00000020)
52*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_STP_INITIATOR          (0x00000010)
53*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_SMP_INITIATOR          (0x00000008)
54*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_DEVICE_TYPE_MASK       (0x00000007)
55*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_DEVICE_TYPE_NO_DEVICE  (0x00000000)
56*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_DEVICE_TYPE_END_DEVICE (0x00000001)
57*2d1d418eSSumit Saxena #define MPI3_SAS_DEVICE_INFO_DEVICE_TYPE_EXPANDER   (0x00000002)
58*2d1d418eSSumit Saxena 
59*2d1d418eSSumit Saxena /*****************************************************************************
60*2d1d418eSSumit Saxena  *              SMP Passthrough Request Message                              *
61*2d1d418eSSumit Saxena  ****************************************************************************/
62*2d1d418eSSumit Saxena typedef struct _MPI3_SMP_PASSTHROUGH_REQUEST
63*2d1d418eSSumit Saxena {
64*2d1d418eSSumit Saxena     U16                     HostTag;                        /* 0x00 */
65*2d1d418eSSumit Saxena     U8                      IOCUseOnly02;                   /* 0x02 */
66*2d1d418eSSumit Saxena     U8                      Function;                       /* 0x03 */
67*2d1d418eSSumit Saxena     U16                     IOCUseOnly04;                   /* 0x04 */
68*2d1d418eSSumit Saxena     U8                      IOCUseOnly06;                   /* 0x06 */
69*2d1d418eSSumit Saxena     U8                      MsgFlags;                       /* 0x07 */
70*2d1d418eSSumit Saxena     U16                     ChangeCount;                    /* 0x08 */
71*2d1d418eSSumit Saxena     U8                      Reserved0A;                     /* 0x0A */
72*2d1d418eSSumit Saxena     U8                      IOUnitPort;                     /* 0x0B */
73*2d1d418eSSumit Saxena     U32                     Reserved0C[3];                  /* 0x0C */
74*2d1d418eSSumit Saxena     U64                     SASAddress;                     /* 0x18 */
75*2d1d418eSSumit Saxena     MPI3_SGE_SIMPLE         RequestSGE;                     /* 0x20 */
76*2d1d418eSSumit Saxena     MPI3_SGE_SIMPLE         ResponseSGE;                    /* 0x30 */
77*2d1d418eSSumit Saxena } MPI3_SMP_PASSTHROUGH_REQUEST, MPI3_POINTER PTR_MPI3_SMP_PASSTHROUGH_REQUEST,
78*2d1d418eSSumit Saxena   Mpi3SmpPassthroughRequest_t, MPI3_POINTER pMpi3SmpPassthroughRequest_t;
79*2d1d418eSSumit Saxena 
80*2d1d418eSSumit Saxena /*****************************************************************************
81*2d1d418eSSumit Saxena  *              SMP Passthrough Reply Message                               *
82*2d1d418eSSumit Saxena  ****************************************************************************/
83*2d1d418eSSumit Saxena typedef struct _MPI3_SMP_PASSTHROUGH_REPLY
84*2d1d418eSSumit Saxena {
85*2d1d418eSSumit Saxena     U16                     HostTag;                        /* 0x00 */
86*2d1d418eSSumit Saxena     U8                      IOCUseOnly02;                   /* 0x02 */
87*2d1d418eSSumit Saxena     U8                      Function;                       /* 0x03 */
88*2d1d418eSSumit Saxena     U16                     IOCUseOnly04;                   /* 0x04 */
89*2d1d418eSSumit Saxena     U8                      IOCUseOnly06;                   /* 0x06 */
90*2d1d418eSSumit Saxena     U8                      MsgFlags;                       /* 0x07 */
91*2d1d418eSSumit Saxena     U16                     IOCUseOnly08;                   /* 0x08 */
92*2d1d418eSSumit Saxena     U16                     IOCStatus;                      /* 0x0A */
93*2d1d418eSSumit Saxena     U32                     IOCLogInfo;                     /* 0x0C */
94*2d1d418eSSumit Saxena     U16                     ResponseDataLength;             /* 0x10 */
95*2d1d418eSSumit Saxena     U16                     Reserved12;                     /* 0x12 */
96*2d1d418eSSumit Saxena } MPI3_SMP_PASSTHROUGH_REPLY, MPI3_POINTER PTR_MPI3_SMP_PASSTHROUGH_REPLY,
97*2d1d418eSSumit Saxena   Mpi3SmpPassthroughReply_t, MPI3_POINTER pMpi3SmpPassthroughReply_t;
98*2d1d418eSSumit Saxena 
99*2d1d418eSSumit Saxena #endif  /* MPI30_SAS_H */
100