1 /*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright (c) 2000-2012 LSI Corporation.
24 *
25 * Redistribution and use in source and binary forms of all code within
26 * this file that is exclusively owned by LSI, with or without
27 * modification, is permitted provided that, in addition to the CDDL 1.0
28 * License requirements, the following conditions are met:
29 *
30 * Neither the name of the author nor the names of its contributors may be
31 * used to endorse or promote products derived from this software without
32 * specific prior written permission.
33 *
34 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
35 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
36 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
37 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
38 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
39 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
40 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
41 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
42 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
43 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
44 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
45 * DAMAGE.
46 */
47
48 /*
49 * Name: mpi2_raid.h
50 * Title: MPI Integrated RAID messages and structures
51 * Creation Date: April 26, 2007
52 *
53 * mpi2_raid.h Version: 02.00.05
54 *
55 * Version History
56 * ---------------
57 *
58 * Date Version Description
59 * -------- -------- ------------------------------------------------------
60 * 04-30-07 02.00.00 Corresponds to Fusion-MPT MPI Specification Rev A.
61 * 08-31-07 02.00.01 Modifications to RAID Action request and reply,
62 * including the Actions and ActionData.
63 * 02-29-08 02.00.02 Added MPI2_RAID_ACTION_ADATA_DISABL_FULL_REBUILD.
64 * 05-21-08 02.00.03 Added MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS so that
65 * the PhysDisk array in MPI2_RAID_VOLUME_CREATION_STRUCT
66 * can be sized by the build environment.
67 * 07-30-09 02.00.04 Added proper define for the Use Default Settings bit of
68 * VolumeCreationFlags and marked the old one as obsolete.
69 * 05-12-10 02.00.05 Added MPI2_RAID_VOL_FLAGS_OP_MDC define.
70 * --------------------------------------------------------------------------
71 */
72
73 #ifndef MPI2_RAID_H
74 #define MPI2_RAID_H
75
76 /*****************************************************************************
77 *
78 * Integrated RAID Messages
79 *
80 *****************************************************************************/
81
82 /****************************************************************************
83 * RAID Action messages
84 ****************************************************************************/
85
86 /* ActionDataWord defines for use with MPI2_RAID_ACTION_DELETE_VOLUME action */
87 #define MPI2_RAID_ACTION_ADATA_KEEP_LBA0 (0x00000000)
88 #define MPI2_RAID_ACTION_ADATA_ZERO_LBA0 (0x00000001)
89
90 /* use MPI2_RAIDVOL0_SETTING_ defines from mpi2_cnfg.h for MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE action */
91
92 /* ActionDataWord defines for use with MPI2_RAID_ACTION_DISABLE_ALL_VOLUMES action */
93 #define MPI2_RAID_ACTION_ADATA_DISABL_FULL_REBUILD (0x00000001)
94
95 /* ActionDataWord for MPI2_RAID_ACTION_SET_RAID_FUNCTION_RATE Action */
96 typedef struct _MPI2_RAID_ACTION_RATE_DATA
97 {
98 U8 RateToChange; /* 0x00 */
99 U8 RateOrMode; /* 0x01 */
100 U16 DataScrubDuration; /* 0x02 */
101 } MPI2_RAID_ACTION_RATE_DATA, MPI2_POINTER PTR_MPI2_RAID_ACTION_RATE_DATA,
102 Mpi2RaidActionRateData_t, MPI2_POINTER pMpi2RaidActionRateData_t;
103
104 #define MPI2_RAID_ACTION_SET_RATE_RESYNC (0x00)
105 #define MPI2_RAID_ACTION_SET_RATE_DATA_SCRUB (0x01)
106 #define MPI2_RAID_ACTION_SET_RATE_POWERSAVE_MODE (0x02)
107
108 /* ActionDataWord for MPI2_RAID_ACTION_START_RAID_FUNCTION Action */
109 typedef struct _MPI2_RAID_ACTION_START_RAID_FUNCTION
110 {
111 U8 RAIDFunction; /* 0x00 */
112 U8 Flags; /* 0x01 */
113 U16 Reserved1; /* 0x02 */
114 } MPI2_RAID_ACTION_START_RAID_FUNCTION,
115 MPI2_POINTER PTR_MPI2_RAID_ACTION_START_RAID_FUNCTION,
116 Mpi2RaidActionStartRaidFunction_t,
117 MPI2_POINTER pMpi2RaidActionStartRaidFunction_t;
118
119 /* defines for the RAIDFunction field */
120 #define MPI2_RAID_ACTION_START_BACKGROUND_INIT (0x00)
121 #define MPI2_RAID_ACTION_START_ONLINE_CAP_EXPANSION (0x01)
122 #define MPI2_RAID_ACTION_START_CONSISTENCY_CHECK (0x02)
123
124 /* defines for the Flags field */
125 #define MPI2_RAID_ACTION_START_NEW (0x00)
126 #define MPI2_RAID_ACTION_START_RESUME (0x01)
127
128 /* ActionDataWord for MPI2_RAID_ACTION_STOP_RAID_FUNCTION Action */
129 typedef struct _MPI2_RAID_ACTION_STOP_RAID_FUNCTION
130 {
131 U8 RAIDFunction; /* 0x00 */
132 U8 Flags; /* 0x01 */
133 U16 Reserved1; /* 0x02 */
134 } MPI2_RAID_ACTION_STOP_RAID_FUNCTION,
135 MPI2_POINTER PTR_MPI2_RAID_ACTION_STOP_RAID_FUNCTION,
136 Mpi2RaidActionStopRaidFunction_t,
137 MPI2_POINTER pMpi2RaidActionStopRaidFunction_t;
138
139 /* defines for the RAIDFunction field */
140 #define MPI2_RAID_ACTION_STOP_BACKGROUND_INIT (0x00)
141 #define MPI2_RAID_ACTION_STOP_ONLINE_CAP_EXPANSION (0x01)
142 #define MPI2_RAID_ACTION_STOP_CONSISTENCY_CHECK (0x02)
143
144 /* defines for the Flags field */
145 #define MPI2_RAID_ACTION_STOP_ABORT (0x00)
146 #define MPI2_RAID_ACTION_STOP_PAUSE (0x01)
147
148 /* ActionDataWord for MPI2_RAID_ACTION_CREATE_HOT_SPARE Action */
149 typedef struct _MPI2_RAID_ACTION_HOT_SPARE
150 {
151 U8 HotSparePool; /* 0x00 */
152 U8 Reserved1; /* 0x01 */
153 U16 DevHandle; /* 0x02 */
154 } MPI2_RAID_ACTION_HOT_SPARE, MPI2_POINTER PTR_MPI2_RAID_ACTION_HOT_SPARE,
155 Mpi2RaidActionHotSpare_t, MPI2_POINTER pMpi2RaidActionHotSpare_t;
156
157 /* ActionDataWord for MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE Action */
158 typedef struct _MPI2_RAID_ACTION_FW_UPDATE_MODE
159 {
160 U8 Flags; /* 0x00 */
161 U8 DeviceFirmwareUpdateModeTimeout; /* 0x01 */
162 U16 Reserved1; /* 0x02 */
163 } MPI2_RAID_ACTION_FW_UPDATE_MODE,
164 MPI2_POINTER PTR_MPI2_RAID_ACTION_FW_UPDATE_MODE,
165 Mpi2RaidActionFwUpdateMode_t, MPI2_POINTER pMpi2RaidActionFwUpdateMode_t;
166
167 /* ActionDataWord defines for use with MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE action */
168 #define MPI2_RAID_ACTION_ADATA_DISABLE_FW_UPDATE (0x00)
169 #define MPI2_RAID_ACTION_ADATA_ENABLE_FW_UPDATE (0x01)
170
171 typedef union _MPI2_RAID_ACTION_DATA
172 {
173 U32 Word;
174 MPI2_RAID_ACTION_RATE_DATA Rates;
175 MPI2_RAID_ACTION_START_RAID_FUNCTION StartRaidFunction;
176 MPI2_RAID_ACTION_STOP_RAID_FUNCTION StopRaidFunction;
177 MPI2_RAID_ACTION_HOT_SPARE HotSpare;
178 MPI2_RAID_ACTION_FW_UPDATE_MODE FwUpdateMode;
179 } MPI2_RAID_ACTION_DATA, MPI2_POINTER PTR_MPI2_RAID_ACTION_DATA,
180 Mpi2RaidActionData_t, MPI2_POINTER pMpi2RaidActionData_t;
181
182
183 /* RAID Action Request Message */
184 typedef struct _MPI2_RAID_ACTION_REQUEST
185 {
186 U8 Action; /* 0x00 */
187 U8 Reserved1; /* 0x01 */
188 U8 ChainOffset; /* 0x02 */
189 U8 Function; /* 0x03 */
190 U16 VolDevHandle; /* 0x04 */
191 U8 PhysDiskNum; /* 0x06 */
192 U8 MsgFlags; /* 0x07 */
193 U8 VP_ID; /* 0x08 */
194 U8 VF_ID; /* 0x09 */
195 U16 Reserved2; /* 0x0A */
196 U32 Reserved3; /* 0x0C */
197 MPI2_RAID_ACTION_DATA ActionDataWord; /* 0x10 */
198 MPI2_SGE_SIMPLE_UNION ActionDataSGE; /* 0x14 */
199 } MPI2_RAID_ACTION_REQUEST, MPI2_POINTER PTR_MPI2_RAID_ACTION_REQUEST,
200 Mpi2RaidActionRequest_t, MPI2_POINTER pMpi2RaidActionRequest_t;
201
202 /* RAID Action request Action values */
203
204 #define MPI2_RAID_ACTION_INDICATOR_STRUCT (0x01)
205 #define MPI2_RAID_ACTION_CREATE_VOLUME (0x02)
206 #define MPI2_RAID_ACTION_DELETE_VOLUME (0x03)
207 #define MPI2_RAID_ACTION_DISABLE_ALL_VOLUMES (0x04)
208 #define MPI2_RAID_ACTION_ENABLE_ALL_VOLUMES (0x05)
209 #define MPI2_RAID_ACTION_PHYSDISK_OFFLINE (0x0A)
210 #define MPI2_RAID_ACTION_PHYSDISK_ONLINE (0x0B)
211 #define MPI2_RAID_ACTION_FAIL_PHYSDISK (0x0F)
212 #define MPI2_RAID_ACTION_ACTIVATE_VOLUME (0x11)
213 #define MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE (0x15)
214 #define MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE (0x17)
215 #define MPI2_RAID_ACTION_SET_VOLUME_NAME (0x18)
216 #define MPI2_RAID_ACTION_SET_RAID_FUNCTION_RATE (0x19)
217 #define MPI2_RAID_ACTION_ENABLE_FAILED_VOLUME (0x1C)
218 #define MPI2_RAID_ACTION_CREATE_HOT_SPARE (0x1D)
219 #define MPI2_RAID_ACTION_DELETE_HOT_SPARE (0x1E)
220 #define MPI2_RAID_ACTION_SYSTEM_SHUTDOWN_INITIATED (0x20)
221 #define MPI2_RAID_ACTION_START_RAID_FUNCTION (0x21)
222 #define MPI2_RAID_ACTION_STOP_RAID_FUNCTION (0x22)
223 #define MPI2_RAID_ACTION_FAST_PATH_PERMITTED (0x24)
224
225 /* RAID Volume Creation Structure */
226
227 /*
228 * The following define can be customized for the targeted product.
229 */
230 #ifndef MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS
231 #define MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS (1)
232 #endif
233
234 typedef struct _MPI2_RAID_VOLUME_PHYSDISK
235 {
236 U8 RAIDSetNum; /* 0x00 */
237 U8 PhysDiskMap; /* 0x01 */
238 U16 PhysDiskDevHandle; /* 0x02 */
239 } MPI2_RAID_VOLUME_PHYSDISK, MPI2_POINTER PTR_MPI2_RAID_VOLUME_PHYSDISK,
240 Mpi2RaidVolumePhysDisk_t, MPI2_POINTER pMpi2RaidVolumePhysDisk_t;
241
242 /* defines for the PhysDiskMap field */
243 #define MPI2_RAIDACTION_PHYSDISK_PRIMARY (0x01)
244 #define MPI2_RAIDACTION_PHYSDISK_SECONDARY (0x02)
245
246 typedef struct _MPI2_RAID_VOLUME_CREATION_STRUCT
247 {
248 U8 NumPhysDisks; /* 0x00 */
249 U8 VolumeType; /* 0x01 */
250 U16 Reserved1; /* 0x02 */
251 U32 VolumeCreationFlags; /* 0x04 */
252 U32 VolumeSettings; /* 0x08 */
253 U8 Reserved2; /* 0x0C */
254 U8 ResyncRate; /* 0x0D */
255 U16 DataScrubDuration; /* 0x0E */
256 U64 VolumeMaxLBA; /* 0x10 */
257 U32 StripeSize; /* 0x18 */
258 U8 Name[16]; /* 0x1C */
259 MPI2_RAID_VOLUME_PHYSDISK PhysDisk[MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS];/* 0x2C */
260 } MPI2_RAID_VOLUME_CREATION_STRUCT,
261 MPI2_POINTER PTR_MPI2_RAID_VOLUME_CREATION_STRUCT,
262 Mpi2RaidVolumeCreationStruct_t, MPI2_POINTER pMpi2RaidVolumeCreationStruct_t;
263
264 /* use MPI2_RAID_VOL_TYPE_ defines from mpi2_cnfg.h for VolumeType */
265
266 /* defines for the VolumeCreationFlags field */
267 #define MPI2_RAID_VOL_CREATION_DEFAULT_SETTINGS (0x80000000)
268 #define MPI2_RAID_VOL_CREATION_BACKGROUND_INIT (0x00000004)
269 #define MPI2_RAID_VOL_CREATION_LOW_LEVEL_INIT (0x00000002)
270 #define MPI2_RAID_VOL_CREATION_MIGRATE_DATA (0x00000001)
271 /* The following is an obsolete define.
272 * It must be shifted left 24 bits in order to set the proper bit.
273 */
274 #define MPI2_RAID_VOL_CREATION_USE_DEFAULT_SETTINGS (0x80)
275
276
277 /* RAID Online Capacity Expansion Structure */
278
279 typedef struct _MPI2_RAID_ONLINE_CAPACITY_EXPANSION
280 {
281 U32 Flags; /* 0x00 */
282 U16 DevHandle0; /* 0x04 */
283 U16 Reserved1; /* 0x06 */
284 U16 DevHandle1; /* 0x08 */
285 U16 Reserved2; /* 0x0A */
286 } MPI2_RAID_ONLINE_CAPACITY_EXPANSION,
287 MPI2_POINTER PTR_MPI2_RAID_ONLINE_CAPACITY_EXPANSION,
288 Mpi2RaidOnlineCapacityExpansion_t,
289 MPI2_POINTER pMpi2RaidOnlineCapacityExpansion_t;
290
291
292 /* RAID Volume Indicator Structure */
293
294 typedef struct _MPI2_RAID_VOL_INDICATOR
295 {
296 U64 TotalBlocks; /* 0x00 */
297 U64 BlocksRemaining; /* 0x08 */
298 U32 Flags; /* 0x10 */
299 } MPI2_RAID_VOL_INDICATOR, MPI2_POINTER PTR_MPI2_RAID_VOL_INDICATOR,
300 Mpi2RaidVolIndicator_t, MPI2_POINTER pMpi2RaidVolIndicator_t;
301
302 /* defines for RAID Volume Indicator Flags field */
303 #define MPI2_RAID_VOL_FLAGS_OP_MASK (0x0000000F)
304 #define MPI2_RAID_VOL_FLAGS_OP_BACKGROUND_INIT (0x00000000)
305 #define MPI2_RAID_VOL_FLAGS_OP_ONLINE_CAP_EXPANSION (0x00000001)
306 #define MPI2_RAID_VOL_FLAGS_OP_CONSISTENCY_CHECK (0x00000002)
307 #define MPI2_RAID_VOL_FLAGS_OP_RESYNC (0x00000003)
308 #define MPI2_RAID_VOL_FLAGS_OP_MDC (0x00000004)
309
310
311 /* RAID Action Reply ActionData union */
312 typedef union _MPI2_RAID_ACTION_REPLY_DATA
313 {
314 U32 Word[5];
315 MPI2_RAID_VOL_INDICATOR RaidVolumeIndicator;
316 U16 VolDevHandle;
317 U8 VolumeState;
318 U8 PhysDiskNum;
319 } MPI2_RAID_ACTION_REPLY_DATA, MPI2_POINTER PTR_MPI2_RAID_ACTION_REPLY_DATA,
320 Mpi2RaidActionReplyData_t, MPI2_POINTER pMpi2RaidActionReplyData_t;
321
322 /* use MPI2_RAIDVOL0_SETTING_ defines from mpi2_cnfg.h for MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE action */
323
324
325 /* RAID Action Reply Message */
326 typedef struct _MPI2_RAID_ACTION_REPLY
327 {
328 U8 Action; /* 0x00 */
329 U8 Reserved1; /* 0x01 */
330 U8 MsgLength; /* 0x02 */
331 U8 Function; /* 0x03 */
332 U16 VolDevHandle; /* 0x04 */
333 U8 PhysDiskNum; /* 0x06 */
334 U8 MsgFlags; /* 0x07 */
335 U8 VP_ID; /* 0x08 */
336 U8 VF_ID; /* 0x09 */
337 U16 Reserved2; /* 0x0A */
338 U16 Reserved3; /* 0x0C */
339 U16 IOCStatus; /* 0x0E */
340 U32 IOCLogInfo; /* 0x10 */
341 MPI2_RAID_ACTION_REPLY_DATA ActionData; /* 0x14 */
342 } MPI2_RAID_ACTION_REPLY, MPI2_POINTER PTR_MPI2_RAID_ACTION_REPLY,
343 Mpi2RaidActionReply_t, MPI2_POINTER pMpi2RaidActionReply_t;
344
345
346 #endif
347