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