VirtualBox

source: vbox/trunk/src/VBox/Devices/Storage/DevLsiLogicSCSI.h@ 27342

Last change on this file since 27342 was 25697, checked in by vboxsync, 15 years ago

LsiLogic: Fix gcc warning

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 123.0 KB
Line 
1/* $Id: DevLsiLogicSCSI.h 25697 2010-01-08 20:26:16Z vboxsync $ */
2/** @file
3 * VBox storage devices: LsiLogic LSI53c1030 SCSI controller - Defines and structures.
4 */
5
6/*
7 * Copyright (C) 2006-2009 Sun Microsystems, Inc.
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21#ifndef __DEVLSILOGICSCSI_H__
22#define __DEVLSILOGICSCSI_H__
23
24#include <iprt/stdint.h>
25
26/*
27 * I/O port registered in the ISA compatible range to let the BIOS access
28 * the controller.
29 */
30#define LSILOGIC_ISA_IO_PORT 0x340
31
32#define LSILOGICSCSI_REQUEST_QUEUE_DEPTH_DEFAULT 1024
33#define LSILOGICSCSI_REPLY_QUEUE_DEPTH_DEFAULT 128
34
35#define LSILOGICSCSI_MAXIMUM_CHAIN_DEPTH 3
36
37#define LSILOGIC_NR_OF_ALLOWED_BIGGER_LISTS 100
38
39/** Equal for all devices */
40#define LSILOGICSCSI_PCI_VENDOR_ID (0x1000)
41
42/** SPI SCSI controller (LSI53C1030) */
43#define LSILOGICSCSI_PCI_SPI_CTRLNAME "LSI53C1030"
44#define LSILOGICSCSI_PCI_SPI_DEVICE_ID (0x0030)
45#define LSILOGICSCSI_PCI_SPI_REVISION_ID (0x00)
46#define LSILOGICSCSI_PCI_SPI_CLASS_CODE (0x01)
47#define LSILOGICSCSI_PCI_SPI_SUBSYSTEM_VENDOR_ID (0x1000)
48#define LSILOGICSCSI_PCI_SPI_SUBSYSTEM_ID (0x8000)
49#define LSILOGICSCSI_PCI_SPI_PORTS_MAX 1
50#define LSILOGICSCSI_PCI_SPI_BUSES_MAX 1
51#define LSILOGICSCSI_PCI_SPI_DEVICES_PER_BUS_MAX 16
52#define LSILOGICSCSI_PCI_SPI_DEVICES_MAX (LSILOGICSCSI_PCI_SPI_BUSES_MAX*LSILOGICSCSI_PCI_SPI_DEVICES_PER_BUS_MAX)
53
54/** SAS SCSI controller (SAS1068 PCI-X Fusion-MPT SAS) */
55#define LSILOGICSCSI_PCI_SAS_CTRLNAME "SAS1068"
56#define LSILOGICSCSI_PCI_SAS_DEVICE_ID (0x0054)
57#define LSILOGICSCSI_PCI_SAS_REVISION_ID (0x00)
58#define LSILOGICSCSI_PCI_SAS_CLASS_CODE (0x00)
59#define LSILOGICSCSI_PCI_SAS_SUBSYSTEM_VENDOR_ID (0x1000)
60#define LSILOGICSCSI_PCI_SAS_SUBSYSTEM_ID (0x8000)
61#define LSILOGICSCSI_PCI_SAS_PORTS_MAX 256
62#define LSILOGICSCSI_PCI_SAS_PORTS_DEFAULT 8
63#define LSILOGICSCSI_PCI_SAS_DEVICES_PER_PORT_MAX 1
64#define LSILOGICSCSI_PCI_SAS_DEVICES_MAX (LSILOGICSCSI_PCI_SAS_PORTS_MAX * LSILOGICSCSI_PCI_SAS_DEVICES_PER_PORT_MAX)
65
66/**
67 * A SAS address.
68 */
69#pragma pack(1)
70typedef union SASADDRESS
71{
72 /** 64bit view. */
73 uint64_t u64Address;
74 /** 32bit view. */
75 uint32_t u32Address[2];
76 /** 16bit view. */
77 uint16_t u16Address[4];
78 /** Byte view. */
79 uint8_t u8Address[8];
80} SASADDRESS, *PSASADDRESS;
81#pragma pack()
82AssertCompileSize(SASADDRESS, 8);
83
84/**
85 * Possible device types we support.
86 */
87typedef enum LSILOGICCTRLTYPE
88{
89 /** SPI SCSI controller (PCI dev id 0x0030) */
90 LSILOGICCTRLTYPE_SCSI_SPI = 0,
91 /** SAS SCSI controller (PCI dev id 0x0054) */
92 LSILOGICCTRLTYPE_SCSI_SAS = 1,
93 /** 32bit hack */
94 LSILOGICCTRLTYPE_32BIT_HACK = 0x7fffffff
95} LSILOGICCTRLTYPE, *PLSILOGICCTRLTYPE;
96
97/**
98 * A simple SG element for a 64bit adress.
99 */
100#pragma pack(1)
101typedef struct MptSGEntrySimple64
102{
103 /** Length of the buffer this entry describes. */
104 unsigned u24Length: 24;
105 /** Flag whether this element is the end of the list. */
106 unsigned fEndOfList: 1;
107 /** Flag whether the address is 32bit or 64bits wide. */
108 unsigned f64BitAddress: 1;
109 /** Flag whether this buffer contains data to be transfered or is the destination. */
110 unsigned fBufferContainsData: 1;
111 /** Flag whether this is a local address or a system address. */
112 unsigned fLocalAddress: 1;
113 /** Element type. */
114 unsigned u2ElementType: 2;
115 /** Flag whether this is the last element of the buffer. */
116 unsigned fEndOfBuffer: 1;
117 /** Flag whether this is the last element of the current segment. */
118 unsigned fLastElement: 1;
119 /** Lower 32bits of the address of the data buffer. */
120 unsigned u32DataBufferAddressLow: 32;
121 /** Upper 32bits of the address of the data buffer. */
122 unsigned u32DataBufferAddressHigh: 32;
123} MptSGEntrySimple64, *PMptSGEntrySimple64;
124#pragma pack()
125AssertCompileSize(MptSGEntrySimple64, 12);
126
127/**
128 * A simple SG element for a 32bit adress.
129 */
130#pragma pack(1)
131typedef struct MptSGEntrySimple32
132{
133 /** Length of the buffer this entry describes. */
134 unsigned u24Length: 24;
135 /** Flag whether this element is the end of the list. */
136 unsigned fEndOfList: 1;
137 /** Flag whether the address is 32bit or 64bits wide. */
138 unsigned f64BitAddress: 1;
139 /** Flag whether this buffer contains data to be transfered or is the destination. */
140 unsigned fBufferContainsData: 1;
141 /** Flag whether this is a local address or a system address. */
142 unsigned fLocalAddress: 1;
143 /** Element type. */
144 unsigned u2ElementType: 2;
145 /** Flag whether this is the last element of the buffer. */
146 unsigned fEndOfBuffer: 1;
147 /** Flag whether this is the last element of the current segment. */
148 unsigned fLastElement: 1;
149 /** Lower 32bits of the address of the data buffer. */
150 unsigned u32DataBufferAddressLow: 32;
151} MptSGEntrySimple32, *PMptSGEntrySimple32;
152#pragma pack()
153AssertCompileSize(MptSGEntrySimple32, 8);
154
155/**
156 * A chain SG element.
157 */
158#pragma pack(1)
159typedef struct MptSGEntryChain
160{
161 /** Size of the segment. */
162 unsigned u16Length: 16;
163 /** Offset in 32bit words of the next chain element in the segment
164 * identified by this element. */
165 unsigned u8NextChainOffset: 8;
166 /** Reserved. */
167 unsigned fReserved0: 1;
168 /** Flag whether the address is 32bit or 64bits wide. */
169 unsigned f64BitAddress: 1;
170 /** Reserved. */
171 unsigned fReserved1: 1;
172 /** Flag whether this is a local address or a system address. */
173 unsigned fLocalAddress: 1;
174 /** Element type. */
175 unsigned u2ElementType: 2;
176 /** Flag whether this is the last element of the buffer. */
177 unsigned u2Reserved2: 2;
178 /** Lower 32bits of the address of the data buffer. */
179 unsigned u32SegmentAddressLow: 32;
180 /** Upper 32bits of the address of the data buffer. */
181 unsigned u32SegmentAddressHigh: 32;
182} MptSGEntryChain, *PMptSGEntryChain;
183#pragma pack()
184AssertCompileSize(MptSGEntryChain, 12);
185
186typedef union MptSGEntryUnion
187{
188 MptSGEntrySimple64 Simple64;
189 MptSGEntrySimple32 Simple32;
190 MptSGEntryChain Chain;
191} MptSGEntryUnion, *PMptSGEntryUnion;
192
193/**
194 * MPT Fusion message header - Common for all message frames.
195 * This is filled in by the guest.
196 */
197#pragma pack(1)
198typedef struct MptMessageHdr
199{
200 /** Function dependent data. */
201 uint16_t u16FunctionDependent;
202 /** Chain offset. */
203 uint8_t u8ChainOffset;
204 /** The function code. */
205 uint8_t u8Function;
206 /** Function dependent data. */
207 uint8_t au8FunctionDependent[3];
208 /** Message flags. */
209 uint8_t u8MessageFlags;
210 /** Message context - Unique ID from the guest unmodified by the device. */
211 uint32_t u32MessageContext;
212} MptMessageHdr, *PMptMessageHdr;
213#pragma pack()
214AssertCompileSize(MptMessageHdr, 12);
215
216/** Defined function codes found in the message header. */
217#define MPT_MESSAGE_HDR_FUNCTION_SCSI_IO_REQUEST (0x00)
218#define MPT_MESSAGE_HDR_FUNCTION_SCSI_TASK_MGMT (0x01)
219#define MPT_MESSAGE_HDR_FUNCTION_IOC_INIT (0x02)
220#define MPT_MESSAGE_HDR_FUNCTION_IOC_FACTS (0x03)
221#define MPT_MESSAGE_HDR_FUNCTION_CONFIG (0x04)
222#define MPT_MESSAGE_HDR_FUNCTION_PORT_FACTS (0x05)
223#define MPT_MESSAGE_HDR_FUNCTION_PORT_ENABLE (0x06)
224#define MPT_MESSAGE_HDR_FUNCTION_EVENT_NOTIFICATION (0x07)
225#define MPT_MESSAGE_HDR_FUNCTION_EVENT_ACK (0x08)
226#define MPT_MESSAGE_HDR_FUNCTION_FW_DOWNLOAD (0x09)
227#define MPT_MESSAGE_HDR_FUNCTION_TARGET_CMD_BUFFER_POST (0x0A)
228#define MPT_MESSAGE_HDR_FUNCTION_TARGET_ASSIST (0x0B)
229#define MPT_MESSAGE_HDR_FUNCTION_TARGET_STATUS_SEND (0x0C)
230#define MPT_MESSAGE_HDR_FUNCTION_TARGET_MODE_ABORT (0x0D)
231
232#ifdef DEBUG
233/**
234 * Function names
235 */
236static const char * const g_apszMPTFunctionNames[] =
237{
238 "SCSI I/O Request",
239 "SCSI Task Management",
240 "IOC Init",
241 "IOC Facts",
242 "Config",
243 "Port Facts",
244 "Port Enable",
245 "Event Notification",
246 "Event Ack",
247 "Firmware Download"
248};
249#endif
250
251/**
252 * Default reply message.
253 * Send from the device to the guest upon completion of a request.
254 */
255 #pragma pack(1)
256typedef struct MptDefaultReplyMessage
257{
258 /** Function dependent data. */
259 uint16_t u16FunctionDependent;
260 /** Length of the message in 32bit DWords. */
261 uint8_t u8MessageLength;
262 /** Function which completed. */
263 uint8_t u8Function;
264 /** Function dependent. */
265 uint8_t au8FunctionDependent[3];
266 /** Message flags. */
267 uint8_t u8MessageFlags;
268 /** Message context given in the request. */
269 uint32_t u32MessageContext;
270 /** Function dependent status code. */
271 uint16_t u16FunctionDependentStatus;
272 /** Status of the IOC. */
273 uint16_t u16IOCStatus;
274 /** Additional log info. */
275 uint32_t u32IOCLogInfo;
276} MptDefaultReplyMessage, *PMptDefaultReplyMessage;
277#pragma pack()
278AssertCompileSize(MptDefaultReplyMessage, 20);
279
280/**
281 * IO controller init request.
282 */
283#pragma pack(1)
284typedef struct MptIOCInitRequest
285{
286 /** Which system send this init request. */
287 uint8_t u8WhoInit;
288 /** Reserved */
289 uint8_t u8Reserved;
290 /** Chain offset in the SG list. */
291 uint8_t u8ChainOffset;
292 /** Function to execute. */
293 uint8_t u8Function;
294 /** Flags */
295 uint8_t u8Flags;
296 /** Maximum number of devices the driver can handle. */
297 uint8_t u8MaxDevices;
298 /** Maximum number of buses the driver can handle. */
299 uint8_t u8MaxBuses;
300 /** Message flags. */
301 uint8_t u8MessageFlags;
302 /** Message context ID. */
303 uint32_t u32MessageContext;
304 /** Reply frame size. */
305 uint16_t u16ReplyFrameSize;
306 /** Reserved */
307 uint16_t u16Reserved;
308 /** Upper 32bit part of the 64bit address the message frames are in.
309 * That means all frames must be in the same 4GB segment. */
310 uint32_t u32HostMfaHighAddr;
311 /** Upper 32bit of the sense buffer. */
312 uint32_t u32SenseBufferHighAddr;
313} MptIOCInitRequest, *PMptIOCInitRequest;
314#pragma pack()
315AssertCompileSize(MptIOCInitRequest, 24);
316
317/**
318 * IO controller init reply.
319 */
320#pragma pack(1)
321typedef struct MptIOCInitReply
322{
323 /** Which subsystem send this init request. */
324 uint8_t u8WhoInit;
325 /** Reserved */
326 uint8_t u8Reserved;
327 /** Message length */
328 uint8_t u8MessageLength;
329 /** Function. */
330 uint8_t u8Function;
331 /** Flags */
332 uint8_t u8Flags;
333 /** Maximum number of devices the driver can handle. */
334 uint8_t u8MaxDevices;
335 /** Maximum number of busses the driver can handle. */
336 uint8_t u8MaxBuses;
337 /** Message flags. */
338 uint8_t u8MessageFlags;
339 /** Message context ID */
340 uint32_t u32MessageContext;
341 /** Reserved */
342 uint16_t u16Reserved;
343 /** IO controller status. */
344 uint16_t u16IOCStatus;
345 /** IO controller log information. */
346 uint32_t u32IOCLogInfo;
347} MptIOCInitReply, *PMptIOCInitReply;
348#pragma pack()
349AssertCompileSize(MptIOCInitReply, 20);
350
351/**
352 * IO controller facts request.
353 */
354#pragma pack(1)
355typedef struct MptIOCFactsRequest
356{
357 /** Reserved. */
358 uint16_t u16Reserved;
359 /** Chain offset in SG list. */
360 uint8_t u8ChainOffset;
361 /** Function number. */
362 uint8_t u8Function;
363 /** Reserved */
364 uint8_t u8Reserved[3];
365 /** Message flags. */
366 uint8_t u8MessageFlags;
367 /** Message context ID. */
368 uint32_t u32MessageContext;
369} MptIOCFactsRequest, *PMptIOCFactsRequest;
370#pragma pack()
371AssertCompileSize(MptIOCFactsRequest, 12);
372
373/**
374 * IO controller facts reply.
375 */
376#pragma pack(1)
377typedef struct MptIOCFactsReply
378{
379 /** Message version. */
380 uint16_t u16MessageVersion;
381 /** Message length. */
382 uint8_t u8MessageLength;
383 /** Function number. */
384 uint8_t u8Function;
385 /** Reserved */
386 uint16_t u16Reserved1;
387 /** IO controller number */
388 uint8_t u8IOCNumber;
389 /** Message flags. */
390 uint8_t u8MessageFlags;
391 /** Message context ID. */
392 uint32_t u32MessageContext;
393 /** IO controller exceptions */
394 uint16_t u16IOCExceptions;
395 /** IO controller status. */
396 uint16_t u16IOCStatus;
397 /** IO controller log information. */
398 uint32_t u32IOCLogInfo;
399 /** Maximum chain depth. */
400 uint8_t u8MaxChainDepth;
401 /** The current value of the WhoInit field. */
402 uint8_t u8WhoInit;
403 /** Block size. */
404 uint8_t u8BlockSize;
405 /** Flags. */
406 uint8_t u8Flags;
407 /** Depth of the reply queue. */
408 uint16_t u16ReplyQueueDepth;
409 /** Size of a request frame. */
410 uint16_t u16RequestFrameSize;
411 /** Reserved */
412 uint16_t u16Reserved2;
413 /** Product ID. */
414 uint16_t u16ProductID;
415 /** Current value of the high 32bit MFA address. */
416 uint32_t u32CurrentHostMFAHighAddr;
417 /** Global credits - Number of entries allocated to queues */
418 uint16_t u16GlobalCredits;
419 /** Number of ports on the IO controller */
420 uint8_t u8NumberOfPorts;
421 /** Event state. */
422 uint8_t u8EventState;
423 /** Current value of the high 32bit sense buffer address. */
424 uint32_t u32CurrentSenseBufferHighAddr;
425 /** Current reply frame size. */
426 uint16_t u16CurReplyFrameSize;
427 /** Maximum number of devices. */
428 uint8_t u8MaxDevices;
429 /** Maximum number of buses. */
430 uint8_t u8MaxBuses;
431 /** Size of the firmware image. */
432 uint32_t u32FwImageSize;
433 /** Reserved. */
434 uint32_t u32Reserved;
435 /** Firmware version */
436 uint32_t u32FWVersion;
437} MptIOCFactsReply, *PMptIOCFactsReply;
438#pragma pack()
439AssertCompileSize(MptIOCFactsReply, 60);
440
441/**
442 * Port facts request
443 */
444#pragma pack(1)
445typedef struct MptPortFactsRequest
446{
447 /** Reserved */
448 uint16_t u16Reserved1;
449 /** Message length. */
450 uint8_t u8MessageLength;
451 /** Function number. */
452 uint8_t u8Function;
453 /** Reserved */
454 uint16_t u16Reserved2;
455 /** Port number to get facts for. */
456 uint8_t u8PortNumber;
457 /** Message flags. */
458 uint8_t u8MessageFlags;
459 /** Message context ID. */
460 uint32_t u32MessageContext;
461} MptPortFactsRequest, *PMptPortFactsRequest;
462#pragma pack()
463AssertCompileSize(MptPortFactsRequest, 12);
464
465/**
466 * Port facts reply.
467 */
468#pragma pack(1)
469typedef struct MptPortFactsReply
470{
471 /** Reserved. */
472 uint16_t u16Reserved1;
473 /** Message length. */
474 uint8_t u8MessageLength;
475 /** Function number. */
476 uint8_t u8Function;
477 /** Reserved */
478 uint16_t u16Reserved2;
479 /** Port number the facts are for. */
480 uint8_t u8PortNumber;
481 /** Message flags. */
482 uint8_t u8MessageFlags;
483 /** Message context ID. */
484 uint32_t u32MessageContext;
485 /** Reserved. */
486 uint16_t u16Reserved3;
487 /** IO controller status. */
488 uint16_t u16IOCStatus;
489 /** IO controller log information. */
490 uint32_t u32IOCLogInfo;
491 /** Reserved */
492 uint8_t u8Reserved;
493 /** Port type */
494 uint8_t u8PortType;
495 /** Maximum number of devices on this port. */
496 uint16_t u16MaxDevices;
497 /** SCSI ID of this port on the attached bus. */
498 uint16_t u16PortSCSIID;
499 /** Protocol flags. */
500 uint16_t u16ProtocolFlags;
501 /** Maxmimum number of target command buffers which can be posted to this port at a time. */
502 uint16_t u16MaxPostedCmdBuffers;
503 /** Maximum number of target IDs that remain persistent between power/reset cycles. */
504 uint16_t u16MaxPersistentIDs;
505 /** Maximum number of LAN buckets. */
506 uint16_t u16MaxLANBuckets;
507 /** Reserved. */
508 uint16_t u16Reserved4;
509 /** Reserved. */
510 uint32_t u32Reserved;
511} MptPortFactsReply, *PMptPortFactsReply;
512#pragma pack()
513AssertCompileSize(MptPortFactsReply, 40);
514
515/**
516 * Port Enable request.
517 */
518#pragma pack(1)
519typedef struct MptPortEnableRequest
520{
521 /** Reserved. */
522 uint16_t u16Reserved1;
523 /** Message length. */
524 uint8_t u8MessageLength;
525 /** Function number. */
526 uint8_t u8Function;
527 /** Reserved. */
528 uint16_t u16Reserved2;
529 /** Port number to enable. */
530 uint8_t u8PortNumber;
531 /** Message flags. */
532 uint8_t u8MessageFlags;
533 /** Message context ID. */
534 uint32_t u32MessageContext;
535} MptPortEnableRequest, *PMptPortEnableRequest;
536#pragma pack()
537AssertCompileSize(MptPortEnableRequest, 12);
538
539/**
540 * Port enable reply.
541 */
542#pragma pack(1)
543typedef struct MptPortEnableReply
544{
545 /** Reserved. */
546 uint16_t u16Reserved1;
547 /** Message length. */
548 uint8_t u8MessageLength;
549 /** Function number. */
550 uint8_t u8Function;
551 /** Reserved */
552 uint16_t u16Reserved2;
553 /** Port number which was enabled. */
554 uint8_t u8PortNumber;
555 /** Message flags. */
556 uint8_t u8MessageFlags;
557 /** Message context ID. */
558 uint32_t u32MessageContext;
559 /** Reserved. */
560 uint16_t u16Reserved3;
561 /** IO controller status */
562 uint16_t u16IOCStatus;
563 /** IO controller log information. */
564 uint32_t u32IOCLogInfo;
565} MptPortEnableReply, *PMptPortEnableReply;
566#pragma pack()
567AssertCompileSize(MptPortEnableReply, 20);
568
569/**
570 * Event notification request.
571 */
572#pragma pack(1)
573typedef struct MptEventNotificationRequest
574{
575 /** Switch - Turns event notification on and off. */
576 uint8_t u8Switch;
577 /** Reserved. */
578 uint8_t u8Reserved1;
579 /** Chain offset. */
580 uint8_t u8ChainOffset;
581 /** Function number. */
582 uint8_t u8Function;
583 /** Reserved. */
584 uint8_t u8reserved2[3];
585 /** Message flags. */
586 uint8_t u8MessageFlags;
587 /** Message context ID. */
588 uint32_t u32MessageContext;
589} MptEventNotificationRequest, *PMptEventNotificationRequest;
590#pragma pack()
591AssertCompileSize(MptEventNotificationRequest, 12);
592
593/**
594 * Event notification reply.
595 */
596#pragma pack(1)
597typedef struct MptEventNotificationReply
598{
599 /** Event data length. */
600 uint16_t u16EventDataLength;
601 /** Message length. */
602 uint8_t u8MessageLength;
603 /** Function number. */
604 uint8_t u8Function;
605 /** Reserved. */
606 uint16_t u16Reserved1;
607 /** Ack required. */
608 uint8_t u8AckRequired;
609 /** Message flags. */
610 uint8_t u8MessageFlags;
611 /** Message context ID. */
612 uint32_t u32MessageContext;
613 /** Reserved. */
614 uint16_t u16Reserved2;
615 /** IO controller status. */
616 uint16_t u16IOCStatus;
617 /** IO controller log information. */
618 uint32_t u32IOCLogInfo;
619 /** Notification event. */
620 uint32_t u32Event;
621 /** Event context. */
622 uint32_t u32EventContext;
623 /** Event data. */
624 uint32_t u32EventData;
625} MptEventNotificationReply, *PMptEventNotificationReply;
626#pragma pack()
627AssertCompileSize(MptEventNotificationReply, 32);
628
629#define MPT_EVENT_EVENT_CHANGE (0x0000000a)
630
631/**
632 * SCSI IO Request
633 */
634#pragma pack(1)
635typedef struct MptSCSIIORequest
636{
637 /** Target ID */
638 uint8_t u8TargetID;
639 /** Bus number */
640 uint8_t u8Bus;
641 /** Chain offset */
642 uint8_t u8ChainOffset;
643 /** Function number. */
644 uint8_t u8Function;
645 /** CDB length. */
646 uint8_t u8CDBLength;
647 /** Sense buffer length. */
648 uint8_t u8SenseBufferLength;
649 /** Rserved */
650 uint8_t u8Reserved;
651 /** Message flags. */
652 uint8_t u8MessageFlags;
653 /** Message context ID. */
654 uint32_t u32MessageContext;
655 /** LUN */
656 uint8_t au8LUN[8];
657 /** Control values. */
658 uint32_t u32Control;
659 /** The CDB. */
660 uint8_t au8CDB[16];
661 /** Data length. */
662 uint32_t u32DataLength;
663 /** Sense buffer low 32bit address. */
664 uint32_t u32SenseBufferLowAddress;
665} MptSCSIIORequest, *PMptSCSIIORequest;
666#pragma pack()
667AssertCompileSize(MptSCSIIORequest, 48);
668
669#define MPT_SCSIIO_REQUEST_CONTROL_TXDIR_GET(x) (((x) & 0x3000000) >> 24)
670#define MPT_SCSIIO_REQUEST_CONTROL_TXDIR_NONE (0x0)
671#define MPT_SCSIIO_REQUEST_CONTROL_TXDIR_WRITE (0x1)
672#define MPT_SCSIIO_REQUEST_CONTROL_TXDIR_READ (0x2)
673
674/**
675 * SCSI IO error reply.
676 */
677#pragma pack(1)
678typedef struct MptSCSIIOErrorReply
679{
680 /** Target ID */
681 uint8_t u8TargetID;
682 /** Bus number */
683 uint8_t u8Bus;
684 /** Message length. */
685 uint8_t u8MessageLength;
686 /** Function number. */
687 uint8_t u8Function;
688 /** CDB length */
689 uint8_t u8CDBLength;
690 /** Sense buffer length */
691 uint8_t u8SenseBufferLength;
692 /** Reserved */
693 uint8_t u8Reserved;
694 /** Message flags */
695 uint8_t u8MessageFlags;
696 /** Message context ID */
697 uint32_t u32MessageContext;
698 /** SCSI status. */
699 uint8_t u8SCSIStatus;
700 /** SCSI state */
701 uint8_t u8SCSIState;
702 /** IO controller status */
703 uint16_t u16IOCStatus;
704 /** IO controller log information */
705 uint32_t u32IOCLogInfo;
706 /** Transfer count */
707 uint32_t u32TransferCount;
708 /** Sense count */
709 uint32_t u32SenseCount;
710 /** Response information */
711 uint32_t u32ResponseInfo;
712} MptSCSIIOErrorReply, *PMptSCSIIOErrorReply;
713#pragma pack()
714AssertCompileSize(MptSCSIIOErrorReply, 32);
715
716#define MPT_SCSI_IO_ERROR_SCSI_STATE_AUTOSENSE_VALID (0x01)
717#define MPT_SCSI_IO_ERROR_SCSI_STATE_TERMINATED (0x08)
718
719/**
720 * IOC status codes sepcific to the SCSI I/O error reply.
721 */
722#define MPT_SCSI_IO_ERROR_IOCSTATUS_INVALID_BUS (0x0041)
723#define MPT_SCSI_IO_ERROR_IOCSTATUS_INVALID_TARGETID (0x0042)
724#define MPT_SCSI_IO_ERROR_IOCSTATUS_DEVICE_NOT_THERE (0x0043)
725
726/**
727 * SCSI task management request.
728 */
729#pragma pack(1)
730typedef struct MptSCSITaskManagementRequest
731{
732 /** Target ID */
733 uint8_t u8TargetID;
734 /** Bus number */
735 uint8_t u8Bus;
736 /** Chain offset */
737 uint8_t u8ChainOffset;
738 /** Function number */
739 uint8_t u8Function;
740 /** Reserved */
741 uint8_t u8Reserved1;
742 /** Task type */
743 uint8_t u8TaskType;
744 /** Reserved */
745 uint8_t u8Reserved2;
746 /** Message flags */
747 uint8_t u8MessageFlags;
748 /** Message context ID */
749 uint32_t u32MessageContext;
750 /** LUN */
751 uint8_t au8LUN[8];
752 /** Reserved */
753 uint8_t auReserved[28];
754 /** Task message context ID. */
755 uint32_t u32TaskMessageContext;
756} MptSCSITaskManagementRequest, *PMptSCSITaskManagementRequest;
757#pragma pack()
758AssertCompileSize(MptSCSITaskManagementRequest, 52);
759
760/**
761 * SCSI task management reply.
762 */
763#pragma pack(1)
764typedef struct MptSCSITaskManagementReply
765{
766 /** Target ID */
767 uint8_t u8TargetID;
768 /** Bus number */
769 uint8_t u8Bus;
770 /** Message length */
771 uint8_t u8MessageLength;
772 /** Function number */
773 uint8_t u8Function;
774 /** Reserved */
775 uint8_t u8Reserved1;
776 /** Task type */
777 uint8_t u8TaskType;
778 /** Reserved */
779 uint8_t u8Reserved2;
780 /** Message flags */
781 uint8_t u8MessageFlags;
782 /** Message context ID */
783 uint32_t u32MessageContext;
784 /** Reserved */
785 uint16_t u16Reserved;
786 /** IO controller status */
787 uint16_t u16IOCStatus;
788 /** IO controller log information */
789 uint32_t u32IOCLogInfo;
790 /** Termination count */
791 uint32_t u32TerminationCount;
792} MptSCSITaskManagementReply, *PMptSCSITaskManagementReply;
793#pragma pack()
794AssertCompileSize(MptSCSITaskManagementReply, 24);
795
796/**
797 * Page address for SAS expander page types.
798 */
799#pragma pack(1)
800typedef union MptConfigurationPageAddressSASExpander
801{
802 struct
803 {
804 uint16_t u16Handle;
805 uint16_t u16Reserved;
806 } Form0And2;
807 struct
808 {
809 uint16_t u16Handle;
810 uint8_t u8PhyNum;
811 uint8_t u8Reserved;
812 } Form1;
813} MptConfigurationPageAddressSASExpander, *PMptConfigurationPageAddressSASExpander;
814#pragma pack()
815
816/**
817 * Page address for SAS device page types.
818 */
819#pragma pack(1)
820typedef union MptConfigurationPageAddressSASDevice
821{
822 struct
823 {
824 uint16_t u16Handle;
825 uint16_t u16Reserved;
826 } Form0And2;
827 struct
828 {
829 uint8_t u8TargetID;
830 uint8_t u8Bus;
831 uint8_t u8Reserved;
832 } Form1;
833} MptConfigurationPageAddressSASDevice, *PMptConfigurationPageAddressSASDevice;
834#pragma pack()
835
836/**
837 * Page address for SAS PHY page types.
838 */
839#pragma pack(1)
840typedef union MptConfigurationPageAddressSASPHY
841{
842 struct
843 {
844 uint8_t u8PhyNumber;
845 uint8_t u8Reserved[3];
846 } Form0;
847 struct
848 {
849 uint16_t u16Index;
850 uint16_t u16Reserved;
851 } Form1;
852} MptConfigurationPageAddressSASPHY, *PMptConfigurationPageAddressSASPHY;
853#pragma pack()
854
855/**
856 * Page address for SAS Enclosure page types.
857 */
858#pragma pack(1)
859typedef struct MptConfigurationPageAddressSASEnclosure
860{
861 uint16_t u16Handle;
862 uint16_t u16Reserved;
863} MptConfigurationPageAddressSASEnclosure, *PMptConfigurationPageAddressSASEnclosure;
864#pragma pack()
865
866/**
867 * Union of all possible address types.
868 */
869#pragma pack(1)
870typedef union MptConfigurationPageAddress
871{
872 /** 32bit view. */
873 uint32_t u32PageAddress;
874 struct
875 {
876 /** Port number to get the configuration page for. */
877 uint8_t u8PortNumber;
878 /** Reserved. */
879 uint8_t u8Reserved[3];
880 } MPIPortNumber;
881 struct
882 {
883 /** Target ID to get the configuration page for. */
884 uint8_t u8TargetID;
885 /** Bus number to get the configuration page for. */
886 uint8_t u8Bus;
887 /** Reserved. */
888 uint8_t u8Reserved[2];
889 } BusAndTargetId;
890 MptConfigurationPageAddressSASExpander SASExpander;
891 MptConfigurationPageAddressSASDevice SASDevice;
892 MptConfigurationPageAddressSASPHY SASPHY;
893 MptConfigurationPageAddressSASEnclosure SASEnclosure;
894} MptConfigurationPageAddress, *PMptConfigurationPageAddress;
895#pragma pack()
896AssertCompileSize(MptConfigurationPageAddress, 4);
897
898#define MPT_CONFIGURATION_PAGE_ADDRESS_GET_SAS_FORM(x) (((x).u32PageAddress >> 28) & 0x0f)
899
900/**
901 * Configuration request
902 */
903#pragma pack(1)
904typedef struct MptConfigurationRequest
905{
906 /** Action code. */
907 uint8_t u8Action;
908 /** Reserved. */
909 uint8_t u8Reserved1;
910 /** Chain offset. */
911 uint8_t u8ChainOffset;
912 /** Function number. */
913 uint8_t u8Function;
914 /** Extended page length. */
915 uint16_t u16ExtPageLength;
916 /** Extended page type */
917 uint8_t u8ExtPageType;
918 /** Message flags. */
919 uint8_t u8MessageFlags;
920 /** Message context ID. */
921 uint32_t u32MessageContext;
922 /** Reserved. */
923 uint8_t u8Reserved2[8];
924 /** Version number of the page. */
925 uint8_t u8PageVersion;
926 /** Length of the page in 32bit Dwords. */
927 uint8_t u8PageLength;
928 /** Page number to access. */
929 uint8_t u8PageNumber;
930 /** Type of the page beeing accessed. */
931 uint8_t u8PageType;
932 /** Page type dependent address. */
933 MptConfigurationPageAddress PageAddress;
934 /** Simple SG element describing the buffer. */
935 MptSGEntrySimple64 SimpleSGElement;
936} MptConfigurationRequest, *PMptConfigurationRequest;
937#pragma pack()
938AssertCompileSize(MptConfigurationRequest, 40);
939
940/** Possible action codes. */
941#define MPT_CONFIGURATION_REQUEST_ACTION_HEADER (0x00)
942#define MPT_CONFIGURATION_REQUEST_ACTION_READ_CURRENT (0x01)
943#define MPT_CONFIGURATION_REQUEST_ACTION_WRITE_CURRENT (0x02)
944#define MPT_CONFIGURATION_REQUEST_ACTION_READ_DEFAULT (0x03)
945#define MPT_CONFIGURATION_REQUEST_ACTION_DEFAULT (0x04)
946#define MPT_CONFIGURATION_REQUEST_ACTION_READ_NVRAM (0x05)
947#define MPT_CONFIGURATION_REQUEST_ACTION_WRITE_NVRAM (0x06)
948
949/** Page type codes. */
950#define MPT_CONFIGURATION_REQUEST_PAGE_TYPE_IO_UNIT (0x00)
951#define MPT_CONFIGURATION_REQUEST_PAGE_TYPE_IOC (0x01)
952#define MPT_CONFIGURATION_REQUEST_PAGE_TYPE_BIOS (0x02)
953#define MPT_CONFIGURATION_REQUEST_PAGE_TYPE_SCSI_PORT (0x03)
954#define MPT_CONFIGURATION_REQUEST_PAGE_TYPE_EXTENDED (0x0F)
955
956/**
957 * Configuration reply.
958 */
959#pragma pack(1)
960typedef struct MptConfigurationReply
961{
962 /** Action code. */
963 uint8_t u8Action;
964 /** Reserved. */
965 uint8_t u8Reserved;
966 /** Message length. */
967 uint8_t u8MessageLength;
968 /** Function number. */
969 uint8_t u8Function;
970 /** Extended page length. */
971 uint16_t u16ExtPageLength;
972 /** Extended page type */
973 uint8_t u8ExtPageType;
974 /** Message flags. */
975 uint8_t u8MessageFlags;
976 /** Message context ID. */
977 uint32_t u32MessageContext;
978 /** Reserved. */
979 uint16_t u16Reserved;
980 /** I/O controller status. */
981 uint16_t u16IOCStatus;
982 /** I/O controller log information. */
983 uint32_t u32IOCLogInfo;
984 /** Version number of the page. */
985 uint8_t u8PageVersion;
986 /** Length of the page in 32bit Dwords. */
987 uint8_t u8PageLength;
988 /** Page number to access. */
989 uint8_t u8PageNumber;
990 /** Type of the page beeing accessed. */
991 uint8_t u8PageType;
992} MptConfigurationReply, *PMptConfigurationReply;
993#pragma pack()
994AssertCompileSize(MptConfigurationReply, 24);
995
996/** Additional I/O controller status codes for the configuration reply. */
997#define MPT_IOCSTATUS_CONFIG_INVALID_ACTION (0x0020)
998#define MPT_IOCSTATUS_CONFIG_INVALID_TYPE (0x0021)
999#define MPT_IOCSTATUS_CONFIG_INVALID_PAGE (0x0022)
1000#define MPT_IOCSTATUS_CONFIG_INVALID_DATA (0x0023)
1001#define MPT_IOCSTATUS_CONFIG_NO_DEFAULTS (0x0024)
1002#define MPT_IOCSTATUS_CONFIG_CANT_COMMIT (0x0025)
1003
1004/**
1005 * Union of all possible request messages.
1006 */
1007typedef union MptRequestUnion
1008{
1009 MptMessageHdr Header;
1010 MptIOCInitRequest IOCInit;
1011 MptIOCFactsRequest IOCFacts;
1012 MptPortFactsRequest PortFacts;
1013 MptPortEnableRequest PortEnable;
1014 MptEventNotificationRequest EventNotification;
1015 MptSCSIIORequest SCSIIO;
1016 MptSCSITaskManagementRequest SCSITaskManagement;
1017 MptConfigurationRequest Configuration;
1018} MptRequestUnion, *PMptRequestUnion;
1019
1020/**
1021 * Union of all possible reply messages.
1022 */
1023typedef union MptReplyUnion
1024{
1025 /** 16bit view. */
1026 uint16_t au16Reply[30];
1027 MptDefaultReplyMessage Header;
1028 MptIOCInitReply IOCInit;
1029 MptIOCFactsReply IOCFacts;
1030 MptPortFactsReply PortFacts;
1031 MptPortEnableReply PortEnable;
1032 MptEventNotificationReply EventNotification;
1033 MptSCSIIOErrorReply SCSIIOError;
1034 MptSCSITaskManagementReply SCSITaskManagement;
1035 MptConfigurationReply Configuration;
1036} MptReplyUnion, *PMptReplyUnion;
1037
1038
1039/**
1040 * Configuration Page attributes.
1041 */
1042#define MPT_CONFIGURATION_PAGE_ATTRIBUTE_READONLY (0x00)
1043#define MPT_CONFIGURATION_PAGE_ATTRIBUTE_CHANGEABLE (0x10)
1044#define MPT_CONFIGURATION_PAGE_ATTRIBUTE_PERSISTENT (0x20)
1045#define MPT_CONFIGURATION_PAGE_ATTRIBUTE_PERSISTENT_READONLY (0x30)
1046
1047#define MPT_CONFIGURATION_PAGE_ATTRIBUTE_GET(u8PageType) ((u8PageType) & 0xf0)
1048
1049/**
1050 * Configuration Page types.
1051 */
1052#define MPT_CONFIGURATION_PAGE_TYPE_IO_UNIT (0x00)
1053#define MPT_CONFIGURATION_PAGE_TYPE_IOC (0x01)
1054#define MPT_CONFIGURATION_PAGE_TYPE_BIOS (0x02)
1055#define MPT_CONFIGURATION_PAGE_TYPE_SCSI_SPI_PORT (0x03)
1056#define MPT_CONFIGURATION_PAGE_TYPE_SCSI_SPI_DEVICE (0x04)
1057#define MPT_CONFIGURATION_PAGE_TYPE_MANUFACTURING (0x09)
1058#define MPT_CONFIGURATION_PAGE_TYPE_EXTENDED (0x0F)
1059
1060#define MPT_CONFIGURATION_PAGE_TYPE_GET(u8PageType) ((u8PageType) & 0x0f)
1061
1062/**
1063 * Extented page types.
1064 */
1065#define MPT_CONFIGURATION_PAGE_TYPE_EXTENDED_SASIOUNIT (0x10)
1066#define MPT_CONFIGURATION_PAGE_TYPE_EXTENDED_SASEXPANDER (0x11)
1067#define MPT_CONFIGURATION_PAGE_TYPE_EXTENDED_SASDEVICE (0x12)
1068#define MPT_CONFIGURATION_PAGE_TYPE_EXTENDED_SASPHYS (0x13)
1069#define MPT_CONFIGURATION_PAGE_TYPE_EXTENDED_LOG (0x14)
1070#define MPT_CONFIGURATION_PAGE_TYPE_EXTENDED_ENCLOSURE (0x15)
1071
1072/**
1073 * Configuration Page header - Common to all pages.
1074 */
1075#pragma pack(1)
1076typedef struct MptConfigurationPageHeader
1077{
1078 /** Version of the page. */
1079 uint8_t u8PageVersion;
1080 /** The length of the page in 32bit D-Words. */
1081 uint8_t u8PageLength;
1082 /** Number of the page. */
1083 uint8_t u8PageNumber;
1084 /** Type of the page. */
1085 uint8_t u8PageType;
1086} MptConfigurationPageHeader, *PMptConfigurationPageHeader;
1087#pragma pack()
1088AssertCompileSize(MptConfigurationPageHeader, 4);
1089
1090/**
1091 * Extended configuration page header - Common to all extended pages.
1092 */
1093#pragma pack(1)
1094typedef struct MptExtendedConfigurationPageHeader
1095{
1096 /** Version of the page. */
1097 uint8_t u8PageVersion;
1098 /** Reserved. */
1099 uint8_t u8Reserved1;
1100 /** Number of the page. */
1101 uint8_t u8PageNumber;
1102 /** Type of the page. */
1103 uint8_t u8PageType;
1104 /** Extended page length. */
1105 uint16_t u16ExtPageLength;
1106 /** Extended page type. */
1107 uint8_t u8ExtPageType;
1108 /** Reserved */
1109 uint8_t u8Reserved2;
1110} MptExtendedConfigurationPageHeader, *PMptExtendedConfigurationPageHeader;
1111#pragma pack()
1112AssertCompileSize(MptExtendedConfigurationPageHeader, 8);
1113
1114/**
1115 * Manufacturing page 0. - Readonly.
1116 */
1117#pragma pack(1)
1118typedef struct MptConfigurationPageManufacturing0
1119{
1120 /** Union. */
1121 union
1122 {
1123 /** Byte view. */
1124 uint8_t abPageData[76];
1125 /** Field view. */
1126 struct
1127 {
1128 /** The omnipresent header. */
1129 MptConfigurationPageHeader Header;
1130 /** Name of the chip. */
1131 uint8_t abChipName[16];
1132 /** Chip revision. */
1133 uint8_t abChipRevision[8];
1134 /** Board name. */
1135 uint8_t abBoardName[16];
1136 /** Board assembly. */
1137 uint8_t abBoardAssembly[16];
1138 /** Board tracer number. */
1139 uint8_t abBoardTracerNumber[16];
1140 } fields;
1141 } u;
1142} MptConfigurationPageManufacturing0, *PMptConfigurationPageManufacturing0;
1143#pragma pack()
1144AssertCompileSize(MptConfigurationPageManufacturing0, 76);
1145
1146/**
1147 * Manufacturing page 1. - Readonly Persistent.
1148 */
1149#pragma pack(1)
1150typedef struct MptConfigurationPageManufacturing1
1151{
1152 /** Union */
1153 union
1154 {
1155 /** Byte view */
1156 uint8_t abPageData[260];
1157 /** Field view */
1158 struct
1159 {
1160 /** The omnipresent header. */
1161 MptConfigurationPageHeader Header;
1162 /** VPD info - don't know what belongs here so all zero. */
1163 uint8_t abVPDInfo[256];
1164 } fields;
1165 } u;
1166} MptConfigurationPageManufacturing1, *PMptConfigurationPageManufacturing1;
1167#pragma pack()
1168AssertCompileSize(MptConfigurationPageManufacturing1, 260);
1169
1170/**
1171 * Manufacturing page 2. - Readonly.
1172 */
1173#pragma pack(1)
1174typedef struct MptConfigurationPageManufacturing2
1175{
1176 /** Union. */
1177 union
1178 {
1179 /** Byte view. */
1180 uint8_t abPageData[8];
1181 /** Field view. */
1182 struct
1183 {
1184 /** The omnipresent header. */
1185 MptConfigurationPageHeader Header;
1186 /** PCI Device ID. */
1187 uint16_t u16PCIDeviceID;
1188 /** PCI Revision ID. */
1189 uint8_t u8PCIRevisionID;
1190 /** Reserved. */
1191 uint8_t u8Reserved;
1192 /** Hardware specific settings... */
1193 } fields;
1194 } u;
1195} MptConfigurationPageManufacturing2, *PMptConfigurationPageManufacturing2;
1196#pragma pack()
1197AssertCompileSize(MptConfigurationPageManufacturing2, 8);
1198
1199/**
1200 * Manufacturing page 3. - Readonly.
1201 */
1202#pragma pack(1)
1203typedef struct MptConfigurationPageManufacturing3
1204{
1205 /** Union. */
1206 union
1207 {
1208 /** Byte view. */
1209 uint8_t abPageData[8];
1210 /** Field view. */
1211 struct
1212 {
1213 /** The omnipresent header. */
1214 MptConfigurationPageHeader Header;
1215 /** PCI Device ID. */
1216 uint16_t u16PCIDeviceID;
1217 /** PCI Revision ID. */
1218 uint8_t u8PCIRevisionID;
1219 /** Reserved. */
1220 uint8_t u8Reserved;
1221 /** Chip specific settings... */
1222 } fields;
1223 } u;
1224} MptConfigurationPageManufacturing3, *PMptConfigurationPageManufacturing3;
1225#pragma pack()
1226AssertCompileSize(MptConfigurationPageManufacturing3, 8);
1227
1228/**
1229 * Manufacturing page 4. - Readonly.
1230 */
1231#pragma pack(1)
1232typedef struct MptConfigurationPageManufacturing4
1233{
1234 /** Union. */
1235 union
1236 {
1237 /** Byte view. */
1238 uint8_t abPageData[84];
1239 /** Field view. */
1240 struct
1241 {
1242 /** The omnipresent header. */
1243 MptConfigurationPageHeader Header;
1244 /** Reserved. */
1245 uint32_t u32Reserved;
1246 /** InfoOffset0. */
1247 uint8_t u8InfoOffset0;
1248 /** Info size. */
1249 uint8_t u8InfoSize0;
1250 /** InfoOffset1. */
1251 uint8_t u8InfoOffset1;
1252 /** Info size. */
1253 uint8_t u8InfoSize1;
1254 /** Size of the inquiry data. */
1255 uint8_t u8InquirySize;
1256 /** Reserved. */
1257 uint8_t abReserved[3];
1258 /** Inquiry data. */
1259 uint8_t abInquiryData[56];
1260 /** IS volume settings. */
1261 uint32_t u32ISVolumeSettings;
1262 /** IME volume settings. */
1263 uint32_t u32IMEVolumeSettings;
1264 /** IM volume settings. */
1265 uint32_t u32IMVolumeSettings;
1266 } fields;
1267 } u;
1268} MptConfigurationPageManufacturing4, *PMptConfigurationPageManufacturing4;
1269#pragma pack()
1270AssertCompileSize(MptConfigurationPageManufacturing4, 84);
1271
1272/**
1273 * Manufacturing page 5 - Readonly.
1274 */
1275#pragma pack(1)
1276typedef struct MptConfigurationPageManufacturing5
1277{
1278 /** Union. */
1279 union
1280 {
1281 /** Byte view. */
1282 uint8_t abPageData[88];
1283 /** Field view. */
1284 struct
1285 {
1286 /** The omnipresent header. */
1287 MptConfigurationPageHeader Header;
1288 /** Base WWID. */
1289 uint64_t u64BaseWWID;
1290 /** Flags */
1291 uint8_t u8Flags;
1292 /** Number of ForceWWID fields in this page. */
1293 uint8_t u8NumForceWWID;
1294 /** Reserved */
1295 uint16_t u16Reserved;
1296 /** Reserved */
1297 uint32_t au32Reserved[2];
1298 /** ForceWWID entries Maximum of 8 because the SAS controller doesn't has more */
1299 uint64_t au64ForceWWID[8];
1300 } fields;
1301 } u;
1302} MptConfigurationPageManufacturing5, *PMptConfigurationPageManufacturing5;
1303#pragma pack()
1304AssertCompileSize(MptConfigurationPageManufacturing5, 24+64);
1305
1306/**
1307 * Manufacturing page 6 - Readonly.
1308 */
1309#pragma pack(1)
1310typedef struct MptConfigurationPageManufacturing6
1311{
1312 /** Union. */
1313 union
1314 {
1315 /** Byte view. */
1316 uint8_t abPageData[4];
1317 /** Field view. */
1318 struct
1319 {
1320 /** The omnipresent header. */
1321 MptConfigurationPageHeader Header;
1322 /** Product specific data - 0 for now */
1323 } fields;
1324 } u;
1325} MptConfigurationPageManufacturing6, *PMptConfigurationPageManufacturing6;
1326#pragma pack()
1327AssertCompileSize(MptConfigurationPageManufacturing6, 4);
1328
1329/**
1330 * Manufacutring page 7 - PHY element.
1331 */
1332#pragma pack(1)
1333typedef struct MptConfigurationPageManufacturing7PHY
1334{
1335 /** Pinout */
1336 uint32_t u32Pinout;
1337 /** Connector name */
1338 uint8_t szConnector[16];
1339 /** Location */
1340 uint8_t u8Location;
1341 /** reserved */
1342 uint8_t u8Reserved;
1343 /** Slot */
1344 uint16_t u16Slot;
1345} MptConfigurationPageManufacturing7PHY, *PMptConfigurationPageManufacturing7PHY;
1346#pragma pack()
1347AssertCompileSize(MptConfigurationPageManufacturing7PHY, 24);
1348
1349/**
1350 * Manufacturing page 7 - Readonly.
1351 */
1352#pragma pack(1)
1353typedef struct MptConfigurationPageManufacturing7
1354{
1355 /** Union. */
1356 union
1357 {
1358 /** Byte view. */
1359 uint8_t abPageData[1];
1360 /** Field view. */
1361 struct
1362 {
1363 /** The omnipresent header. */
1364 MptConfigurationPageHeader Header;
1365 /** Reserved */
1366 uint32_t au32Reserved[2];
1367 /** Flags */
1368 uint32_t u32Flags;
1369 /** Enclosure name */
1370 uint8_t szEnclosureName[16];
1371 /** Nummber of PHYs */
1372 uint8_t u8NumPhys;
1373 /** Reserved */
1374 uint8_t au8Reserved[3];
1375 /** PHY list for the SAS controller - variable depending on the number of ports */
1376 MptConfigurationPageManufacturing7PHY aPHY[1];
1377 } fields;
1378 } u;
1379} MptConfigurationPageManufacturing7, *PMptConfigurationPageManufacturing7;
1380#pragma pack()
1381AssertCompileSize(MptConfigurationPageManufacturing7, 36+sizeof(MptConfigurationPageManufacturing7PHY));
1382
1383#define LSILOGICSCSI_MANUFACTURING7_GET_SIZE(ports) (sizeof(MptConfigurationPageManufacturing7) + ((ports) - 1) * sizeof(MptConfigurationPageManufacturing7PHY))
1384
1385/** Flags for the flags field */
1386#define LSILOGICSCSI_MANUFACTURING7_FLAGS_USE_PROVIDED_INFORMATION RT_BIT(0)
1387
1388/** Flags for the pinout field */
1389#define LSILOGICSCSI_MANUFACTURING7_PINOUT_UNKNOWN RT_BIT(0)
1390#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8482 RT_BIT(1)
1391#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8470_LANE1 RT_BIT(8)
1392#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8470_LANE2 RT_BIT(9)
1393#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8470_LANE3 RT_BIT(10)
1394#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8470_LANE4 RT_BIT(11)
1395#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8484_LANE1 RT_BIT(16)
1396#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8484_LANE2 RT_BIT(17)
1397#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8484_LANE3 RT_BIT(18)
1398#define LSILOGICSCSI_MANUFACTURING7_PINOUT_SFF8484_LANE4 RT_BIT(19)
1399
1400/** Flags for the location field */
1401#define LSILOGICSCSI_MANUFACTURING7_LOCATION_UNKNOWN 0x01
1402#define LSILOGICSCSI_MANUFACTURING7_LOCATION_INTERNAL 0x02
1403#define LSILOGICSCSI_MANUFACTURING7_LOCATION_EXTERNAL 0x04
1404#define LSILOGICSCSI_MANUFACTURING7_LOCATION_SWITCHABLE 0x08
1405#define LSILOGICSCSI_MANUFACTURING7_LOCATION_AUTO 0x10
1406#define LSILOGICSCSI_MANUFACTURING7_LOCATION_NOT_PRESENT 0x20
1407#define LSILOGICSCSI_MANUFACTURING7_LOCATION_NOT_CONNECTED 0x80
1408
1409/**
1410 * Manufacturing page 8 - Readonly.
1411 */
1412#pragma pack(1)
1413typedef struct MptConfigurationPageManufacturing8
1414{
1415 /** Union. */
1416 union
1417 {
1418 /** Byte view. */
1419 uint8_t abPageData[4];
1420 /** Field view. */
1421 struct
1422 {
1423 /** The omnipresent header. */
1424 MptConfigurationPageHeader Header;
1425 /** Product specific information */
1426 } fields;
1427 } u;
1428} MptConfigurationPageManufacturing8, *PMptConfigurationPageManufacturing8;
1429#pragma pack()
1430AssertCompileSize(MptConfigurationPageManufacturing8, 4);
1431
1432/**
1433 * Manufacturing page 9 - Readonly.
1434 */
1435#pragma pack(1)
1436typedef struct MptConfigurationPageManufacturing9
1437{
1438 /** Union. */
1439 union
1440 {
1441 /** Byte view. */
1442 uint8_t abPageData[4];
1443 /** Field view. */
1444 struct
1445 {
1446 /** The omnipresent header. */
1447 MptConfigurationPageHeader Header;
1448 /** Product specific information */
1449 } fields;
1450 } u;
1451} MptConfigurationPageManufacturing9, *PMptConfigurationPageManufacturing9;
1452#pragma pack()
1453AssertCompileSize(MptConfigurationPageManufacturing9, 4);
1454
1455/**
1456 * Manufacturing page 10 - Readonly.
1457 */
1458#pragma pack(1)
1459typedef struct MptConfigurationPageManufacturing10
1460{
1461 /** Union. */
1462 union
1463 {
1464 /** Byte view. */
1465 uint8_t abPageData[4];
1466 /** Field view. */
1467 struct
1468 {
1469 /** The omnipresent header. */
1470 MptConfigurationPageHeader Header;
1471 /** Product specific information */
1472 } fields;
1473 } u;
1474} MptConfigurationPageManufacturing10, *PMptConfigurationPageManufacturing10;
1475#pragma pack()
1476AssertCompileSize(MptConfigurationPageManufacturing10, 4);
1477
1478/**
1479 * IO Unit page 0. - Readonly.
1480 */
1481#pragma pack(1)
1482typedef struct MptConfigurationPageIOUnit0
1483{
1484 /** Union. */
1485 union
1486 {
1487 /** Byte view. */
1488 uint8_t abPageData[12];
1489 /** Field view. */
1490 struct
1491 {
1492 /** The omnipresent header. */
1493 MptConfigurationPageHeader Header;
1494 /** A unique identifier. */
1495 uint64_t u64UniqueIdentifier;
1496 } fields;
1497 } u;
1498} MptConfigurationPageIOUnit0, *PMptConfigurationPageIOUnit0;
1499#pragma pack()
1500AssertCompileSize(MptConfigurationPageIOUnit0, 12);
1501
1502/**
1503 * IO Unit page 1. - Read/Write.
1504 */
1505#pragma pack(1)
1506typedef struct MptConfigurationPageIOUnit1
1507{
1508 /** Union. */
1509 union
1510 {
1511 /** Byte view. */
1512 uint8_t abPageData[8];
1513 /** Field view. */
1514 struct
1515 {
1516 /** The omnipresent header. */
1517 MptConfigurationPageHeader Header;
1518 /** Flag whether this is a single function PCI device. */
1519 unsigned fSingleFunction: 1;
1520 /** Flag whether all possible paths to a device are mapped. */
1521 unsigned fAllPathsMapped: 1;
1522 /** Reserved. */
1523 unsigned u4Reserved: 4;
1524 /** Flag whether all RAID functionality is disabled. */
1525 unsigned fIntegratedRAIDDisabled: 1;
1526 /** Flag whether 32bit PCI accesses are forced. */
1527 unsigned f32BitAccessForced: 1;
1528 /** Reserved. */
1529 unsigned abReserved: 24;
1530 } fields;
1531 } u;
1532} MptConfigurationPageIOUnit1, *PMptConfigurationPageIOUnit1;
1533#pragma pack()
1534AssertCompileSize(MptConfigurationPageIOUnit1, 8);
1535
1536/**
1537 * Adapter Ordering.
1538 */
1539#pragma pack(1)
1540typedef struct MptConfigurationPageIOUnit2AdapterOrdering
1541{
1542 /** PCI bus number. */
1543 unsigned u8PCIBusNumber: 8;
1544 /** PCI device and function number. */
1545 unsigned u8PCIDevFn: 8;
1546 /** Flag whether the adapter is embedded. */
1547 unsigned fAdapterEmbedded: 1;
1548 /** Flag whether the adapter is enabled. */
1549 unsigned fAdapterEnabled: 1;
1550 /** Reserved. */
1551 unsigned u6Reserved: 6;
1552 /** Reserved. */
1553 unsigned u8Reserved: 8;
1554} MptConfigurationPageIOUnit2AdapterOrdering, *PMptConfigurationPageIOUnit2AdapterOrdering;
1555#pragma pack()
1556AssertCompileSize(MptConfigurationPageIOUnit2AdapterOrdering, 4);
1557
1558/**
1559 * IO Unit page 2. - Read/Write.
1560 */
1561#pragma pack(1)
1562typedef struct MptConfigurationPageIOUnit2
1563{
1564 /** Union. */
1565 union
1566 {
1567 /** Byte view. */
1568 uint8_t abPageData[28];
1569 /** Field view. */
1570 struct
1571 {
1572 /** The omnipresent header. */
1573 MptConfigurationPageHeader Header;
1574 /** Reserved. */
1575 unsigned fReserved: 1;
1576 /** Flag whether Pause on error is enabled. */
1577 unsigned fPauseOnError: 1;
1578 /** Flag whether verbose mode is enabled. */
1579 unsigned fVerboseModeEnabled: 1;
1580 /** Set to disable color video. */
1581 unsigned fDisableColorVideo: 1;
1582 /** Flag whether int 40h is hooked. */
1583 unsigned fNotHookInt40h: 1;
1584 /** Reserved. */
1585 unsigned u3Reserved: 3;
1586 /** Reserved. */
1587 unsigned abReserved: 24;
1588 /** BIOS version. */
1589 uint32_t u32BIOSVersion;
1590 /** Adapter ordering. */
1591 MptConfigurationPageIOUnit2AdapterOrdering aAdapterOrder[4];
1592 } fields;
1593 } u;
1594} MptConfigurationPageIOUnit2, *PMptConfigurationPageIOUnit2;
1595#pragma pack()
1596AssertCompileSize(MptConfigurationPageIOUnit2, 28);
1597
1598/*
1599 * IO Unit page 3. - Read/Write.
1600 */
1601#pragma pack(1)
1602typedef struct MptConfigurationPageIOUnit3
1603{
1604 /** Union. */
1605 union
1606 {
1607 /** Byte view. */
1608 uint8_t abPageData[8];
1609 /** Field view. */
1610 struct
1611 {
1612 /** The omnipresent header. */
1613 MptConfigurationPageHeader Header;
1614 /** Number of GPIO values. */
1615 uint8_t u8GPIOCount;
1616 /** Reserved. */
1617 uint8_t abReserved[3];
1618 } fields;
1619 } u;
1620} MptConfigurationPageIOUnit3, *PMptConfigurationPageIOUnit3;
1621#pragma pack()
1622AssertCompileSize(MptConfigurationPageIOUnit3, 8);
1623
1624/*
1625 * IO Unit page 4. - Readonly for everyone except the BIOS.
1626 */
1627#pragma pack(1)
1628typedef struct MptConfigurationPageIOUnit4
1629{
1630 /** Union. */
1631 union
1632 {
1633 /** Byte view. */
1634 uint8_t abPageData[20];
1635 /** Field view. */
1636 struct
1637 {
1638 /** The omnipresent header. */
1639 MptConfigurationPageHeader Header;
1640 /** Reserved */
1641 uint32_t u32Reserved;
1642 /** SG entry describing the Firmware location. */
1643 MptSGEntrySimple64 FWImageSGE;
1644 } fields;
1645 } u;
1646} MptConfigurationPageIOUnit4, *PMptConfigurationPageIOUnit4;
1647#pragma pack()
1648AssertCompileSize(MptConfigurationPageIOUnit4, 20);
1649
1650/**
1651 * IOC page 0. - Readonly
1652 */
1653#pragma pack(1)
1654typedef struct MptConfigurationPageIOC0
1655{
1656 /** Union. */
1657 union
1658 {
1659 /** Byte view. */
1660 uint8_t abPageData[28];
1661 /** Field view. */
1662 struct
1663 {
1664 /** The omnipresent header. */
1665 MptConfigurationPageHeader Header;
1666 /** Total ammount of NV memory in bytes. */
1667 uint32_t u32TotalNVStore;
1668 /** Number of free bytes in the NV store. */
1669 uint32_t u32FreeNVStore;
1670 /** PCI vendor ID. */
1671 uint16_t u16VendorId;
1672 /** PCI device ID. */
1673 uint16_t u16DeviceId;
1674 /** PCI revision ID. */
1675 uint8_t u8RevisionId;
1676 /** Reserved. */
1677 uint8_t abReserved[3];
1678 /** PCI class code. */
1679 uint32_t u32ClassCode;
1680 /** Subsystem vendor Id. */
1681 uint16_t u16SubsystemVendorId;
1682 /** Subsystem Id. */
1683 uint16_t u16SubsystemId;
1684 } fields;
1685 } u;
1686} MptConfigurationPageIOC0, *PMptConfigurationPageIOC0;
1687#pragma pack()
1688AssertCompileSize(MptConfigurationPageIOC0, 28);
1689
1690/**
1691 * IOC page 1. - Read/Write
1692 */
1693#pragma pack(1)
1694typedef struct MptConfigurationPageIOC1
1695{
1696 /** Union. */
1697 union
1698 {
1699 /** Byte view. */
1700 uint8_t abPageData[16];
1701 /** Field view. */
1702 struct
1703 {
1704 /** The omnipresent header. */
1705 MptConfigurationPageHeader Header;
1706 /** Flag whether reply coalescing is enabled. */
1707 unsigned fReplyCoalescingEnabled: 1;
1708 /** Reserved. */
1709 unsigned u31Reserved: 31;
1710 /** Coalescing Timeout in microseconds. */
1711 unsigned u32CoalescingTimeout: 32;
1712 /** Coalescing depth. */
1713 unsigned u8CoalescingDepth: 8;
1714 /** Reserved. */
1715 unsigned u8Reserved0: 8;
1716 unsigned u8Reserved1: 8;
1717 unsigned u8Reserved2: 8;
1718 } fields;
1719 } u;
1720} MptConfigurationPageIOC1, *PMptConfigurationPageIOC1;
1721#pragma pack()
1722AssertCompileSize(MptConfigurationPageIOC1, 16);
1723
1724/**
1725 * IOC page 2. - Readonly
1726 */
1727#pragma pack(1)
1728typedef struct MptConfigurationPageIOC2
1729{
1730 /** Union. */
1731 union
1732 {
1733 /** Byte view. */
1734 uint8_t abPageData[12];
1735 /** Field view. */
1736 struct
1737 {
1738 /** The omnipresent header. */
1739 MptConfigurationPageHeader Header;
1740 /** Flag whether striping is supported. */
1741 unsigned fStripingSupported: 1;
1742 /** Flag whether enhanced mirroring is supported. */
1743 unsigned fEnhancedMirroringSupported: 1;
1744 /** Flag whether mirroring is supported. */
1745 unsigned fMirroringSupported: 1;
1746 /** Reserved. */
1747 unsigned u26Reserved: 26;
1748 /** Flag whether SES is supported. */
1749 unsigned fSESSupported: 1;
1750 /** Flag whether SAF-TE is supported. */
1751 unsigned fSAFTESupported: 1;
1752 /** Flag whether cross channel volumes are supported. */
1753 unsigned fCrossChannelVolumesSupported: 1;
1754 /** Number of active integrated RAID volumes. */
1755 unsigned u8NumActiveVolumes: 8;
1756 /** Maximum number of integrated RAID volumes supported. */
1757 unsigned u8MaxVolumes: 8;
1758 /** Number of active integrated RAID physical disks. */
1759 unsigned u8NumActivePhysDisks: 8;
1760 /** Maximum number of integrated RAID physical disks supported. */
1761 unsigned u8MaxPhysDisks: 8;
1762 /** RAID volumes... - not supported. */
1763 } fields;
1764 } u;
1765} MptConfigurationPageIOC2, *PMptConfigurationPageIOC2;
1766#pragma pack()
1767AssertCompileSize(MptConfigurationPageIOC2, 12);
1768
1769/**
1770 * IOC page 3. - Readonly
1771 */
1772#pragma pack(1)
1773typedef struct MptConfigurationPageIOC3
1774{
1775 /** Union. */
1776 union
1777 {
1778 /** Byte view. */
1779 uint8_t abPageData[8];
1780 /** Field view. */
1781 struct
1782 {
1783 /** The omnipresent header. */
1784 MptConfigurationPageHeader Header;
1785 /** Number of active integrated RAID physical disks. */
1786 uint8_t u8NumPhysDisks;
1787 /** Reserved. */
1788 uint8_t abReserved[3];
1789 } fields;
1790 } u;
1791} MptConfigurationPageIOC3, *PMptConfigurationPageIOC3;
1792#pragma pack()
1793AssertCompileSize(MptConfigurationPageIOC3, 8);
1794
1795/**
1796 * IOC page 4. - Read/Write
1797 */
1798#pragma pack(1)
1799typedef struct MptConfigurationPageIOC4
1800{
1801 /** Union. */
1802 union
1803 {
1804 /** Byte view. */
1805 uint8_t abPageData[8];
1806 /** Field view. */
1807 struct
1808 {
1809 /** The omnipresent header. */
1810 MptConfigurationPageHeader Header;
1811 /** Number of SEP entries in this page. */
1812 uint8_t u8ActiveSEP;
1813 /** Maximum number of SEp entries supported. */
1814 uint8_t u8MaxSEP;
1815 /** Reserved. */
1816 uint16_t u16Reserved;
1817 /** SEP entries... - not supported. */
1818 } fields;
1819 } u;
1820} MptConfigurationPageIOC4, *PMptConfigurationPageIOC4;
1821#pragma pack()
1822AssertCompileSize(MptConfigurationPageIOC4, 8);
1823
1824/**
1825 * IOC page 6. - Read/Write
1826 */
1827#pragma pack(1)
1828typedef struct MptConfigurationPageIOC6
1829{
1830 /** Union. */
1831 union
1832 {
1833 /** Byte view. */
1834 uint8_t abPageData[60];
1835 /** Field view. */
1836 struct
1837 {
1838 /** The omnipresent header. */
1839 MptConfigurationPageHeader Header;
1840 uint32_t u32CapabilitiesFlags;
1841 uint8_t u8MaxDrivesIS;
1842 uint8_t u8MaxDrivesIM;
1843 uint8_t u8MaxDrivesIME;
1844 uint8_t u8Reserved1;
1845 uint8_t u8MinDrivesIS;
1846 uint8_t u8MinDrivesIM;
1847 uint8_t u8MinDrivesIME;
1848 uint8_t u8Reserved2;
1849 uint8_t u8MaxGlobalHotSpares;
1850 uint8_t u8Reserved3;
1851 uint16_t u16Reserved4;
1852 uint32_t u32Reserved5;
1853 uint32_t u32SupportedStripeSizeMapIS;
1854 uint32_t u32SupportedStripeSizeMapIME;
1855 uint32_t u32Reserved6;
1856 uint8_t u8MetadataSize;
1857 uint8_t u8Reserved7;
1858 uint16_t u16Reserved8;
1859 uint16_t u16MaxBadBlockTableEntries;
1860 uint16_t u16Reserved9;
1861 uint16_t u16IRNvsramUsage;
1862 uint16_t u16Reserved10;
1863 uint32_t u32IRNvsramVersion;
1864 uint32_t u32Reserved11;
1865 } fields;
1866 } u;
1867} MptConfigurationPageIOC6, *PMptConfigurationPageIOC6;
1868#pragma pack()
1869AssertCompileSize(MptConfigurationPageIOC6, 60);
1870
1871/**
1872 * BIOS page 1 - Read/write.
1873 */
1874#pragma pack(1)
1875typedef struct MptConfigurationPageBIOS1
1876{
1877 /** Union. */
1878 union
1879 {
1880 /** Byte view. */
1881 uint8_t abPageData[48];
1882 /** Field view. */
1883 struct
1884 {
1885 /** The omnipresent header. */
1886 MptConfigurationPageHeader Header;
1887 /** BIOS options */
1888 uint32_t u32BiosOptions;
1889 /** IOC settings */
1890 uint32_t u32IOCSettings;
1891 /** Reserved */
1892 uint32_t u32Reserved;
1893 /** Device settings */
1894 uint32_t u32DeviceSettings;
1895 /** Number of devices */
1896 uint16_t u16NumberOfDevices;
1897 /** Expander spinup */
1898 uint8_t u8ExpanderSpinup;
1899 /** Reserved */
1900 uint8_t u8Reserved;
1901 /** I/O timeout of block devices without removable media */
1902 uint16_t u16IOTimeoutBlockDevicesNonRM;
1903 /** I/O timeout sequential */
1904 uint16_t u16IOTimeoutSequential;
1905 /** I/O timeout other */
1906 uint16_t u16IOTimeoutOther;
1907 /** I/O timeout of block devices with removable media */
1908 uint16_t u16IOTimeoutBlockDevicesRM;
1909 } fields;
1910 } u;
1911} MptConfigurationPageBIOS1, *PMptConfigurationPageBIOS1;
1912#pragma pack()
1913AssertCompileSize(MptConfigurationPageBIOS1, 48);
1914
1915#define LSILOGICSCSI_BIOS1_BIOSOPTIONS_BIOS_DISABLE RT_BIT(0)
1916#define LSILOGICSCSI_BIOS1_BIOSOPTIONS_SCAN_FROM_HIGH_TO_LOW RT_BIT(1)
1917#define LSILOGICSCSI_BIOS1_BIOSOPTIONS_BIOS_EXTENDED_SAS_SUPPORT RT_BIT(8)
1918#define LSILOGICSCSI_BIOS1_BIOSOPTIONS_BIOS_EXTENDED_FC_SUPPORT RT_BIT(9)
1919#define LSILOGICSCSI_BIOS1_BIOSOPTIONS_BIOS_EXTENDED_SPI_SUPPORT RT_BIT(10)
1920
1921#define LSILOGICSCSI_BIOS1_IOCSETTINGS_ALTERNATE_CHS RT_BIT(3)
1922
1923#define LSILOGICSCSI_BIOS1_IOCSETTINGS_ADAPTER_SUPPORT_SET(x) ((x) << 4)
1924#define LSILOGICSCSI_BIOS1_IOCSETTINGS_ADAPTER_SUPPORT_DISABLED 0x00
1925#define LSILOGICSCSI_BIOS1_IOCSETTINGS_ADAPTER_SUPPORT_BIOS_ONLY 0x01
1926#define LSILOGICSCSI_BIOS1_IOCSETTINGS_ADAPTER_SUPPORT_OS_ONLY 0x02
1927#define LSILOGICSCSI_BIOS1_IOCSETTINGS_ADAPTER_SUPPORT_BOT 0x03
1928
1929#define LSILOGICSCSI_BIOS1_IOCSETTINGS_REMOVABLE_MEDIA_SET(x) ((x) << 6)
1930#define LSILOGICSCSI_BIOS1_IOCSETTINGS_REMOVABLE_MEDIA_NO_INT13H 0x00
1931#define LSILOGICSCSI_BIOS1_IOCSETTINGS_REMOVABLE_BOOT_MEDIA_INT13H 0x01
1932#define LSILOGICSCSI_BIOS1_IOCSETTINGS_REMOVABLE_MEDIA_INT13H 0x02
1933
1934#define LSILOGICSCSI_BIOS1_IOCSETTINGS_SPINUP_DELAY_SET(x) ((x & 0xF) << 8)
1935#define LSILOGICSCSI_BIOS1_IOCSETTINGS_SPINUP_DELAY_GET(x) ((x >> 8) & 0x0F)
1936#define LSILOGICSCSI_BIOS1_IOCSETTINGS_MAX_TARGET_SPINUP_SET(x) ((x & 0xF) << 12)
1937#define LSILOGICSCSI_BIOS1_IOCSETTINGS_MAX_TARGET_SPINUP_GET(x) ((x >> 12) & 0x0F)
1938
1939#define LSILOGICSCSI_BIOS1_IOCSETTINGS_BOOT_PREFERENCE_SET(x) (((x) & 0x3) << 16)
1940#define LSILOGICSCSI_BIOS1_IOCSETTINGS_BOOT_PREFERENCE_ENCLOSURE 0x0
1941#define LSILOGICSCSI_BIOS1_IOCSETTINGS_BOOT_PREFERENCE_SAS_ADDRESS 0x1
1942
1943#define LSILOGICSCSI_BIOS1_IOCSETTINGS_DIRECT_ATTACH_SPINUP_MODE_ALL RT_BIT(18)
1944#define LSILOGICSCSI_BIOS1_IOCSETTINGS_AUTO_PORT_ENABLE RT_BIT(19)
1945
1946#define LSILOGICSCSI_BIOS1_IOCSETTINGS_PORT_ENABLE_REPLY_DELAY_SET(x) (((x) & 0xF) << 20)
1947#define LSILOGICSCSI_BIOS1_IOCSETTINGS_PORT_ENABLE_REPLY_DELAY_GET(x) ((x >> 20) & 0x0F)
1948
1949#define LSILOGICSCSI_BIOS1_IOCSETTINGS_PORT_ENABLE_SPINUP_DELAY_SET(x) (((x) & 0xF) << 24)
1950#define LSILOGICSCSI_BIOS1_IOCSETTINGS_PORT_ENABLE_SPINUP_DELAY_GET(x) ((x >> 24) & 0x0F)
1951
1952#define LSILOGICSCSI_BIOS1_DEVICESETTINGS_DISABLE_LUN_SCANS RT_BIT(0)
1953#define LSILOGICSCSI_BIOS1_DEVICESETTINGS_DISABLE_LUN_SCANS_FOR_NON_REMOVABLE_DEVICES RT_BIT(1)
1954#define LSILOGICSCSI_BIOS1_DEVICESETTINGS_DISABLE_LUN_SCANS_FOR_REMOVABLE_DEVICES RT_BIT(2)
1955#define LSILOGICSCSI_BIOS1_DEVICESETTINGS_DISABLE_LUN_SCANS2 RT_BIT(3)
1956#define LSILOGICSCSI_BIOS1_DEVICESETTINGS_DISABLE_SMART_POLLING RT_BIT(4)
1957
1958#define LSILOGICSCSI_BIOS1_EXPANDERSPINUP_SPINUP_DELAY_SET(x) ((x) & 0x0F)
1959#define LSILOGICSCSI_BIOS1_EXPANDERSPINUP_SPINUP_DELAY_GET(x) ((x) & 0x0F)
1960#define LSILOGICSCSI_BIOS1_EXPANDERSPINUP_MAX_SPINUP_DELAY_SET(x) (((x) & 0x0F) << 4)
1961#define LSILOGICSCSI_BIOS1_EXPANDERSPINUP_MAX_SPINUP_DELAY_GET(x) ((x >> 4) & 0x0F)
1962
1963/**
1964 * BIOS page 2 - Read/write.
1965 */
1966#pragma pack(1)
1967typedef struct MptConfigurationPageBIOS2
1968{
1969 /** Union. */
1970 union
1971 {
1972 /** Byte view. */
1973 uint8_t abPageData[384];
1974 /** Field view. */
1975 struct
1976 {
1977 /** The omnipresent header. */
1978 MptConfigurationPageHeader Header;
1979 /** Reserved */
1980 uint32_t au32Reserved[6];
1981 /** Format of the boot device field. */
1982 uint8_t u8BootDeviceForm;
1983 /** Previous format of the boot device field. */
1984 uint8_t u8PrevBootDeviceForm;
1985 /** Reserved */
1986 uint16_t u16Reserved;
1987 /** Boot device fields - dependent on the format */
1988 union
1989 {
1990 /** Device for AdapterNumber:Bus:Target:LUN */
1991 struct
1992 {
1993 /** Target ID */
1994 uint8_t u8TargetID;
1995 /** Bus */
1996 uint8_t u8Bus;
1997 /** Adapter Number */
1998 uint8_t u8AdapterNumber;
1999 /** Reserved */
2000 uint8_t u8Reserved;
2001 /** Reserved */
2002 uint32_t au32Reserved[3];
2003 /** LUN */
2004 uint32_t aLUN[5];
2005 /** Reserved */
2006 uint32_t au32Reserved2[56];
2007 } AdapterNumberBusTargetLUN;
2008 /** Device for PCIAddress:Bus:Target:LUN */
2009 struct
2010 {
2011 /** Target ID */
2012 uint8_t u8TargetID;
2013 /** Bus */
2014 uint8_t u8Bus;
2015 /** Adapter Number */
2016 uint16_t u16PCIAddress;
2017 /** Reserved */
2018 uint32_t au32Reserved[3];
2019 /** LUN */
2020 uint32_t aLUN[5];
2021 /** Reserved */
2022 uint32_t au32Reserved2[56];
2023 } PCIAddressBusTargetLUN;
2024 /** Device for PCISlotNo:Bus:Target:LUN */
2025 struct
2026 {
2027 /** Target ID */
2028 uint8_t u8TargetID;
2029 /** Bus */
2030 uint8_t u8Bus;
2031 /** PCI Slot Number */
2032 uint8_t u16PCISlotNo;
2033 /** Reserved */
2034 uint32_t au32Reserved[3];
2035 /** LUN */
2036 uint32_t aLUN[5];
2037 /** Reserved */
2038 uint32_t au32Reserved2[56];
2039 } PCIAddressBusSlotLUN;
2040 /** Device for FC channel world wide name */
2041 struct
2042 {
2043 /** World wide port name low */
2044 uint32_t u32WorldWidePortNameLow;
2045 /** World wide port name high */
2046 uint32_t u32WorldWidePortNameHigh;
2047 /** Reserved */
2048 uint32_t au32Reserved[3];
2049 /** LUN */
2050 uint32_t aLUN[5];
2051 /** Reserved */
2052 uint32_t au32Reserved2[56];
2053 } FCWorldWideName;
2054 /** Device for FC channel world wide name */
2055 struct
2056 {
2057 /** SAS address */
2058 SASADDRESS SASAddress;
2059 /** Reserved */
2060 uint32_t au32Reserved[3];
2061 /** LUN */
2062 uint32_t aLUN[5];
2063 /** Reserved */
2064 uint32_t au32Reserved2[56];
2065 } SASWorldWideName;
2066 /** Device for Enclosure/Slot */
2067 struct
2068 {
2069 /** Enclosure logical ID */
2070 uint64_t u64EnclosureLogicalID;
2071 /** Reserved */
2072 uint32_t au32Reserved[3];
2073 /** LUN */
2074 uint32_t aLUN[5];
2075 /** Reserved */
2076 uint32_t au32Reserved2[56];
2077 } EnclosureSlot;
2078 } BootDevice;
2079 } fields;
2080 } u;
2081} MptConfigurationPageBIOS2, *PMptConfigurationPageBIOS2;
2082#pragma pack()
2083AssertCompileSize(MptConfigurationPageBIOS2, 384);
2084
2085#define LSILOGICSCSI_BIOS2_BOOT_DEVICE_FORM_SET(x) ((x) & 0x0F)
2086#define LSILOGICSCSI_BIOS2_BOOT_DEVICE_FORM_FIRST 0x0
2087#define LSILOGICSCSI_BIOS2_BOOT_DEVICE_FORM_ADAPTER_BUS_TARGET_LUN 0x1
2088#define LSILOGICSCSI_BIOS2_BOOT_DEVICE_FORM_PCIADDR_BUS_TARGET_LUN 0x2
2089#define LSILOGICSCSI_BIOS2_BOOT_DEVICE_FORM_PCISLOT_BUS_TARGET_LUN 0x3
2090#define LSILOGICSCSI_BIOS2_BOOT_DEVICE_FORM_FC_WWN 0x4
2091#define LSILOGICSCSI_BIOS2_BOOT_DEVICE_FORM_SAS_WWN 0x5
2092#define LSILOGICSCSI_BIOS2_BOOT_DEVICE_FORM_ENCLOSURE_SLOT 0x6
2093
2094/**
2095 * BIOS page 4 - Read/Write (Where is 3? - not defined in the spec)
2096 */
2097#pragma pack(1)
2098typedef struct MptConfigurationPageBIOS4
2099{
2100 /** Union. */
2101 union
2102 {
2103 /** Byte view. */
2104 uint8_t abPageData[12];
2105 /** Field view. */
2106 struct
2107 {
2108 /** The omnipresent header. */
2109 MptConfigurationPageHeader Header;
2110 /** Reassignment Base WWID */
2111 uint64_t u64ReassignmentBaseWWID;
2112 } fields;
2113 } u;
2114} MptConfigurationPageBIOS4, *PMptConfigurationPageBIOS4;
2115#pragma pack()
2116AssertCompileSize(MptConfigurationPageBIOS4, 12);
2117
2118/**
2119 * SCSI-SPI port page 0. - Readonly
2120 */
2121#pragma pack(1)
2122typedef struct MptConfigurationPageSCSISPIPort0
2123{
2124 /** Union. */
2125 union
2126 {
2127 /** Byte view. */
2128 uint8_t abPageData[12];
2129 /** Field view. */
2130 struct
2131 {
2132 /** The omnipresent header. */
2133 MptConfigurationPageHeader Header;
2134 /** Flag whether this port is information unit trnafsers capable. */
2135 unsigned fInformationUnitTransfersCapable: 1;
2136 /** Flag whether the port is DT (Dual Transfer) capable. */
2137 unsigned fDTCapable: 1;
2138 /** Flag whether the port is QAS (Quick Arbitrate and Select) capable. */
2139 unsigned fQASCapable: 1;
2140 /** Reserved. */
2141 unsigned u5Reserved1: 5;
2142 /** Minimum Synchronous transfer period. */
2143 unsigned u8MinimumSynchronousTransferPeriod: 8;
2144 /** Maximum synchronous offset. */
2145 unsigned u8MaximumSynchronousOffset: 8;
2146 /** Reserved. */
2147 unsigned u5Reserved2: 5;
2148 /** Flag whether indicating the width of the bus - 0 narrow and 1 for wide. */
2149 unsigned fWide: 1;
2150 /** Reserved */
2151 unsigned fReserved: 1;
2152 /** Flag whether the port is AIP (Asynchronous Information Protection) capable. */
2153 unsigned fAIPCapable: 1;
2154 /** Signaling Type. */
2155 unsigned u2SignalingType: 2;
2156 /** Reserved. */
2157 unsigned u30Reserved: 30;
2158 } fields;
2159 } u;
2160} MptConfigurationPageSCSISPIPort0, *PMptConfigurationPageSCSISPIPort0;
2161#pragma pack()
2162AssertCompileSize(MptConfigurationPageSCSISPIPort0, 12);
2163
2164/**
2165 * SCSI-SPI port page 1. - Read/Write
2166 */
2167#pragma pack(1)
2168typedef struct MptConfigurationPageSCSISPIPort1
2169{
2170 /** Union. */
2171 union
2172 {
2173 /** Byte view. */
2174 uint8_t abPageData[12];
2175 /** Field view. */
2176 struct
2177 {
2178 /** The omnipresent header. */
2179 MptConfigurationPageHeader Header;
2180 /** The SCSI ID of the port. */
2181 uint8_t u8SCSIID;
2182 /** Reserved. */
2183 uint8_t u8Reserved;
2184 /** Port response IDs Bit mask field. */
2185 uint16_t u16PortResponseIDsBitmask;
2186 /** Value for the on BUS timer. */
2187 uint32_t u32OnBusTimerValue;
2188 } fields;
2189 } u;
2190} MptConfigurationPageSCSISPIPort1, *PMptConfigurationPageSCSISPIPort1;
2191#pragma pack()
2192AssertCompileSize(MptConfigurationPageSCSISPIPort1, 12);
2193
2194/**
2195 * Device settings for one device.
2196 */
2197#pragma pack(1)
2198typedef struct MptDeviceSettings
2199{
2200 /** Timeout for I/O in seconds. */
2201 unsigned u8Timeout: 8;
2202 /** Minimum synchronous factor. */
2203 unsigned u8SyncFactor: 8;
2204 /** Flag whether disconnect is enabled. */
2205 unsigned fDisconnectEnable: 1;
2206 /** Flag whether Scan ID is enabled. */
2207 unsigned fScanIDEnable: 1;
2208 /** Flag whether Scan LUNs is enabled. */
2209 unsigned fScanLUNEnable: 1;
2210 /** Flag whether tagged queuing is enabled. */
2211 unsigned fTaggedQueuingEnabled: 1;
2212 /** Flag whether wide is enabled. */
2213 unsigned fWideDisable: 1;
2214 /** Flag whether this device is bootable. */
2215 unsigned fBootChoice: 1;
2216 /** Reserved. */
2217 unsigned u10Reserved: 10;
2218} MptDeviceSettings, *PMptDeviceSettings;
2219#pragma pack()
2220AssertCompileSize(MptDeviceSettings, 4);
2221
2222/**
2223 * SCSI-SPI port page 2. - Read/Write for the BIOS
2224 */
2225#pragma pack(1)
2226typedef struct MptConfigurationPageSCSISPIPort2
2227{
2228 /** Union. */
2229 union
2230 {
2231 /** Byte view. */
2232 uint8_t abPageData[76];
2233 /** Field view. */
2234 struct
2235 {
2236 /** The omnipresent header. */
2237 MptConfigurationPageHeader Header;
2238 /** Flag indicating the bus scan order. */
2239 unsigned fBusScanOrderHighToLow: 1;
2240 /** Reserved. */
2241 unsigned fReserved: 1;
2242 /** Flag whether SCSI Bus resets are avoided. */
2243 unsigned fAvoidSCSIBusResets: 1;
2244 /** Flag whether alternate CHS is used. */
2245 unsigned fAlternateCHS: 1;
2246 /** Flag whether termination is disabled. */
2247 unsigned fTerminationDisabled: 1;
2248 /** Reserved. */
2249 unsigned u27Reserved: 27;
2250 /** Host SCSI ID. */
2251 unsigned u4HostSCSIID: 4;
2252 /** Initialize HBA. */
2253 unsigned u2InitializeHBA: 2;
2254 /** Removeable media setting. */
2255 unsigned u2RemovableMediaSetting: 2;
2256 /** Spinup delay. */
2257 unsigned u4SpinupDelay: 4;
2258 /** Negotiating settings. */
2259 unsigned u2NegotitatingSettings: 2;
2260 /** Reserved. */
2261 unsigned u18Reserved: 18;
2262 /** Device Settings. */
2263 MptDeviceSettings aDeviceSettings[16];
2264 } fields;
2265 } u;
2266} MptConfigurationPageSCSISPIPort2, *PMptConfigurationPageSCSISPIPort2;
2267#pragma pack()
2268AssertCompileSize(MptConfigurationPageSCSISPIPort2, 76);
2269
2270/**
2271 * SCSI-SPI device page 0. - Readonly
2272 */
2273#pragma pack(1)
2274typedef struct MptConfigurationPageSCSISPIDevice0
2275{
2276 /** Union. */
2277 union
2278 {
2279 /** Byte view. */
2280 uint8_t abPageData[12];
2281 /** Field view. */
2282 struct
2283 {
2284 /** The omnipresent header. */
2285 MptConfigurationPageHeader Header;
2286 /** Negotiated Parameters. */
2287 /** Information Units enabled. */
2288 unsigned fInformationUnitsEnabled: 1;
2289 /** Dual Transfers Enabled. */
2290 unsigned fDTEnabled: 1;
2291 /** QAS enabled. */
2292 unsigned fQASEnabled: 1;
2293 /** Reserved. */
2294 unsigned u5Reserved1: 5;
2295 /** Synchronous Transfer period. */
2296 unsigned u8NegotiatedSynchronousTransferPeriod: 8;
2297 /** Synchronous offset. */
2298 unsigned u8NegotiatedSynchronousOffset: 8;
2299 /** Reserved. */
2300 unsigned u5Reserved2: 5;
2301 /** Width - 0 for narrow and 1 for wide. */
2302 unsigned fWide: 1;
2303 /** Reserved. */
2304 unsigned fReserved: 1;
2305 /** AIP enabled. */
2306 unsigned fAIPEnabled: 1;
2307 /** Flag whether negotiation occurred. */
2308 unsigned fNegotationOccured: 1;
2309 /** Flag whether a SDTR message was rejected. */
2310 unsigned fSDTRRejected: 1;
2311 /** Flag whether a WDTR message was rejected. */
2312 unsigned fWDTRRejected: 1;
2313 /** Flag whether a PPR message was rejected. */
2314 unsigned fPPRRejected: 1;
2315 /** Reserved. */
2316 unsigned u28Reserved: 28;
2317 } fields;
2318 } u;
2319} MptConfigurationPageSCSISPIDevice0, *PMptConfigurationPageSCSISPIDevice0;
2320#pragma pack()
2321AssertCompileSize(MptConfigurationPageSCSISPIDevice0, 12);
2322
2323/**
2324 * SCSI-SPI device page 1. - Read/Write
2325 */
2326#pragma pack(1)
2327typedef struct MptConfigurationPageSCSISPIDevice1
2328{
2329 /** Union. */
2330 union
2331 {
2332 /** Byte view. */
2333 uint8_t abPageData[16];
2334 /** Field view. */
2335 struct
2336 {
2337 /** The omnipresent header. */
2338 MptConfigurationPageHeader Header;
2339 /** Requested Parameters. */
2340 /** Information Units enable. */
2341 bool fInformationUnitsEnable: 1;
2342 /** Dual Transfers Enable. */
2343 bool fDTEnable: 1;
2344 /** QAS enable. */
2345 bool fQASEnable: 1;
2346 /** Reserved. */
2347 unsigned u5Reserved1: 5;
2348 /** Synchronous Transfer period. */
2349 unsigned u8NegotiatedSynchronousTransferPeriod: 8;
2350 /** Synchronous offset. */
2351 unsigned u8NegotiatedSynchronousOffset: 8;
2352 /** Reserved. */
2353 unsigned u5Reserved2: 5;
2354 /** Width - 0 for narrow and 1 for wide. */
2355 bool fWide: 1;
2356 /** Reserved. */
2357 bool fReserved1: 1;
2358 /** AIP enable. */
2359 bool fAIPEnable: 1;
2360 /** Reserved. */
2361 bool fReserved2: 1;
2362 /** WDTR disallowed. */
2363 bool fWDTRDisallowed: 1;
2364 /** SDTR disallowed. */
2365 bool fSDTRDisallowed: 1;
2366 /** Reserved. */
2367 unsigned u29Reserved: 29;
2368 } fields;
2369 } u;
2370} MptConfigurationPageSCSISPIDevice1, *PMptConfigurationPageSCSISPIDevice1;
2371#pragma pack()
2372AssertCompileSize(MptConfigurationPageSCSISPIDevice1, 16);
2373
2374/**
2375 * SCSI-SPI device page 2. - Read/Write
2376 */
2377#pragma pack(1)
2378typedef struct MptConfigurationPageSCSISPIDevice2
2379{
2380 /** Union. */
2381 union
2382 {
2383 /** Byte view. */
2384 uint8_t abPageData[16];
2385 /** Field view. */
2386 struct
2387 {
2388 /** The omnipresent header. */
2389 MptConfigurationPageHeader Header;
2390 /** Reserved. */
2391 unsigned u4Reserved: 4;
2392 /** ISI enable. */
2393 unsigned fISIEnable: 1;
2394 /** Secondary driver enable. */
2395 unsigned fSecondaryDriverEnable: 1;
2396 /** Reserved. */
2397 unsigned fReserved: 1;
2398 /** Slew reate controler. */
2399 unsigned u3SlewRateControler: 3;
2400 /** Primary drive strength controler. */
2401 unsigned u3PrimaryDriveStrengthControl: 3;
2402 /** Secondary drive strength controler. */
2403 unsigned u3SecondaryDriveStrengthControl: 3;
2404 /** Reserved. */
2405 unsigned u12Reserved: 12;
2406 /** XCLKH_ST. */
2407 unsigned fXCLKH_ST: 1;
2408 /** XCLKS_ST. */
2409 unsigned fXCLKS_ST: 1;
2410 /** XCLKH_DT. */
2411 unsigned fXCLKH_DT: 1;
2412 /** XCLKS_DT. */
2413 unsigned fXCLKS_DT: 1;
2414 /** Parity pipe select. */
2415 unsigned u2ParityPipeSelect: 2;
2416 /** Reserved. */
2417 unsigned u30Reserved: 30;
2418 /** Data bit pipeline select. */
2419 unsigned u32DataPipelineSelect: 32;
2420 } fields;
2421 } u;
2422} MptConfigurationPageSCSISPIDevice2, *PMptConfigurationPageSCSISPIDevice2;
2423#pragma pack()
2424AssertCompileSize(MptConfigurationPageSCSISPIDevice2, 16);
2425
2426/**
2427 * SCSI-SPI device page 3 (Revision G). - Readonly
2428 */
2429#pragma pack(1)
2430typedef struct MptConfigurationPageSCSISPIDevice3
2431{
2432 /** Union. */
2433 union
2434 {
2435 /** Byte view. */
2436 uint8_t abPageData[1];
2437 /** Field view. */
2438 struct
2439 {
2440 /** The omnipresent header. */
2441 MptConfigurationPageHeader Header;
2442 /** Number of times the IOC rejected a message because it doesn't support the operation. */
2443 uint16_t u16MsgRejectCount;
2444 /** Number of times the SCSI bus entered an invalid operation state. */
2445 uint16_t u16PhaseErrorCount;
2446 /** Number of parity errors. */
2447 uint16_t u16ParityCount;
2448 /** Reserved. */
2449 uint16_t u16Reserved;
2450 } fields;
2451 } u;
2452} MptConfigurationPageSCSISPIDevice3, *PMptConfigurationPageSCSISPIDevice3;
2453#pragma pack()
2454AssertCompileSize(MptConfigurationPageSCSISPIDevice3, 12);
2455
2456/**
2457 * PHY entry for the SAS I/O unit page 0
2458 */
2459#pragma pack(1)
2460typedef struct MptConfigurationPageSASIOUnit0PHY
2461{
2462 /** Port number */
2463 uint8_t u8Port;
2464 /** Port flags */
2465 uint8_t u8PortFlags;
2466 /** Phy flags */
2467 uint8_t u8PhyFlags;
2468 /** negotiated link rate */
2469 uint8_t u8NegotiatedLinkRate;
2470 /** Controller phy device info */
2471 uint32_t u32ControllerPhyDeviceInfo;
2472 /** Attached device handle */
2473 uint16_t u16AttachedDevHandle;
2474 /** Controller device handle */
2475 uint16_t u16ControllerDevHandle;
2476 /** Discovery status */
2477 uint32_t u32DiscoveryStatus;
2478} MptConfigurationPageSASIOUnit0PHY, *PMptConfigurationPageSASIOUnit0PHY;
2479#pragma pack()
2480AssertCompileSize(MptConfigurationPageSASIOUnit0PHY, 16);
2481
2482/**
2483 * SAS I/O Unit page 0 - Readonly
2484 */
2485#pragma pack(1)
2486typedef struct MptConfigurationPageSASIOUnit0
2487{
2488 /** Union. */
2489 union
2490 {
2491 /** Byte view - variable. */
2492 uint8_t abPageData[1];
2493 /** Field view. */
2494 struct
2495 {
2496 /** The omnipresent header. */
2497 MptExtendedConfigurationPageHeader ExtHeader;
2498 /** Nvdata version default */
2499 uint16_t u16NvdataVersionDefault;
2500 /** Nvdata version persisent */
2501 uint16_t u16NvdataVersionPersistent;
2502 /** Number of physical ports */
2503 uint8_t u8NumPhys;
2504 /** Reserved */
2505 uint8_t au8Reserved[3];
2506 /** Content for each physical port - variable depending on the amount of ports. */
2507 MptConfigurationPageSASIOUnit0PHY aPHY[1];
2508 } fields;
2509 } u;
2510} MptConfigurationPageSASIOUnit0, *PMptConfigurationPageSASIOUnit0;
2511#pragma pack()
2512AssertCompileSize(MptConfigurationPageSASIOUnit0, 8+2+2+1+3+sizeof(MptConfigurationPageSASIOUnit0PHY));
2513
2514#define LSILOGICSCSI_SASIOUNIT0_GET_SIZE(ports) (sizeof(MptConfigurationPageSASIOUnit0) + ((ports) - 1) * sizeof(MptConfigurationPageSASIOUnit0PHY))
2515
2516#define LSILOGICSCSI_SASIOUNIT0_PORT_CONFIGURATION_AUTO RT_BIT(0)
2517#define LSILOGICSCSI_SASIOUNIT0_PORT_TARGET_IOC RT_BIT(2)
2518#define LSILOGICSCSI_SASIOUNIT0_PORT_DISCOVERY_IN_STATUS RT_BIT(3)
2519
2520#define LSILOGICSCSI_SASIOUNIT0_PHY_RX_INVERTED RT_BIT(0)
2521#define LSILOGICSCSI_SASIOUNIT0_PHY_TX_INVERTED RT_BIT(1)
2522#define LSILOGICSCSI_SASIOUNIT0_PHY_DISABLED RT_BIT(2)
2523
2524#define LSILOGICSCSI_SASIOUNIT0_NEGOTIATED_RATE_SET(x) ((x) & 0x0F)
2525#define LSILOGICSCSI_SASIOUNIT0_NEGOTIATED_RATE_GET(x) ((x) & 0x0F)
2526#define LSILOGICSCSI_SASIOUNIT0_NEGOTIATED_RATE_UNKNOWN 0x00
2527#define LSILOGICSCSI_SASIOUNIT0_NEGOTIATED_RATE_DISABLED 0x01
2528#define LSILOGICSCSI_SASIOUNIT0_NEGOTIATED_RATE_FAILED 0x02
2529#define LSILOGICSCSI_SASIOUNIT0_NEGOTIATED_RATE_SATA_OOB 0x03
2530#define LSILOGICSCSI_SASIOUNIT0_NEGOTIATED_RATE_15GB 0x08
2531#define LSILOGICSCSI_SASIOUNIT0_NEGOTIATED_RATE_30GB 0x09
2532
2533#define LSILOGICSCSI_SASIOUNIT0_DEVICE_TYPE_SET(x) ((x) & 0x3)
2534#define LSILOGICSCSI_SASIOUNIT0_DEVICE_TYPE_NO 0x0
2535#define LSILOGICSCSI_SASIOUNIT0_DEVICE_TYPE_END 0x1
2536#define LSILOGICSCSI_SASIOUNIT0_DEVICE_TYPE_EDGE_EXPANDER 0x2
2537#define LSILOGICSCSI_SASIOUNIT0_DEVICE_TYPE_FANOUT_EXPANDER 0x3
2538
2539#define LSILOGICSCSI_SASIOUNIT0_DEVICE_SATA_HOST RT_BIT(3)
2540#define LSILOGICSCSI_SASIOUNIT0_DEVICE_SMP_INITIATOR RT_BIT(4)
2541#define LSILOGICSCSI_SASIOUNIT0_DEVICE_STP_INITIATOR RT_BIT(5)
2542#define LSILOGICSCSI_SASIOUNIT0_DEVICE_SSP_INITIATOR RT_BIT(6)
2543#define LSILOGICSCSI_SASIOUNIT0_DEVICE_SATA RT_BIT(7)
2544#define LSILOGICSCSI_SASIOUNIT0_DEVICE_SMP_TARGET RT_BIT(8)
2545#define LSILOGICSCSI_SASIOUNIT0_DEVICE_STP_TARGET RT_BIT(9)
2546#define LSILOGICSCSI_SASIOUNIT0_DEVICE_SSP_TARGET RT_BIT(10)
2547#define LSILOGICSCSI_SASIOUNIT0_DEVICE_DIRECT_ATTACHED RT_BIT(11)
2548#define LSILOGICSCSI_SASIOUNIT0_DEVICE_LSI RT_BIT(12)
2549#define LSILOGICSCSI_SASIOUNIT0_DEVICE_ATAPI_DEVICE RT_BIT(13)
2550#define LSILOGICSCSI_SASIOUNIT0_DEVICE_SEP_DEVICE RT_BIT(14)
2551
2552#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_LOOP RT_BIT(0)
2553#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_UNADDRESSABLE RT_BIT(1)
2554#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_SAME_SAS_ADDR RT_BIT(2)
2555#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_EXPANDER_ERROR RT_BIT(3)
2556#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_SMP_TIMEOUT RT_BIT(4)
2557#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_EXP_ROUTE_OOE RT_BIT(5)
2558#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_EXP_ROUTE_IDX RT_BIT(6)
2559#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_SMP_FUNC_FAILED RT_BIT(7)
2560#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_SMP_CRC_ERROR RT_BIT(8)
2561#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_SUBTRSCTIVE_LNK RT_BIT(9)
2562#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_TBL_LNK RT_BIT(10)
2563#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_UNSUPPORTED_DEV RT_BIT(11)
2564#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_MAX_SATA_TGTS RT_BIT(12)
2565#define LSILOGICSCSI_SASIOUNIT0_DISCOVERY_STATUS_MULT_CTRLS RT_BIT(13)
2566
2567/**
2568 * PHY entry for the SAS I/O unit page 1
2569 */
2570#pragma pack(1)
2571typedef struct MptConfigurationPageSASIOUnit1PHY
2572{
2573 /** Port number */
2574 uint8_t u8Port;
2575 /** Port flags */
2576 uint8_t u8PortFlags;
2577 /** Phy flags */
2578 uint8_t u8PhyFlags;
2579 /** Max link rate */
2580 uint8_t u8MaxMinLinkRate;
2581 /** Controller phy device info */
2582 uint32_t u32ControllerPhyDeviceInfo;
2583 /** Maximum target port connect time */
2584 uint16_t u16MaxTargetPortConnectTime;
2585 /** Reserved */
2586 uint16_t u16Reserved;
2587} MptConfigurationPageSASIOUnit1PHY, *PMptConfigurationPageSASIOUnit1PHY;
2588#pragma pack()
2589AssertCompileSize(MptConfigurationPageSASIOUnit1PHY, 12);
2590
2591/**
2592 * SAS I/O Unit page 1 - Read/Write
2593 */
2594#pragma pack(1)
2595typedef struct MptConfigurationPageSASIOUnit1
2596{
2597 /** Union. */
2598 union
2599 {
2600 /** Byte view - variable. */
2601 uint8_t abPageData[1];
2602 /** Field view. */
2603 struct
2604 {
2605 /** The omnipresent header. */
2606 MptExtendedConfigurationPageHeader ExtHeader;
2607 /** Control flags */
2608 uint16_t u16ControlFlags;
2609 /** maximum number of SATA targets */
2610 uint16_t u16MaxNumSATATargets;
2611 /** additional control flags */
2612 uint16_t u16AdditionalControlFlags;
2613 /** Reserved */
2614 uint16_t u16Reserved;
2615 /** Number of PHYs */
2616 uint8_t u8NumPhys;
2617 /** maximum SATA queue depth */
2618 uint8_t u8SATAMaxQDepth;
2619 /** Delay for reporting missing devices. */
2620 uint8_t u8ReportDeviceMissingDelay;
2621 /** I/O device missing delay */
2622 uint8_t u8IODeviceMissingDelay;
2623 /** Content for each physical port - variable depending on the number of ports */
2624 MptConfigurationPageSASIOUnit1PHY aPHY[1];
2625 } fields;
2626 } u;
2627} MptConfigurationPageSASIOUnit1, *PMptConfigurationPageSASIOUnit1;
2628#pragma pack()
2629AssertCompileSize(MptConfigurationPageSASIOUnit1, 8+12+sizeof(MptConfigurationPageSASIOUnit1PHY));
2630
2631#define LSILOGICSCSI_SASIOUNIT1_GET_SIZE(ports) (sizeof(MptConfigurationPageSASIOUnit1) + ((ports) - 1) * sizeof(MptConfigurationPageSASIOUnit1PHY))
2632
2633#define LSILOGICSCSI_SASIOUNIT1_CONTROL_CLEAR_SATA_AFFILIATION RT_BIT(0)
2634#define LSILOGICSCSI_SASIOUNIT1_CONTROL_FIRST_LEVEL_DISCOVERY_ONLY RT_BIT(1)
2635#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SUBTRACTIVE_LNK_ILLEGAL RT_BIT(2)
2636#define LSILOGICSCSI_SASIOUNIT1_CONTROL_IOC_ENABLE_HIGH_PHY RT_BIT(3)
2637#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_FUA_REQUIRED RT_BIT(4)
2638#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_NCQ_REQUIRED RT_BIT(5)
2639#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_SMART_REQUIRED RT_BIT(6)
2640#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_LBA48_REQUIRED RT_BIT(7)
2641#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_INIT_POSTPONED RT_BIT(8)
2642
2643#define LSILOGICSCSI_SASIOUNIT1_CONTROL_DEVICE_SUPPORT_SET(x) (((x) & 0x3) << 9)
2644#define LSILOGICSCSI_SASIOUNIT1_CONTROL_DEVICE_SUPPORT_GET(x) (((x) >> 9) & 0x3)
2645#define LSILOGICSCSI_SASIOUNIT1_CONTROL_DEVICE_SUPPORT_SAS_AND_SATA 0x00
2646#define LSILOGICSCSI_SASIOUNIT1_CONTROL_DEVICE_SUPPORT_SAS 0x01
2647#define LSILOGICSCSI_SASIOUNIT1_CONTROL_DEVICE_SUPPORT_SATA 0x02
2648
2649#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_EXP_ADDR RT_BIT(11)
2650#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_SETTINGS_PRESERV_REQUIRED RT_BIT(12)
2651#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_LIMIT_RATE_15GB RT_BIT(13)
2652#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SATA_LIMIT_RATE_30GB RT_BIT(14)
2653#define LSILOGICSCSI_SASIOUNIT1_CONTROL_SAS_SELF_TEST_ENABLED RT_BIT(15)
2654
2655#define LSILOGICSCSI_SASIOUNIT1_ADDITIONAL_CONTROL_TBL_LNKS_ALLOW RT_BIT(0)
2656#define LSILOGICSCSI_SASIOUNIT1_ADDITIONAL_CONTROL_SATA_RST_NO_AFFIL RT_BIT(1)
2657#define LSILOGICSCSI_SASIOUNIT1_ADDITIONAL_CONTROL_SATA_RST_SELF_AFFIL RT_BIT(2)
2658#define LSILOGICSCSI_SASIOUNIT1_ADDITIONAL_CONTROL_SATA_RST_OTHER_AFFIL RT_BIT(3)
2659#define LSILOGICSCSI_SASIOUNIT1_ADDITIONAL_CONTROL_SATA_RST_PORT_EN_ONLY RT_BIT(4)
2660#define LSILOGICSCSI_SASIOUNIT1_ADDITIONAL_CONTROL_HIDE_NON_ZERO_PHYS RT_BIT(5)
2661#define LSILOGICSCSI_SASIOUNIT1_ADDITIONAL_CONTROL_SATA_ASYNC_NOTIF RT_BIT(6)
2662#define LSILOGICSCSI_SASIOUNIT1_ADDITIONAL_CONTROL_MULT_PORTS_ILL_SAME_DOMAIN RT_BIT(7)
2663
2664#define LSILOGICSCSI_SASIOUNIT1_MISSING_DEVICE_DELAY_UNITS_16_SEC RT_BIT(7)
2665#define LSILOGICSCSI_SASIOUNIT1_MISSING_DEVICE_DELAY_SET(x) ((x) & 0x7F)
2666#define LSILOGICSCSI_SASIOUNIT1_MISSING_DEVICE_DELAY_GET(x) ((x) & 0x7F)
2667
2668#define LSILOGICSCSI_SASIOUNIT1_PORT_CONFIGURATION_AUTO RT_BIT(0)
2669#define LSILOGICSCSI_SASIOUNIT1_PORT_CONFIGURATION_IOC1 RT_BIT(2)
2670
2671#define LSILOGICSCSI_SASIOUNIT1_PHY_RX_INVERT RT_BIT(0)
2672#define LSILOGICSCSI_SASIOUNIT1_PHY_TX_INVERT RT_BIT(1)
2673#define LSILOGICSCSI_SASIOUNIT1_PHY_DISABLE RT_BIT(2)
2674
2675#define LSILOGICSCSI_SASIOUNIT1_LINK_RATE_MIN_SET(x) ((x) & 0x0F)
2676#define LSILOGICSCSI_SASIOUNIT1_LINK_RATE_MIN_GET(x) ((x) & 0x0F)
2677#define LSILOGICSCSI_SASIOUNIT1_LINK_RATE_MAX_SET(x) (((x) & 0x0F) << 4)
2678#define LSILOGICSCSI_SASIOUNIT1_LINK_RATE_MAX_GET(x) ((x >> 4) & 0x0F)
2679#define LSILOGICSCSI_SASIOUNIT1_LINK_RATE_15GB 0x8
2680#define LSILOGICSCSI_SASIOUNIT1_LINK_RATE_30GB 0x9
2681
2682#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_TYPE_SET(x) ((x) & 0x3)
2683#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_TYPE_GET(x) ((x) & 0x3)
2684#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_TYPE_NO 0x0
2685#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_TYPE_END 0x1
2686#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_TYPE_EDGE_EXPANDER 0x2
2687#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_TYPE_FANOUT_EXPANDER 0x3
2688#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_SMP_INITIATOR RT_BIT(4)
2689#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_STP_INITIATOR RT_BIT(5)
2690#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_SSP_INITIATOR RT_BIT(6)
2691#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_SMP_TARGET RT_BIT(8)
2692#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_STP_TARGET RT_BIT(9)
2693#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_SSP_TARGET RT_BIT(10)
2694#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_DIRECT_ATTACHED RT_BIT(11)
2695#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_LSI RT_BIT(12)
2696#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_ATAPI RT_BIT(13)
2697#define LSILOGICSCSI_SASIOUNIT1_CTL_PHY_DEVICE_SEP RT_BIT(14)
2698
2699/**
2700 * SAS I/O unit page 2 - Read/Write
2701 */
2702#pragma pack(1)
2703typedef struct MptConfigurationPageSASIOUnit2
2704{
2705 /** Union. */
2706 union
2707 {
2708 /** Byte view - variable. */
2709 uint8_t abPageData[1];
2710 /** Field view. */
2711 struct
2712 {
2713 /** The omnipresent header. */
2714 MptExtendedConfigurationPageHeader ExtHeader;
2715 /** Device numbers per enclosure */
2716 uint8_t u8NumDevsPerEnclosure;
2717 /** Boot device wait time */
2718 uint8_t u8BootDeviceWaitTime;
2719 /** Reserved */
2720 uint16_t u16Reserved;
2721 /** Maximum number of persistent Bus and target ID mappings */
2722 uint16_t u16MaxPersistentIDs;
2723 /** Number of persistent IDs used */
2724 uint16_t u16NumPersistentIDsUsed;
2725 /** Status */
2726 uint8_t u8Status;
2727 /** Flags */
2728 uint8_t u8Flags;
2729 /** Maximum number of physical mapped IDs */
2730 uint16_t u16MaxNumPhysicalMappedIDs;
2731 } fields;
2732 } u;
2733} MptConfigurationPageSASIOUnit2, *PMptConfigurationPageSASIOUnit2;
2734#pragma pack()
2735AssertCompileSize(MptConfigurationPageSASIOUnit2, 20);
2736
2737#define LSILOGICSCSI_SASIOUNIT2_STATUS_PERSISTENT_MAP_TBL_FULL RT_BIT(0)
2738#define LSILOGICSCSI_SASIOUNIT2_STATUS_PERSISTENT_MAP_DISABLED RT_BIT(1)
2739#define LSILOGICSCSI_SASIOUNIT2_STATUS_PERSISTENT_ENC_DEV_UNMAPPED RT_BIT(2)
2740#define LSILOGICSCSI_SASIOUNIT2_STATUS_PERSISTENT_DEV_LIMIT_EXCEEDED RT_BIT(3)
2741
2742#define LSILOGICSCSI_SASIOUNIT2_FLAGS_PERSISTENT_MAP_DISABLE RT_BIT(0)
2743#define LSILOGICSCSI_SASIOUNIT2_FLAGS_PERSISTENT_PHYS_MAP_MODE_SET(x) ((x & 0x7) << 1)
2744#define LSILOGICSCSI_SASIOUNIT2_FLAGS_PERSISTENT_PHYS_MAP_MODE_GET(x) ((x >> 1) & 0x7)
2745#define LSILOGICSCSI_SASIOUNIT2_FLAGS_PERSISTENT_PHYS_MAP_MODE_NO 0x0
2746#define LSILOGICSCSI_SASIOUNIT2_FLAGS_PERSISTENT_PHYS_MAP_MODE_DIRECT_ATTACHED 0x1
2747#define LSILOGICSCSI_SASIOUNIT2_FLAGS_PERSISTENT_PHYS_MAP_MODE_ENC 0x2
2748#define LSILOGICSCSI_SASIOUNIT2_FLAGS_PERSISTENT_PHYS_MAP_MODE_HOST 0x7
2749#define LSILOGICSCSI_SASIOUNIT2_FLAGS_RESERVE_TARGET_ID_ZERO RT_BIT(4)
2750#define LSILOGICSCSI_SASIOUNIT2_FLAGS_START_SLOT_NUMBER_ONE RT_BIT(5)
2751
2752/**
2753 * SAS I/O unit page 3 - Read/Write
2754 */
2755#pragma pack(1)
2756typedef struct MptConfigurationPageSASIOUnit3
2757{
2758 /** Union. */
2759 union
2760 {
2761 /** Byte view - variable. */
2762 uint8_t abPageData[1];
2763 /** Field view. */
2764 struct
2765 {
2766 /** The omnipresent header. */
2767 MptExtendedConfigurationPageHeader ExtHeader;
2768 /** Reserved */
2769 uint32_t u32Reserved;
2770 uint32_t u32MaxInvalidDwordCount;
2771 uint32_t u32InvalidDwordCountTime;
2772 uint32_t u32MaxRunningDisparityErrorCount;
2773 uint32_t u32RunningDisparityErrorTime;
2774 uint32_t u32MaxLossDwordSynchCount;
2775 uint32_t u32LossDwordSynchCountTime;
2776 uint32_t u32MaxPhysResetProblemCount;
2777 uint32_t u32PhyResetProblemTime;
2778 } fields;
2779 } u;
2780} MptConfigurationPageSASIOUnit3, *PMptConfigurationPageSASIOUnit3;
2781#pragma pack()
2782AssertCompileSize(MptConfigurationPageSASIOUnit3, 44);
2783
2784/**
2785 * SAS PHY page 0 - Readonly
2786 */
2787#pragma pack(1)
2788typedef struct MptConfigurationPageSASPHY0
2789{
2790 /** Union. */
2791 union
2792 {
2793 /** Byte view - variable. */
2794 uint8_t abPageData[1];
2795 /** Field view. */
2796 struct
2797 {
2798 /** The omnipresent header. */
2799 MptExtendedConfigurationPageHeader ExtHeader;
2800 /** Owner dev handle. */
2801 uint16_t u16OwnerDevHandle;
2802 /** Reserved */
2803 uint16_t u16Reserved0;
2804 /** SAS address */
2805 SASADDRESS SASAddress;
2806 /** Attached device handle */
2807 uint16_t u16AttachedDevHandle;
2808 /** Attached phy identifier */
2809 uint8_t u8AttachedPhyIdentifier;
2810 /** Reserved */
2811 uint8_t u8Reserved1;
2812 /** Attached device information */
2813 uint32_t u32AttachedDeviceInfo;
2814 /** Programmed link rate */
2815 uint8_t u8ProgrammedLinkRate;
2816 /** Hardware link rate */
2817 uint8_t u8HwLinkRate;
2818 /** Change count */
2819 uint8_t u8ChangeCount;
2820 /** Flags */
2821 uint8_t u8Flags;
2822 /** Phy information */
2823 uint32_t u32PhyInfo;
2824 } fields;
2825 } u;
2826} MptConfigurationPageSASPHY0, *PMptConfigurationPageSASPHY0;
2827#pragma pack()
2828AssertCompileSize(MptConfigurationPageSASPHY0, 36);
2829
2830#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_TYPE_SET(x) ((x) & 0x3)
2831#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_TYPE_GET(x) ((x) & 0x3)
2832#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_TYPE_NO 0x0
2833#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_TYPE_END 0x1
2834#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_TYPE_EDGE_EXPANDER 0x2
2835#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_TYPE_FANOUT_EXPANDER 0x3
2836#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_SMP_INITIATOR RT_BIT(4)
2837#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_STP_INITIATOR RT_BIT(5)
2838#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_SSP_INITIATOR RT_BIT(6)
2839#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_SMP_TARGET RT_BIT(8)
2840#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_STP_TARGET RT_BIT(9)
2841#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_SSP_TARGET RT_BIT(10)
2842#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_DIRECT_ATTACHED RT_BIT(11)
2843#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_LSI RT_BIT(12)
2844#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_ATAPI RT_BIT(13)
2845#define LSILOGICSCSI_SASPHY0_DEV_INFO_DEVICE_SEP RT_BIT(14)
2846
2847/**
2848 * SAS PHY page 1 - Readonly
2849 */
2850#pragma pack(1)
2851typedef struct MptConfigurationPageSASPHY1
2852{
2853 /** Union. */
2854 union
2855 {
2856 /** Byte view - variable. */
2857 uint8_t abPageData[1];
2858 /** Field view. */
2859 struct
2860 {
2861 /** The omnipresent header. */
2862 MptExtendedConfigurationPageHeader ExtHeader;
2863 /** Reserved */
2864 uint32_t u32Reserved0;
2865 uint32_t u32InvalidDwordCound;
2866 uint32_t u32RunningDisparityErrorCount;
2867 uint32_t u32LossDwordSynchCount;
2868 uint32_t u32PhyResetProblemCount;
2869 } fields;
2870 } u;
2871} MptConfigurationPageSASPHY1, *PMptConfigurationPageSASPHY1;
2872#pragma pack()
2873AssertCompileSize(MptConfigurationPageSASPHY1, 28);
2874
2875/**
2876 * SAS Device page 0 - Readonly
2877 */
2878#pragma pack(1)
2879typedef struct MptConfigurationPageSASDevice0
2880{
2881 /** Union. */
2882 union
2883 {
2884 /** Byte view - variable. */
2885 uint8_t abPageData[1];
2886 /** Field view. */
2887 struct
2888 {
2889 /** The omnipresent header. */
2890 MptExtendedConfigurationPageHeader ExtHeader;
2891 /** Slot number */
2892 uint16_t u16Slot;
2893 /** Enclosure handle. */
2894 uint16_t u16EnclosureHandle;
2895 /** SAS address */
2896 SASADDRESS SASAddress;
2897 /** Parent device handle */
2898 uint16_t u16ParentDevHandle;
2899 /** Phy number */
2900 uint8_t u8PhyNum;
2901 /** Access status */
2902 uint8_t u8AccessStatus;
2903 /** Device handle */
2904 uint16_t u16DevHandle;
2905 /** Target ID */
2906 uint8_t u8TargetID;
2907 /** Bus */
2908 uint8_t u8Bus;
2909 /** Device info */
2910 uint32_t u32DeviceInfo;
2911 /** Flags */
2912 uint16_t u16Flags;
2913 /** Physical port */
2914 uint8_t u8PhysicalPort;
2915 /** Reserved */
2916 uint8_t u8Reserved0;
2917 } fields;
2918 } u;
2919} MptConfigurationPageSASDevice0, *PMptConfigurationPageSASDevice0;
2920#pragma pack()
2921AssertCompileSize(MptConfigurationPageSASDevice0, 36);
2922
2923#define LSILOGICSCSI_SASDEVICE0_STATUS_NO_ERRORS (0x00)
2924
2925#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_TYPE_SET(x) ((x) & 0x3)
2926#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_TYPE_GET(x) ((x) & 0x3)
2927#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_TYPE_NO 0x0
2928#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_TYPE_END 0x1
2929#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_TYPE_EDGE_EXPANDER 0x2
2930#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_TYPE_FANOUT_EXPANDER 0x3
2931#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_SMP_INITIATOR RT_BIT(4)
2932#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_STP_INITIATOR RT_BIT(5)
2933#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_SSP_INITIATOR RT_BIT(6)
2934#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_SMP_TARGET RT_BIT(8)
2935#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_STP_TARGET RT_BIT(9)
2936#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_SSP_TARGET RT_BIT(10)
2937#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_DIRECT_ATTACHED RT_BIT(11)
2938#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_LSI RT_BIT(12)
2939#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_ATAPI RT_BIT(13)
2940#define LSILOGICSCSI_SASDEVICE0_DEV_INFO_DEVICE_SEP RT_BIT(14)
2941
2942#define LSILOGICSCSI_SASDEVICE0_FLAGS_DEVICE_PRESENT (RT_BIT(0))
2943#define LSILOGICSCSI_SASDEVICE0_FLAGS_DEVICE_MAPPED_TO_BUS_AND_TARGET_ID (RT_BIT(1))
2944#define LSILOGICSCSI_SASDEVICE0_FLAGS_DEVICE_MAPPING_PERSISTENT (RT_BIT(2))
2945
2946/**
2947 * SAS Device page 1 - Readonly
2948 */
2949#pragma pack(1)
2950typedef struct MptConfigurationPageSASDevice1
2951{
2952 /** Union. */
2953 union
2954 {
2955 /** Byte view - variable. */
2956 uint8_t abPageData[1];
2957 /** Field view. */
2958 struct
2959 {
2960 /** The omnipresent header. */
2961 MptExtendedConfigurationPageHeader ExtHeader;
2962 /** Reserved */
2963 uint32_t u32Reserved0;
2964 /** SAS address */
2965 SASADDRESS SASAddress;
2966 /** Reserved */
2967 uint32_t u32Reserved;
2968 /** Device handle */
2969 uint16_t u16DevHandle;
2970 /** Target ID */
2971 uint8_t u8TargetID;
2972 /** Bus */
2973 uint8_t u8Bus;
2974 /** Initial REgister device FIS */
2975 uint32_t au32InitialRegDeviceFIS[5];
2976 } fields;
2977 } u;
2978} MptConfigurationPageSASDevice1, *PMptConfigurationPageSASDevice1;
2979#pragma pack()
2980AssertCompileSize(MptConfigurationPageSASDevice1, 48);
2981
2982/**
2983 * SAS Device page 2 - Read/Write persistent
2984 */
2985#pragma pack(1)
2986typedef struct MptConfigurationPageSASDevice2
2987{
2988 /** Union. */
2989 union
2990 {
2991 /** Byte view - variable. */
2992 uint8_t abPageData[1];
2993 /** Field view. */
2994 struct
2995 {
2996 /** The omnipresent header. */
2997 MptExtendedConfigurationPageHeader ExtHeader;
2998 /** Physical identifier */
2999 SASADDRESS SASAddress;
3000 /** Enclosure mapping */
3001 uint32_t u32EnclosureMapping;
3002 } fields;
3003 } u;
3004} MptConfigurationPageSASDevice2, *PMptConfigurationPageSASDevice2;
3005#pragma pack()
3006AssertCompileSize(MptConfigurationPageSASDevice2, 20);
3007
3008/**
3009 * A device entitiy containing all pages.
3010 */
3011typedef struct MptSASDevice
3012{
3013 /** Pointer to the next device if any. */
3014 struct MptSASDevice *pNext;
3015 /** Pointer to the previous device if any. */
3016 struct MptSASDevice *pPrev;
3017
3018 MptConfigurationPageSASDevice0 SASDevicePage0;
3019 MptConfigurationPageSASDevice1 SASDevicePage1;
3020 MptConfigurationPageSASDevice2 SASDevicePage2;
3021} MptSASDevice, *PMptSASDevice;
3022
3023/**
3024 * SAS Expander page 0 - Readonly
3025 */
3026#pragma pack(1)
3027typedef struct MptConfigurationPageSASExpander0
3028{
3029 /** Union. */
3030 union
3031 {
3032 /** Byte view - variable. */
3033 uint8_t abPageData[1];
3034 /** Field view. */
3035 struct
3036 {
3037 /** The omnipresent header. */
3038 MptExtendedConfigurationPageHeader ExtHeader;
3039 /** Physical port */
3040 uint8_t u8PhysicalPort;
3041 /** Reserved */
3042 uint8_t u8Reserved0;
3043 /** Enclosure handle */
3044 uint16_t u16EnclosureHandle;
3045 /** SAS address */
3046 SASADDRESS SASAddress;
3047 /** Discovery status */
3048 uint32_t u32DiscoveryStatus;
3049 /** Device handle. */
3050 uint16_t u16DevHandle;
3051 /** Parent device handle */
3052 uint16_t u16ParentDevHandle;
3053 /** Expander change count */
3054 uint16_t u16ExpanderChangeCount;
3055 /** Expander route indexes */
3056 uint16_t u16ExpanderRouteIndexes;
3057 /** Number of PHys in this expander */
3058 uint8_t u8NumPhys;
3059 /** SAS level */
3060 uint8_t u8SASLevel;
3061 /** Flags */
3062 uint8_t u8Flags;
3063 /** Reserved */
3064 uint8_t u8Reserved1;
3065 } fields;
3066 } u;
3067} MptConfigurationPageSASExpander0, *PMptConfigurationPageSASExpander0;
3068#pragma pack()
3069AssertCompileSize(MptConfigurationPageSASExpander0, 36);
3070
3071/**
3072 * SAS Expander page 1 - Readonly
3073 */
3074#pragma pack(1)
3075typedef struct MptConfigurationPageSASExpander1
3076{
3077 /** Union. */
3078 union
3079 {
3080 /** Byte view - variable. */
3081 uint8_t abPageData[1];
3082 /** Field view. */
3083 struct
3084 {
3085 /** The omnipresent header. */
3086 MptExtendedConfigurationPageHeader ExtHeader;
3087 /** Physical port */
3088 uint8_t u8PhysicalPort;
3089 /** Reserved */
3090 uint8_t u8Reserved0[3];
3091 /** Number of PHYs */
3092 uint8_t u8NumPhys;
3093 /** Number of the Phy the information in this page is for. */
3094 uint8_t u8Phy;
3095 /** Number of routing table entries */
3096 uint16_t u16NumTableEntriesProgrammed;
3097 /** Programmed link rate */
3098 uint8_t u8ProgrammedLinkRate;
3099 /** Hardware link rate */
3100 uint8_t u8HwLinkRate;
3101 /** Attached device handle */
3102 uint16_t u16AttachedDevHandle;
3103 /** Phy information */
3104 uint32_t u32PhyInfo;
3105 /** Attached device information */
3106 uint32_t u32AttachedDeviceInfo;
3107 /** Owner device handle. */
3108 uint16_t u16OwnerDevHandle;
3109 /** Change count */
3110 uint8_t u8ChangeCount;
3111 /** Negotiated link rate */
3112 uint8_t u8NegotiatedLinkRate;
3113 /** Phy identifier */
3114 uint8_t u8PhyIdentifier;
3115 /** Attached phy identifier */
3116 uint8_t u8AttachedPhyIdentifier;
3117 /** Reserved */
3118 uint8_t u8Reserved1;
3119 /** Discovery information */
3120 uint8_t u8DiscoveryInfo;
3121 /** Reserved */
3122 uint32_t u32Reserved;
3123 } fields;
3124 } u;
3125} MptConfigurationPageSASExpander1, *PMptConfigurationPageSASExpander1;
3126#pragma pack()
3127AssertCompileSize(MptConfigurationPageSASExpander1, 40);
3128
3129/**
3130 * Structure of all supported pages for the SCSI SPI controller.
3131 * Used to load the device state from older versions.
3132 */
3133typedef struct MptConfigurationPagesSupported_SSM_V2
3134{
3135 MptConfigurationPageManufacturing0 ManufacturingPage0;
3136 MptConfigurationPageManufacturing1 ManufacturingPage1;
3137 MptConfigurationPageManufacturing2 ManufacturingPage2;
3138 MptConfigurationPageManufacturing3 ManufacturingPage3;
3139 MptConfigurationPageManufacturing4 ManufacturingPage4;
3140 MptConfigurationPageIOUnit0 IOUnitPage0;
3141 MptConfigurationPageIOUnit1 IOUnitPage1;
3142 MptConfigurationPageIOUnit2 IOUnitPage2;
3143 MptConfigurationPageIOUnit3 IOUnitPage3;
3144 MptConfigurationPageIOC0 IOCPage0;
3145 MptConfigurationPageIOC1 IOCPage1;
3146 MptConfigurationPageIOC2 IOCPage2;
3147 MptConfigurationPageIOC3 IOCPage3;
3148 MptConfigurationPageIOC4 IOCPage4;
3149 MptConfigurationPageIOC6 IOCPage6;
3150 struct
3151 {
3152 MptConfigurationPageSCSISPIPort0 SCSISPIPortPage0;
3153 MptConfigurationPageSCSISPIPort1 SCSISPIPortPage1;
3154 MptConfigurationPageSCSISPIPort2 SCSISPIPortPage2;
3155 } aPortPages[1]; /* Currently only one port supported. */
3156 struct
3157 {
3158 struct
3159 {
3160 MptConfigurationPageSCSISPIDevice0 SCSISPIDevicePage0;
3161 MptConfigurationPageSCSISPIDevice1 SCSISPIDevicePage1;
3162 MptConfigurationPageSCSISPIDevice2 SCSISPIDevicePage2;
3163 MptConfigurationPageSCSISPIDevice3 SCSISPIDevicePage3;
3164 } aDevicePages[LSILOGICSCSI_PCI_SPI_DEVICES_MAX];
3165 } aBuses[1]; /* Only one bus at the moment. */
3166} MptConfigurationPagesSupported_SSM_V2, *PMptConfigurationPagesSupported_SSM_V2;
3167
3168typedef struct MptConfigurationPagesSpi
3169{
3170 struct
3171 {
3172 MptConfigurationPageSCSISPIPort0 SCSISPIPortPage0;
3173 MptConfigurationPageSCSISPIPort1 SCSISPIPortPage1;
3174 MptConfigurationPageSCSISPIPort2 SCSISPIPortPage2;
3175 } aPortPages[1]; /* Currently only one port supported. */
3176 struct
3177 {
3178 struct
3179 {
3180 MptConfigurationPageSCSISPIDevice0 SCSISPIDevicePage0;
3181 MptConfigurationPageSCSISPIDevice1 SCSISPIDevicePage1;
3182 MptConfigurationPageSCSISPIDevice2 SCSISPIDevicePage2;
3183 MptConfigurationPageSCSISPIDevice3 SCSISPIDevicePage3;
3184 } aDevicePages[LSILOGICSCSI_PCI_SPI_DEVICES_MAX];
3185 } aBuses[1]; /* Only one bus at the moment. */
3186} MptConfigurationPagesSpi, *PMptConfigurationPagesSpi;
3187
3188typedef struct MptPHY
3189{
3190 MptConfigurationPageSASPHY0 SASPHYPage0;
3191 MptConfigurationPageSASPHY1 SASPHYPage1;
3192} MptPHY, *PMptPHY;
3193
3194#pragma pack(1)
3195typedef struct MptConfigurationPagesSas
3196{
3197 /** Size of the manufacturing page 7 */
3198 uint32_t cbManufacturingPage7;
3199 /** Pointer to the manufacturing page 7 */
3200 PMptConfigurationPageManufacturing7 pManufacturingPage7;
3201 /** Size of the I/O unit page 0 */
3202 uint32_t cbSASIOUnitPage0;
3203 /** Pointer to the I/O unit page 0 */
3204 PMptConfigurationPageSASIOUnit0 pSASIOUnitPage0;
3205 /** Size of the I/O unit page 1 */
3206 uint32_t cbSASIOUnitPage1;
3207 /** Pointer to the I/O unit page 1 */
3208 PMptConfigurationPageSASIOUnit1 pSASIOUnitPage1;
3209 /** I/O unit page 2 */
3210 MptConfigurationPageSASIOUnit2 SASIOUnitPage2;
3211 /** I/O unit page 3 */
3212 MptConfigurationPageSASIOUnit3 SASIOUnitPage3;
3213
3214 /** Number of PHYs in the array. */
3215 uint32_t cPHYs;
3216 /** Pointer to an array of per PHYS pages. */
3217 R3PTRTYPE(PMptPHY) paPHYs;
3218
3219 /** Number of devices detected. */
3220 uint32_t cDevices;
3221 /** Pointer to the first SAS device. */
3222 R3PTRTYPE(PMptSASDevice) pSASDeviceHead;
3223 /** Pointer to the last SAS device. */
3224 R3PTRTYPE(PMptSASDevice) pSASDeviceTail;
3225} MptConfigurationPagesSas, *PMptConfigurationPagesSas;
3226#pragma pack()
3227
3228/**
3229 * Structure of all supported pages for both controllers.
3230 */
3231typedef struct MptConfigurationPagesSupported
3232{
3233 MptConfigurationPageManufacturing0 ManufacturingPage0;
3234 MptConfigurationPageManufacturing1 ManufacturingPage1;
3235 MptConfigurationPageManufacturing2 ManufacturingPage2;
3236 MptConfigurationPageManufacturing3 ManufacturingPage3;
3237 MptConfigurationPageManufacturing4 ManufacturingPage4;
3238 MptConfigurationPageManufacturing5 ManufacturingPage5;
3239 MptConfigurationPageManufacturing6 ManufacturingPage6;
3240 MptConfigurationPageManufacturing8 ManufacturingPage8;
3241 MptConfigurationPageManufacturing9 ManufacturingPage9;
3242 MptConfigurationPageManufacturing10 ManufacturingPage10;
3243 MptConfigurationPageIOUnit0 IOUnitPage0;
3244 MptConfigurationPageIOUnit1 IOUnitPage1;
3245 MptConfigurationPageIOUnit2 IOUnitPage2;
3246 MptConfigurationPageIOUnit3 IOUnitPage3;
3247 MptConfigurationPageIOUnit4 IOUnitPage4;
3248 MptConfigurationPageIOC0 IOCPage0;
3249 MptConfigurationPageIOC1 IOCPage1;
3250 MptConfigurationPageIOC2 IOCPage2;
3251 MptConfigurationPageIOC3 IOCPage3;
3252 MptConfigurationPageIOC4 IOCPage4;
3253 MptConfigurationPageIOC6 IOCPage6;
3254 /* BIOS page 0 is not described */
3255 MptConfigurationPageBIOS1 BIOSPage1;
3256 MptConfigurationPageBIOS2 BIOSPage2;
3257 /* BIOS page 3 is not described */
3258 MptConfigurationPageBIOS4 BIOSPage4;
3259
3260 /** Controller dependent data. */
3261 union
3262 {
3263 MptConfigurationPagesSpi SpiPages;
3264 MptConfigurationPagesSas SasPages;
3265 } u;
3266} MptConfigurationPagesSupported, *PMptConfigurationPagesSupported;
3267
3268/**
3269 * Initializes a page header.
3270 */
3271#define MPT_CONFIG_PAGE_HEADER_INIT(pg, type, nr, flags) \
3272 (pg)->u.fields.Header.u8PageType = flags; \
3273 (pg)->u.fields.Header.u8PageNumber = nr; \
3274 (pg)->u.fields.Header.u8PageLength = sizeof(type) / 4
3275
3276#define MPT_CONFIG_PAGE_HEADER_INIT_MANUFACTURING(pg, type, nr, flags) \
3277 MPT_CONFIG_PAGE_HEADER_INIT(pg, type, nr, flags | MPT_CONFIGURATION_PAGE_TYPE_MANUFACTURING)
3278
3279#define MPT_CONFIG_PAGE_HEADER_INIT_IO_UNIT(pg, type, nr, flags) \
3280 MPT_CONFIG_PAGE_HEADER_INIT(pg, type, nr, flags | MPT_CONFIGURATION_PAGE_TYPE_IO_UNIT)
3281
3282#define MPT_CONFIG_PAGE_HEADER_INIT_IOC(pg, type, nr, flags) \
3283 MPT_CONFIG_PAGE_HEADER_INIT(pg, type, nr, flags | MPT_CONFIGURATION_PAGE_TYPE_IOC)
3284
3285#define MPT_CONFIG_PAGE_HEADER_INIT_BIOS(pg, type, nr, flags) \
3286 MPT_CONFIG_PAGE_HEADER_INIT(pg, type, nr, flags | MPT_CONFIGURATION_PAGE_TYPE_BIOS)
3287
3288/**
3289 * Initializes a extended page header.
3290 */
3291#define MPT_CONFIG_EXTENDED_PAGE_HEADER_INIT(pg, cb, nr, flags, exttype) \
3292 (pg)->u.fields.ExtHeader.u8PageType = flags | MPT_CONFIGURATION_PAGE_TYPE_EXTENDED; \
3293 (pg)->u.fields.ExtHeader.u8PageNumber = nr; \
3294 (pg)->u.fields.ExtHeader.u8ExtPageType = exttype; \
3295 (pg)->u.fields.ExtHeader.u16ExtPageLength = cb / 4
3296
3297/**
3298 * Possible SG element types.
3299 */
3300enum MPTSGENTRYTYPE
3301{
3302 MPTSGENTRYTYPE_TRANSACTION_CONTEXT = 0x00,
3303 MPTSGENTRYTYPE_SIMPLE = 0x01,
3304 MPTSGENTRYTYPE_CHAIN = 0x03
3305};
3306
3307/**
3308 * Register interface.
3309 */
3310
3311/**
3312 * Defined states that the SCSI controller can have.
3313 */
3314typedef enum LSILOGICSTATE
3315{
3316 /** Reset state. */
3317 LSILOGICSTATE_RESET = 0x00,
3318 /** Ready state. */
3319 LSILOGICSTATE_READY = 0x01,
3320 /** Operational state. */
3321 LSILOGICSTATE_OPERATIONAL = 0x02,
3322 /** Fault state. */
3323 LSILOGICSTATE_FAULT = 0x04,
3324 /** 32bit size hack */
3325 LSILOGICSTATE_32BIT_HACK = 0x7fffffff
3326} LSILOGICSTATE;
3327
3328/**
3329 * Which entity needs to initialize the controller
3330 * to get into the operational state.
3331 */
3332typedef enum LSILOGICWHOINIT
3333{
3334 /** Not initialized. */
3335 LSILOGICWHOINIT_NOT_INITIALIZED = 0x00,
3336 /** System BIOS. */
3337 LSILOGICWHOINIT_SYSTEM_BIOS = 0x01,
3338 /** ROM Bios. */
3339 LSILOGICWHOINIT_ROM_BIOS = 0x02,
3340 /** PCI Peer. */
3341 LSILOGICWHOINIT_PCI_PEER = 0x03,
3342 /** Host driver. */
3343 LSILOGICWHOINIT_HOST_DRIVER = 0x04,
3344 /** Manufacturing. */
3345 LSILOGICWHOINIT_MANUFACTURING = 0x05,
3346 /** 32bit size hack. */
3347 LSILOGICWHOINIT_32BIT_HACK = 0x7fffffff
3348} LSILOGICWHOINIT;
3349
3350
3351/**
3352 * IOC status codes.
3353 */
3354#define LSILOGIC_IOCSTATUS_SUCCESS 0x0000
3355#define LSILOGIC_IOCSTATUS_INVALID_FUNCTION 0x0001
3356#define LSILOGIC_IOCSTATUS_BUSY 0x0002
3357#define LSILOGIC_IOCSTATUS_INVALID_SGL 0x0003
3358#define LSILOGIC_IOCSTATUS_INTERNAL_ERROR 0x0004
3359#define LSILOGIC_IOCSTATUS_RESERVED 0x0005
3360#define LSILOGIC_IOCSTATUS_INSUFFICIENT_RESOURCES 0x0006
3361#define LSILOGIC_IOCSTATUS_INVALID_FIELD 0x0007
3362#define LSILOGIC_IOCSTATUS_INVALID_STATE 0x0008
3363#define LSILOGIC_IOCSTATUS_OP_STATE_NOT_SUPPOTED 0x0009
3364
3365/**
3366 * Size of the I/O and MMIO space.
3367 */
3368#define LSILOGIC_PCI_SPACE_IO_SIZE 256
3369#define LSILOGIC_PCI_SPACE_MEM_SIZE 128 * _1K
3370
3371/**
3372 * Doorbell register - Used to get the status of the controller and
3373 * initialise it.
3374 */
3375#define LSILOGIC_REG_DOORBELL 0x00
3376# define LSILOGIC_REG_DOORBELL_SET_STATE(enmState) (((enmState) & 0x0f) << 28)
3377# define LSILOGIC_REG_DOORBELL_SET_USED(fUsed) (((fUsed) ? 1 : 0) << 27)
3378# define LSILOGIC_REG_DOORBELL_SET_WHOINIT(enmWhoInit) (((enmWhoInit) & 0x07) << 24)
3379# define LSILOGIC_REG_DOORBELL_SET_FAULT_CODE(u16Code) (u16Code)
3380# define LSILOGIC_REG_DOORBELL_GET_FUNCTION(x) (((x) & 0xff000000) >> 24)
3381# define LSILOGIC_REG_DOORBELL_GET_SIZE(x) (((x) & 0x00ff0000) >> 16)
3382
3383/**
3384 * Functions which can be passed through the system doorbell.
3385 */
3386#define LSILOGIC_DOORBELL_FUNCTION_IOC_MSG_UNIT_RESET 0x40
3387#define LSILOGIC_DOORBELL_FUNCTION_IO_UNIT_RESET 0x41
3388#define LSILOGIC_DOORBELL_FUNCTION_HANDSHAKE 0x42
3389#define LSILOGIC_DOORBELL_FUNCTION_REPLY_FRAME_REMOVAL 0x43
3390
3391/**
3392 * Write sequence register for the diagnostic register.
3393 */
3394#define LSILOGIC_REG_WRITE_SEQUENCE 0x04
3395
3396/**
3397 * Diagnostic register - used to reset the controller.
3398 */
3399#define LSILOGIC_REG_HOST_DIAGNOSTIC 0x08
3400# define LSILOGIC_REG_HOST_DIAGNOSTIC_DIAG_MEM_ENABLE (RT_BIT(0))
3401# define LSILOGIC_REG_HOST_DIAGNOSTIC_DISABLE_ARM (RT_BIT(1))
3402# define LSILOGIC_REG_HOST_DIAGNOSTIC_RESET_ADAPTER (RT_BIT(2))
3403# define LSILOGIC_REG_HOST_DIAGNOSTIC_DIAG_RW_ENABLE (RT_BIT(4))
3404# define LSILOGIC_REG_HOST_DIAGNOSTIC_RESET_HISTORY (RT_BIT(5))
3405# define LSILOGIC_REG_HOST_DIAGNOSTIC_FLASH_BAD_SIG (RT_BIT(6))
3406# define LSILOGIC_REG_HOST_DIAGNOSTIC_DRWE (RT_BIT(7))
3407# define LSILOGIC_REG_HOST_DIAGNOSTIC_PREVENT_IOC_BOOT (RT_BIT(9))
3408# define LSILOGIC_REG_HOST_DIAGNOSTIC_CLEAR_FLASH_BAD_SIG (RT_BIT(10))
3409
3410#define LSILOGIC_REG_TEST_BASE_ADDRESS 0x0c
3411#define LSILOGIC_REG_DIAG_RW_DATA 0x10
3412#define LSILOGIC_REG_DIAG_RW_ADDRESS 0x14
3413
3414/**
3415 * Interrupt status register.
3416 */
3417#define LSILOGIC_REG_HOST_INTR_STATUS 0x30
3418# define LSILOGIC_REG_HOST_INTR_STATUS_W_MASK (RT_BIT(3))
3419# define LSILOGIC_REG_HOST_INTR_STATUS_DOORBELL_STS (RT_BIT(31))
3420# define LSILOGIC_REG_HOST_INTR_STATUS_REPLY_INTR (RT_BIT(3))
3421# define LSILOGIC_REG_HOST_INTR_STATUS_SYSTEM_DOORBELL (RT_BIT(0))
3422
3423/**
3424 * Interrupt mask register.
3425 */
3426#define LSILOGIC_REG_HOST_INTR_MASK 0x34
3427# define LSILOGIC_REG_HOST_INTR_MASK_W_MASK (RT_BIT(0) | RT_BIT(3) | RT_BIT(8) | RT_BIT(9))
3428# define LSILOGIC_REG_HOST_INTR_MASK_IRQ_ROUTING (RT_BIT(8) | RT_BIT(9))
3429# define LSILOGIC_REG_HOST_INTR_MASK_DOORBELL RT_BIT(0)
3430# define LSILOGIC_REG_HOST_INTR_MASK_REPLY RT_BIT(3)
3431
3432/**
3433 * Queue registers.
3434 */
3435#define LSILOGIC_REG_REQUEST_QUEUE 0x40
3436#define LSILOGIC_REG_REPLY_QUEUE 0x44
3437
3438#endif /* __DEVLSILOGICSCSI_H__ */
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette