1 /*- 2 * SPDX-License-Identifier: BSD-2-Clause 3 * 4 * Copyright (c) 2000 Michael Smith 5 * Copyright (c) 2000-2001 Scott Long 6 * Copyright (c) 2000 BSDi 7 * Copyright (c) 2001-2010 Adaptec, Inc. 8 * Copyright (c) 2010-2012 PMC-Sierra, Inc. 9 * All rights reserved. 10 * 11 * Redistribution and use in source and binary forms, with or without 12 * modification, are permitted provided that the following conditions 13 * are met: 14 * 1. Redistributions of source code must retain the above copyright 15 * notice, this list of conditions and the following disclaimer. 16 * 2. Redistributions in binary form must reproduce the above copyright 17 * notice, this list of conditions and the following disclaimer in the 18 * documentation and/or other materials provided with the distribution. 19 * 20 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 21 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30 * SUCH DAMAGE. 31 * 32 * $FreeBSD$ 33 */ 34 35 /* 36 * Data structures defining the interface between the driver and the Adaptec 37 * 'FSA' adapters. Note that many field names and comments here are taken 38 * verbatim from the Adaptec driver source in order to make comparing the 39 * two slightly easier. 40 */ 41 42 /* 43 * Misc. magic numbers. 44 */ 45 #define AAC_MAX_CONTAINERS 240 46 #define AAC_BLOCK_SIZE 512 47 48 /* 49 * Communications interface. 50 * 51 * Where datastructure layouts are closely parallel to the Adaptec sample code, 52 * retain their naming conventions (for now) to aid in cross-referencing. 53 */ 54 55 /* transport FIB header (PMC) */ 56 struct aac_fib_xporthdr { 57 u_int64_t HostAddress; /* FIB host address w/o xport header */ 58 u_int32_t Size; /* FIB size excluding xport header */ 59 u_int32_t Handle; /* driver handle to reference the FIB */ 60 u_int64_t Reserved[2]; 61 } __packed; 62 63 /* 64 * List structure used to chain FIBs (used by the adapter - we hang FIBs off 65 * our private command structure and don't touch these) 66 */ 67 struct aac_fib_list_entry { 68 u_int32_t Flink; 69 u_int32_t Blink; 70 } __packed; 71 72 /* 73 * FIB (FSA Interface Block?); this is the datastructure passed between the host 74 * and adapter. 75 */ 76 struct aac_fib_header { 77 u_int32_t XferState; 78 u_int16_t Command; 79 u_int8_t StructType; 80 u_int8_t Unused; 81 u_int16_t Size; 82 u_int16_t SenderSize; 83 u_int32_t SenderFibAddress; 84 union { 85 u_int32_t ReceiverFibAddress; 86 u_int32_t SenderFibAddressHigh; 87 u_int32_t TimeStamp; 88 } u; 89 u_int32_t Handle; 90 u_int32_t Previous; 91 u_int32_t Next; 92 } __packed; 93 94 #define AAC_FIB_DATASIZE (512 - sizeof(struct aac_fib_header)) 95 96 struct aac_fib { 97 struct aac_fib_header Header; 98 u_int8_t data[AAC_FIB_DATASIZE]; 99 } __packed; 100 101 /* 102 * FIB commands 103 */ 104 typedef enum { 105 TestCommandResponse = 1, 106 TestAdapterCommand = 2, 107 108 /* lowlevel and comm commands */ 109 LastTestCommand = 100, 110 ReinitHostNormCommandQueue = 101, 111 ReinitHostHighCommandQueue = 102, 112 ReinitHostHighRespQueue = 103, 113 ReinitHostNormRespQueue = 104, 114 ReinitAdapNormCommandQueue = 105, 115 ReinitAdapHighCommandQueue = 107, 116 ReinitAdapHighRespQueue = 108, 117 ReinitAdapNormRespQueue = 109, 118 InterfaceShutdown = 110, 119 DmaCommandFib = 120, 120 StartProfile = 121, 121 TermProfile = 122, 122 SpeedTest = 123, 123 TakeABreakPt = 124, 124 RequestPerfData = 125, 125 SetInterruptDefTimer= 126, 126 SetInterruptDefCount= 127, 127 GetInterruptDefStatus= 128, 128 LastCommCommand = 129, 129 130 /* filesystem commands */ 131 NuFileSystem = 300, 132 UFS = 301, 133 HostFileSystem = 302, 134 LastFileSystemCommand = 303, 135 136 /* Container Commands */ 137 ContainerCommand = 500, 138 ContainerCommand64 = 501, 139 RawIo = 502, 140 RawIo2 = 503, 141 142 /* Cluster Commands */ 143 ClusterCommand = 550, 144 145 /* Scsi Port commands (scsi passthrough) */ 146 ScsiPortCommand = 600, 147 ScsiPortCommandU64 = 601, 148 SataPortCommandU64 = 602, 149 SasSmpPassThrough = 603, 150 SasRequestPhyInfo = 612, 151 152 /* misc house keeping and generic adapter initiated commands */ 153 AifRequest = 700, 154 CheckRevision = 701, 155 FsaHostShutdown = 702, 156 RequestAdapterInfo = 703, 157 IsAdapterPaused = 704, 158 SendHostTime = 705, 159 RequestSupplementAdapterInfo = 706, /* Supp. Info for set in UCC 160 * use only if supported 161 * (RequestAdapterInfo first) */ 162 LastMiscCommand = 707, 163 164 OnLineDiagnostic = 800, 165 FduAdapterTest = 801, 166 RequestCompatibilityId = 802, 167 AdapterEnvironmentInfo = 803, /* temp. sensors */ 168 NvsramEventLog = 900, 169 ResetNvsramEventLogPointers = 901, 170 EnableEventLog = 902, 171 DisableEventLog = 903, 172 EncryptedKeyTransportFIB= 904, 173 KeyableFeaturesFIB= 905 174 } AAC_FibCommands; 175 176 /* 177 * FIB types 178 */ 179 #define AAC_FIBTYPE_TFIB 1 180 #define AAC_FIBTYPE_TQE 2 181 #define AAC_FIBTYPE_TCTPERF 3 182 #define AAC_FIBTYPE_TFIB2 4 183 #define AAC_FIBTYPE_TFIB2_64 5 184 185 /* 186 * FIB transfer state 187 */ 188 #define AAC_FIBSTATE_HOSTOWNED (1<<0) /* owned by the host */ 189 #define AAC_FIBSTATE_ADAPTEROWNED (1<<1) /* owned by the adapter */ 190 #define AAC_FIBSTATE_INITIALISED (1<<2) /* initialised */ 191 #define AAC_FIBSTATE_EMPTY (1<<3) /* empty */ 192 #define AAC_FIBSTATE_FROMPOOL (1<<4) /* allocated from pool */ 193 #define AAC_FIBSTATE_FROMHOST (1<<5) /* sent from the host */ 194 #define AAC_FIBSTATE_FROMADAP (1<<6) /* sent from the adapter */ 195 #define AAC_FIBSTATE_REXPECTED (1<<7) /* response is expected */ 196 #define AAC_FIBSTATE_RNOTEXPECTED (1<<8) /* response is not expected */ 197 #define AAC_FIBSTATE_DONEADAP (1<<9) /* processed by the adapter */ 198 #define AAC_FIBSTATE_DONEHOST (1<<10) /* processed by the host */ 199 #define AAC_FIBSTATE_HIGH (1<<11) /* high priority */ 200 #define AAC_FIBSTATE_NORM (1<<12) /* normal priority */ 201 #define AAC_FIBSTATE_ASYNC (1<<13) 202 #define AAC_FIBSTATE_ASYNCIO (1<<13) /* to be removed */ 203 #define AAC_FIBSTATE_PAGEFILEIO (1<<14) /* to be removed */ 204 #define AAC_FIBSTATE_SHUTDOWN (1<<15) 205 #define AAC_FIBSTATE_LAZYWRITE (1<<16) /* to be removed */ 206 #define AAC_FIBSTATE_ADAPMICROFIB (1<<17) 207 #define AAC_FIBSTATE_BIOSFIB (1<<18) 208 #define AAC_FIBSTATE_FAST_RESPONSE (1<<19) /* fast response capable */ 209 #define AAC_FIBSTATE_APIFIB (1<<20) 210 #define AAC_FIBSTATE_NOMOREAIF (1<<21) 211 212 /* 213 * FIB error values 214 */ 215 #define AAC_ERROR_NORMAL 0x00 216 #define AAC_ERROR_PENDING 0x01 217 #define AAC_ERROR_FATAL 0x02 218 #define AAC_ERROR_INVALID_QUEUE 0x03 219 #define AAC_ERROR_NOENTRIES 0x04 220 #define AAC_ERROR_SENDFAILED 0x05 221 #define AAC_ERROR_INVALID_QUEUE_PRIORITY 0x06 222 #define AAC_ERROR_FIB_ALLOCATION_FAILED 0x07 223 #define AAC_ERROR_FIB_DEALLOCATION_FAILED 0x08 224 225 /* 226 * Adapter Init Structure: this is passed to the adapter with the 227 * AAC_MONKER_INITSTRUCT command to point it at our control structures. 228 */ 229 struct aac_adapter_init { 230 u_int32_t InitStructRevision; 231 #define AAC_INIT_STRUCT_REVISION 3 232 #define AAC_INIT_STRUCT_REVISION_4 4 233 #define AAC_INIT_STRUCT_REVISION_6 6 234 #define AAC_INIT_STRUCT_REVISION_7 7 235 u_int32_t NoOfMSIXVectors; 236 u_int32_t FilesystemRevision; 237 u_int32_t CommHeaderAddress; 238 u_int32_t FastIoCommAreaAddress; 239 u_int32_t AdapterFibsPhysicalAddress; 240 u_int32_t AdapterFibsVirtualAddress; 241 u_int32_t AdapterFibsSize; 242 u_int32_t AdapterFibAlign; 243 u_int32_t PrintfBufferAddress; 244 u_int32_t PrintfBufferSize; 245 #define AAC_PAGE_SIZE 4096 246 u_int32_t HostPhysMemPages; 247 u_int32_t HostElapsedSeconds; 248 /* ADAPTER_INIT_STRUCT_REVISION_4 begins here */ 249 u_int32_t InitFlags; /* flags for supported features */ 250 #define AAC_INITFLAGS_NEW_COMM_SUPPORTED 1 251 #define AAC_INITFLAGS_DRIVER_USES_UTC_TIME 0x10 252 #define AAC_INITFLAGS_DRIVER_SUPPORTS_PM 0x20 253 #define AAC_INITFLAGS_NEW_COMM_TYPE1_SUPPORTED 0x40 254 #define AAC_INITFLAGS_FAST_JBOD_SUPPORTED 0x80 255 #define AAC_INITFLAGS_NEW_COMM_TYPE2_SUPPORTED 0x100 256 u_int32_t MaxIoCommands; /* max outstanding commands */ 257 u_int32_t MaxIoSize; /* largest I/O command */ 258 u_int32_t MaxFibSize; /* largest FIB to adapter */ 259 /* ADAPTER_INIT_STRUCT_REVISION_5 begins here */ 260 u_int32_t MaxNumAif; /* max number of aif */ 261 /* ADAPTER_INIT_STRUCT_REVISION_6 begins here */ 262 u_int32_t HostRRQ_AddrLow; 263 u_int32_t HostRRQ_AddrHigh; /* Host RRQ (response queue) for SRC */ 264 } __packed; 265 266 /* 267 * Shared data types 268 */ 269 /* 270 * Container types 271 */ 272 typedef enum { 273 CT_NONE = 0, 274 CT_VOLUME, 275 CT_MIRROR, 276 CT_STRIPE, 277 CT_RAID5, 278 CT_SSRW, 279 CT_SSRO, 280 CT_MORPH, 281 CT_PASSTHRU, 282 CT_RAID4, 283 CT_RAID10, /* stripe of mirror */ 284 CT_RAID00, /* stripe of stripe */ 285 CT_VOLUME_OF_MIRRORS, /* volume of mirror */ 286 CT_PSEUDO_RAID3, /* really raid4 */ 287 CT_RAID50, /* stripe of raid5 */ 288 CT_RAID5D, /* raid5 distributed hot-sparing */ 289 CT_RAID5D0, 290 CT_RAID1E, /* extended raid1 mirroring */ 291 CT_RAID6, 292 CT_RAID60, 293 } AAC_FSAVolType; 294 295 /* 296 * Host-addressable object types 297 */ 298 typedef enum { 299 FT_REG = 1, /* regular file */ 300 FT_DIR, /* directory */ 301 FT_BLK, /* "block" device - reserved */ 302 FT_CHR, /* "character special" device - reserved */ 303 FT_LNK, /* symbolic link */ 304 FT_SOCK, /* socket */ 305 FT_FIFO, /* fifo */ 306 FT_FILESYS, /* ADAPTEC's "FSA"(tm) filesystem */ 307 FT_DRIVE, /* physical disk - addressable in scsi by b/t/l */ 308 FT_SLICE, /* virtual disk - raw volume - slice */ 309 FT_PARTITION, /* FSA partition - carved out of a slice - building 310 * block for containers */ 311 FT_VOLUME, /* Container - Volume Set */ 312 FT_STRIPE, /* Container - Stripe Set */ 313 FT_MIRROR, /* Container - Mirror Set */ 314 FT_RAID5, /* Container - Raid 5 Set */ 315 FT_DATABASE /* Storage object with "foreign" content manager */ 316 } AAC_FType; 317 318 /* 319 * Host-side scatter/gather list for 32-bit commands. 320 */ 321 struct aac_sg_entry { 322 u_int32_t SgAddress; 323 u_int32_t SgByteCount; 324 } __packed; 325 326 struct aac_sg_entry64 { 327 u_int64_t SgAddress; 328 u_int32_t SgByteCount; 329 } __packed; 330 331 struct aac_sg_entryraw { 332 u_int32_t Next; /* reserved for FW use */ 333 u_int32_t Prev; /* reserved for FW use */ 334 u_int64_t SgAddress; 335 u_int32_t SgByteCount; 336 u_int32_t Flags; /* reserved for FW use */ 337 } __packed; 338 339 struct aac_sg_table { 340 u_int32_t SgCount; 341 struct aac_sg_entry SgEntry[0]; 342 } __packed; 343 344 /* 345 * Host-side scatter/gather list for 64-bit commands. 346 */ 347 struct aac_sg_table64 { 348 u_int32_t SgCount; 349 struct aac_sg_entry64 SgEntry64[0]; 350 } __packed; 351 352 /* 353 * s/g list for raw commands 354 */ 355 struct aac_sg_tableraw { 356 u_int32_t SgCount; 357 struct aac_sg_entryraw SgEntryRaw[0]; 358 } __packed; 359 360 /* 361 * new ieee1212 s/g element 362 */ 363 struct aac_sge_ieee1212 { 364 u_int32_t addrLow; 365 u_int32_t addrHigh; 366 u_int32_t length; 367 u_int32_t flags; /* always 0 from host side */ 368 } __packed; 369 370 /* 371 * Container creation data 372 */ 373 struct aac_container_creation { 374 u_int8_t ViaBuildNumber; 375 u_int8_t MicroSecond; 376 u_int8_t Via; /* 1 = FSU, 2 = API, etc. */ 377 u_int8_t YearsSince1900; 378 u_int32_t Month:4; /* 1-12 */ 379 u_int32_t Day:6; /* 1-32 */ 380 u_int32_t Hour:6; /* 0-23 */ 381 u_int32_t Minute:6; /* 0-59 */ 382 u_int32_t Second:6; /* 0-59 */ 383 u_int64_t ViaAdapterSerialNumber; 384 } __packed; 385 386 /* 387 * Revision number handling 388 */ 389 390 typedef enum { 391 RevApplication = 1, 392 RevDkiCli, 393 RevNetService, 394 RevApi, 395 RevFileSysDriver, 396 RevMiniportDriver, 397 RevAdapterSW, 398 RevMonitor, 399 RevRemoteApi 400 } RevComponent; 401 402 struct FsaRevision { 403 union { 404 struct { 405 u_int8_t dash; 406 u_int8_t type; 407 u_int8_t minor; 408 u_int8_t major; 409 } comp; 410 u_int32_t ul; 411 } external; 412 u_int32_t buildNumber; 413 } __packed; 414 415 /* 416 * Adapter Information 417 */ 418 419 typedef enum { 420 CPU_NTSIM = 1, 421 CPU_I960, 422 CPU_ARM, 423 CPU_SPARC, 424 CPU_POWERPC, 425 CPU_ALPHA, 426 CPU_P7, 427 CPU_I960_RX, 428 CPU_MIPS, 429 CPU_XSCALE, 430 CPU__last 431 } AAC_CpuType; 432 433 typedef enum { 434 CPUI960_JX = 1, 435 CPUI960_CX, 436 CPUI960_HX, 437 CPUI960_RX, 438 CPUARM_SA110, 439 CPUARM_xxx, 440 CPUPPC_603e, 441 CPUPPC_xxx, 442 CPUI960_80303, 443 CPU_XSCALE_80321, 444 CPU_MIPS_4KC, 445 CPU_MIPS_5KC, 446 CPUSUBTYPE__last 447 } AAC_CpuSubType; 448 449 typedef enum { 450 PLAT_NTSIM = 1, 451 PLAT_V3ADU, 452 PLAT_CYCLONE, 453 PLAT_CYCLONE_HD, 454 PLAT_BATBOARD, 455 PLAT_BATBOARD_HD, 456 PLAT_YOLO, 457 PLAT_COBRA, 458 PLAT_ANAHEIM, 459 PLAT_JALAPENO, 460 PLAT_QUEENS, 461 PLAT_JALAPENO_DELL, 462 PLAT_POBLANO, 463 PLAT_POBLANO_OPAL, 464 PLAT_POBLANO_SL0, 465 PLAT_POBLANO_SL1, 466 PLAT_POBLANO_SL2, 467 PLAT_POBLANO_XXX, 468 PLAT_JALAPENO_P2, 469 PLAT_HABANERO, 470 PLAT_VULCAN, 471 PLAT_CRUSADER, 472 PLAT_LANCER, 473 PLAT_HARRIER, 474 PLAT_TERMINATOR, 475 PLAT_SKYHAWK, 476 PLAT_CORSAIR, 477 PLAT_JAGUAR, 478 PLAT_SATAHAWK, 479 PLAT_SATANATOR, 480 PLAT_PROWLER, 481 PLAT_BLACKBIRD, 482 PLAT_SABREEXPRESS, 483 PLAT_INTRUDER, 484 PLAT__last 485 } AAC_Platform; 486 487 typedef enum { 488 OEM_FLAVOR_ADAPTEC = 1, 489 OEM_FLAVOR_DELL, 490 OEM_FLAVOR_HP, 491 OEM_FLAVOR_IBM, 492 OEM_FLAVOR_CPQ, 493 OEM_FLAVOR_FSC, 494 OEM_FLAVOR_DWS, 495 OEM_FLAVOR_BRAND_Z, 496 OEM_FLAVOR_LEGEND, 497 OEM_FLAVOR_HITACHI, 498 OEM_FLAVOR_ESG, 499 OEM_FLAVOR_ICP, 500 OEM_FLAVOR_SCM, 501 OEM_FLAVOR__last 502 } AAC_OemFlavor; 503 504 /* 505 * XXX the aac-2622 with no battery present reports PLATFORM_BAT_OPT_PRESENT 506 */ 507 typedef enum 508 { 509 PLATFORM_BAT_REQ_PRESENT = 1, /* BATTERY REQUIRED AND PRESENT */ 510 PLATFORM_BAT_REQ_NOTPRESENT, /* BATTERY REQUIRED AND NOT PRESENT */ 511 PLATFORM_BAT_OPT_PRESENT, /* BATTERY OPTIONAL AND PRESENT */ 512 PLATFORM_BAT_OPT_NOTPRESENT, /* BATTERY OPTIONAL AND NOT PRESENT */ 513 PLATFORM_BAT_NOT_SUPPORTED /* BATTERY NOT SUPPORTED */ 514 } AAC_BatteryPlatform; 515 516 /* 517 * options supported by this board 518 * there has to be a one to one mapping of these defines and the ones in 519 * fsaapi.h, search for FSA_SUPPORT_SNAPSHOT 520 */ 521 #define AAC_SUPPORTED_SNAPSHOT 0x01 522 #define AAC_SUPPORTED_CLUSTERS 0x02 523 #define AAC_SUPPORTED_WRITE_CACHE 0x04 524 #define AAC_SUPPORTED_64BIT_DATA 0x08 525 #define AAC_SUPPORTED_HOST_TIME_FIB 0x10 526 #define AAC_SUPPORTED_RAID50 0x20 527 #define AAC_SUPPORTED_4GB_WINDOW 0x40 528 #define AAC_SUPPORTED_SCSI_UPGRADEABLE 0x80 529 #define AAC_SUPPORTED_SOFT_ERR_REPORT 0x100 530 #define AAC_SUPPORTED_NOT_RECONDITION 0x200 531 #define AAC_SUPPORTED_SGMAP_HOST64 0x400 532 #define AAC_SUPPORTED_ALARM 0x800 533 #define AAC_SUPPORTED_NONDASD 0x1000 534 #define AAC_SUPPORTED_SCSI_MANAGED 0x2000 535 #define AAC_SUPPORTED_RAID_SCSI_MODE 0x4000 536 #define AAC_SUPPORTED_SUPPLEMENT_ADAPTER_INFO 0x10000 537 #define AAC_SUPPORTED_NEW_COMM 0x20000 538 #define AAC_SUPPORTED_64BIT_ARRAYSIZE 0x40000 539 #define AAC_SUPPORTED_HEAT_SENSOR 0x80000 540 #define AAC_SUPPORTED_NEW_COMM_TYPE1 0x10000000 /* Tupelo new comm */ 541 #define AAC_SUPPORTED_NEW_COMM_TYPE2 0x20000000 /* Denali new comm */ 542 #define AAC_SUPPORTED_NEW_COMM_TYPE3 0x40000000 /* Series 8 new comm */ 543 #define AAC_SUPPORTED_NEW_COMM_TYPE4 0x80000000 /* Series 9 new comm */ 544 545 /* 546 * Structure used to respond to a RequestAdapterInfo fib. 547 */ 548 struct aac_adapter_info { 549 AAC_Platform PlatformBase; /* adapter type */ 550 AAC_CpuType CpuArchitecture; /* adapter CPU type */ 551 AAC_CpuSubType CpuVariant; /* adapter CPU subtype */ 552 u_int32_t ClockSpeed; /* adapter CPU clockspeed */ 553 u_int32_t ExecutionMem; /* adapter Execution Memory 554 * size */ 555 u_int32_t BufferMem; /* adapter Data Memory */ 556 u_int32_t TotalMem; /* adapter Total Memory */ 557 struct FsaRevision KernelRevision; /* adapter Kernel Software 558 * Revision */ 559 struct FsaRevision MonitorRevision; /* adapter Monitor/Diagnostic 560 * Software Revision */ 561 struct FsaRevision HardwareRevision;/* TBD */ 562 struct FsaRevision BIOSRevision; /* adapter BIOS Revision */ 563 u_int32_t ClusteringEnabled; 564 u_int32_t ClusterChannelMask; 565 u_int64_t SerialNumber; 566 AAC_BatteryPlatform batteryPlatform; 567 u_int32_t SupportedOptions; /* supported features of this 568 * controller */ 569 AAC_OemFlavor OemVariant; 570 } __packed; 571 572 /* 573 * More options from supplement info - SupportedOptions2 574 */ 575 #define AAC_SUPPORTED_MU_RESET 0x01 576 #define AAC_SUPPORTED_IGNORE_RESET 0x02 577 #define AAC_SUPPORTED_POWER_MANAGEMENT 0x04 578 #define AAC_SUPPORTED_ARCIO_PHYDEV 0x08 579 #define AAC_SUPPORTED_DOORBELL_RESET 0x4000 580 #define AAC_SUPPORTED_VARIABLE_BLOCK_SIZE 0x40000 /* 4KB sector size */ 581 582 /* 583 * FeatureBits of RequestSupplementAdapterInfo used in the driver 584 */ 585 #define AAC_SUPPL_SUPPORTED_JBOD 0x08000000 586 587 /* 588 * Structure used to respond to a RequestSupplementAdapterInfo fib. 589 */ 590 struct vpd_info { 591 u_int8_t AssemblyPn[8]; 592 u_int8_t FruPn[8]; 593 u_int8_t BatteryFruPn[8]; 594 u_int8_t EcVersionString[8]; 595 u_int8_t Tsid[12]; 596 } __packed; 597 598 #define MFG_PCBA_SERIAL_NUMBER_WIDTH 12 599 #define MFG_WWN_WIDTH 8 600 601 struct aac_supplement_adapter_info { 602 /* The assigned Adapter Type Text, extra byte for null termination */ 603 int8_t AdapterTypeText[17+1]; 604 /* Pad for the text above */ 605 int8_t Pad[2]; 606 /* Size in bytes of the memory that is flashed */ 607 u_int32_t FlashMemoryByteSize; 608 /* The assigned IMAGEID_xxx for this adapter */ 609 u_int32_t FlashImageId; 610 /* 611 * The maximum number of Phys available on a SATA/SAS 612 * Controller, 0 otherwise 613 */ 614 u_int32_t MaxNumberPorts; 615 /* Version of expansion area */ 616 u_int32_t Version; 617 u_int32_t FeatureBits; 618 u_int8_t SlotNumber; 619 u_int8_t ReservedPad0[3]; 620 u_int8_t BuildDate[12]; 621 /* The current number of Ports on a SAS controller, 0 otherwise */ 622 u_int32_t CurrentNumberPorts; 623 624 struct vpd_info VpdInfo; 625 626 /* Firmware Revision (Vmaj.min-dash.) */ 627 struct FsaRevision FlashFirmwareRevision; 628 u_int32_t RaidTypeMorphOptions; 629 /* Firmware's boot code Revision (Vmaj.min-dash.) */ 630 struct FsaRevision FlashFirmwareBootRevision; 631 /* PCBA serial no. from th MFG sector */ 632 u_int8_t MfgPcbaSerialNo[MFG_PCBA_SERIAL_NUMBER_WIDTH]; 633 /* WWN from the MFG sector */ 634 u_int8_t MfgWWNName[MFG_WWN_WIDTH]; 635 u_int32_t SupportedOptions2; /* more supported features */ 636 u_int32_t ExpansionFlag; /* 1 - following fields are valid */ 637 u_int32_t FeatureBits3; 638 u_int32_t SupportedPerformanceMode; 639 /* Growth Area for future expansion */ 640 u_int32_t ReservedGrowth[80]; 641 } __packed; 642 643 /* 644 * Monitor/Kernel interface. 645 */ 646 647 /* 648 * Synchronous commands to the monitor/kernel. 649 */ 650 #define AAC_MONKER_BREAKPOINT 0x04 651 #define AAC_MONKER_INITSTRUCT 0x05 652 #define AAC_MONKER_SYNCFIB 0x0c 653 #define AAC_MONKER_GETKERNVER 0x11 654 #define AAC_MONKER_POSTRESULTS 0x14 655 #define AAC_MONKER_GETINFO 0x19 656 #define AAC_MONKER_GETDRVPROP 0x23 657 #define AAC_MONKER_RCVTEMP 0x25 658 #define AAC_MONKER_GETCOMMPREF 0x26 659 #define AAC_MONKER_REINIT 0xee 660 #define AAC_IOP_RESET 0x1000 661 #define AAC_IOP_RESET_ALWAYS 0x1001 662 663 /* 664 * Adapter Status Register 665 * 666 * Phase Staus mailbox is 32bits: 667 * <31:16> = Phase Status 668 * <15:0> = Phase 669 * 670 * The adapter reports its present state through the phase. Only 671 * a single phase should be ever be set. Each phase can have multiple 672 * phase status bits to provide more detailed information about the 673 * state of the adapter. 674 */ 675 #define AAC_SELF_TEST_FAILED 0x00000004 676 #define AAC_MONITOR_PANIC 0x00000020 677 #define AAC_UP_AND_RUNNING 0x00000080 678 #define AAC_KERNEL_PANIC 0x00000100 679 680 /* 681 * for dual FW image support 682 */ 683 #define AAC_FLASH_UPD_PENDING 0x00002000 684 #define AAC_FLASH_UPD_SUCCESS 0x00004000 685 #define AAC_FLASH_UPD_FAILED 0x00008000 686 687 /* 688 * Data types relating to control and monitoring of the NVRAM/WriteCache 689 * subsystem. 690 */ 691 692 #define AAC_NFILESYS 24 /* maximum number of filesystems */ 693 694 /* 695 * NVRAM/Write Cache subsystem states 696 */ 697 typedef enum { 698 NVSTATUS_DISABLED = 0, /* present, clean, not being used */ 699 NVSTATUS_ENABLED, /* present, possibly dirty, ready for use */ 700 NVSTATUS_ERROR, /* present, dirty, contains dirty data */ 701 NVSTATUS_BATTERY, /* present, bad or low battery, may contain 702 * dirty data */ 703 NVSTATUS_UNKNOWN /* for bad/missing device */ 704 } AAC_NVSTATUS; 705 706 /* 707 * NVRAM/Write Cache subsystem battery component states 708 * 709 */ 710 typedef enum { 711 NVBATTSTATUS_NONE = 0, /* battery has no power or is not present */ 712 NVBATTSTATUS_LOW, /* battery is low on power */ 713 NVBATTSTATUS_OK, /* battery is okay - normal operation possible 714 * only in this state */ 715 NVBATTSTATUS_RECONDITIONING /* no battery present - reconditioning 716 * in process */ 717 } AAC_NVBATTSTATUS; 718 719 /* 720 * Battery transition type 721 */ 722 typedef enum { 723 NVBATT_TRANSITION_NONE = 0, /* battery now has no power or is not 724 * present */ 725 NVBATT_TRANSITION_LOW, /* battery is now low on power */ 726 NVBATT_TRANSITION_OK /* battery is now okay - normal 727 * operation possible only in this 728 * state */ 729 } AAC_NVBATT_TRANSITION; 730 731 /* 732 * NVRAM Info structure returned for NVRAM_GetInfo call 733 */ 734 struct aac_nvramdevinfo { 735 u_int32_t NV_Enabled; /* write caching enabled */ 736 u_int32_t NV_Error; /* device in error state */ 737 u_int32_t NV_NDirty; /* count of dirty NVRAM buffers */ 738 u_int32_t NV_NActive; /* count of NVRAM buffers being 739 * written */ 740 } __packed; 741 742 struct aac_nvraminfo { 743 AAC_NVSTATUS NV_Status; /* nvram subsystem status */ 744 AAC_NVBATTSTATUS NV_BattStatus; /* battery status */ 745 u_int32_t NV_Size; /* size of WriteCache NVRAM in 746 * bytes */ 747 u_int32_t NV_BufSize; /* size of NVRAM buffers in 748 * bytes */ 749 u_int32_t NV_NBufs; /* number of NVRAM buffers */ 750 u_int32_t NV_NDirty; /* Num dirty NVRAM buffers */ 751 u_int32_t NV_NClean; /* Num clean NVRAM buffers */ 752 u_int32_t NV_NActive; /* Num NVRAM buffers being 753 * written */ 754 u_int32_t NV_NBrokered; /* Num brokered NVRAM buffers */ 755 struct aac_nvramdevinfo NV_DevInfo[AAC_NFILESYS]; /* per device 756 * info */ 757 u_int32_t NV_BattNeedsReconditioning; /* boolean */ 758 u_int32_t NV_TotalSize; /* size of all non-volatile 759 * memories in bytes */ 760 } __packed; 761 762 /* 763 * Data types relating to adapter-initiated FIBs 764 * 765 * Based on types and structures in <aifstruc.h> 766 */ 767 768 /* 769 * Progress Reports 770 */ 771 typedef enum { 772 AifJobStsSuccess = 1, 773 AifJobStsFinished, 774 AifJobStsAborted, 775 AifJobStsFailed, 776 AifJobStsLastReportMarker = 100, /* All prior mean last report */ 777 AifJobStsSuspended, 778 AifJobStsRunning 779 } AAC_AifJobStatus; 780 781 typedef enum { 782 AifJobScsiMin = 1, /* Minimum value for Scsi operation */ 783 AifJobScsiZero, /* SCSI device clear operation */ 784 AifJobScsiVerify, /* SCSI device Verify operation NO 785 * REPAIR */ 786 AifJobScsiExercise, /* SCSI device Exercise operation */ 787 AifJobScsiVerifyRepair, /* SCSI device Verify operation WITH 788 * repair */ 789 AifJobScsiWritePattern, /* write pattern */ 790 AifJobScsiMax = 99, /* Max Scsi value */ 791 AifJobCtrMin, /* Min Ctr op value */ 792 AifJobCtrZero, /* Container clear operation */ 793 AifJobCtrCopy, /* Container copy operation */ 794 AifJobCtrCreateMirror, /* Container Create Mirror operation */ 795 AifJobCtrMergeMirror, /* Container Merge Mirror operation */ 796 AifJobCtrScrubMirror, /* Container Scrub Mirror operation */ 797 AifJobCtrRebuildRaid5, /* Container Rebuild Raid5 operation */ 798 AifJobCtrScrubRaid5, /* Container Scrub Raid5 operation */ 799 AifJobCtrMorph, /* Container morph operation */ 800 AifJobCtrPartCopy, /* Container Partition copy operation */ 801 AifJobCtrRebuildMirror, /* Container Rebuild Mirror operation */ 802 AifJobCtrCrazyCache, /* crazy cache */ 803 AifJobCtrCopyback, /* Container Copyback operation */ 804 AifJobCtrCompactRaid5D, /* Container Compaction operation */ 805 AifJobCtrExpandRaid5D, /* Container Expansion operation */ 806 AifJobCtrRebuildRaid6, /* Container Rebuild Raid6 operation */ 807 AifJobCtrScrubRaid6, /* Container Scrub Raid6 operation */ 808 AifJobCtrSSBackup, /* Container snapshot backup task */ 809 AifJobCtrMax = 199, /* Max Ctr type operation */ 810 AifJobFsMin, /* Min Fs type operation */ 811 AifJobFsCreate, /* File System Create operation */ 812 AifJobFsVerify, /* File System Verify operation */ 813 AifJobFsExtend, /* File System Extend operation */ 814 AifJobFsMax = 299, /* Max Fs type operation */ 815 AifJobApiFormatNTFS, /* Format a drive to NTFS */ 816 AifJobApiFormatFAT, /* Format a drive to FAT */ 817 AifJobApiUpdateSnapshot, /* update the read/write half of a 818 * snapshot */ 819 AifJobApiFormatFAT32, /* Format a drive to FAT32 */ 820 AifJobApiMax = 399, /* Max API type operation */ 821 AifJobCtlContinuousCtrVerify, /* Adapter operation */ 822 AifJobCtlMax = 499 /* Max Adapter type operation */ 823 } AAC_AifJobType; 824 825 struct aac_AifContainers { 826 u_int32_t src; /* from/master */ 827 u_int32_t dst; /* to/slave */ 828 } __packed; 829 830 union aac_AifJobClient { 831 struct aac_AifContainers container; /* For Container and 832 * filesystem progress 833 * ops; */ 834 int32_t scsi_dh; /* For SCSI progress 835 * ops */ 836 }; 837 838 struct aac_AifJobDesc { 839 u_int32_t jobID; /* DO NOT FILL IN! Will be 840 * filled in by AIF */ 841 AAC_AifJobType type; /* Operation that is being 842 * performed */ 843 union aac_AifJobClient client; /* Details */ 844 } __packed; 845 846 struct aac_AifJobProgressReport { 847 struct aac_AifJobDesc jd; 848 AAC_AifJobStatus status; 849 u_int32_t finalTick; 850 u_int32_t currentTick; 851 u_int32_t jobSpecificData1; 852 u_int32_t jobSpecificData2; 853 } __packed; 854 855 /* 856 * Event Notification 857 */ 858 typedef enum { 859 /* General application notifies start here */ 860 AifEnGeneric = 1, /* Generic notification */ 861 AifEnTaskComplete, /* Task has completed */ 862 AifEnConfigChange, /* Adapter config change occurred */ 863 AifEnContainerChange, /* Adapter specific container 864 * configuration change */ 865 AifEnDeviceFailure, /* SCSI device failed */ 866 AifEnMirrorFailover, /* Mirror failover started */ 867 AifEnContainerEvent, /* Significant container event */ 868 AifEnFileSystemChange, /* File system changed */ 869 AifEnConfigPause, /* Container pause event */ 870 AifEnConfigResume, /* Container resume event */ 871 AifEnFailoverChange, /* Failover space assignment changed */ 872 AifEnRAID5RebuildDone, /* RAID5 rebuild finished */ 873 AifEnEnclosureManagement, /* Enclosure management event */ 874 AifEnBatteryEvent, /* Significant NV battery event */ 875 AifEnAddContainer, /* A new container was created. */ 876 AifEnDeleteContainer, /* A container was deleted. */ 877 AifEnSMARTEvent, /* SMART Event */ 878 AifEnBatteryNeedsRecond, /* The battery needs reconditioning */ 879 AifEnClusterEvent, /* Some cluster event */ 880 AifEnDiskSetEvent, /* A disk set event occurred. */ 881 AifEnContainerScsiEvent, /* a container event with no. and scsi id */ 882 AifEnPicBatteryEvent, /* An event gen. by pic_battery.c for an ABM */ 883 AifEnExpEvent, /* Exp. Event Type to replace CTPopUp messages */ 884 AifEnRAID6RebuildDone, /* RAID6 rebuild finished */ 885 AifEnSensorOverHeat, /* Heat Sensor indicate overheat */ 886 AifEnSensorCoolDown, /* Heat Sensor ind. cooled down after overheat */ 887 AifFeatureKeysModified, /* notif. of updated feature keys */ 888 AifApplicationExpirationEvent, /* notif. on app. expiration status */ 889 AifEnBackgroundConsistencyCheck,/* BCC notif. for NEC - DDTS 94700 */ 890 AifEnAddJBOD, /* A new JBOD type drive was created (30) */ 891 AifEnDeleteJBOD, /* A JBOD type drive was deleted (31) */ 892 AifDriverNotifyStart=199, /* Notifies for host driver go here */ 893 /* Host driver notifications start here */ 894 AifDenMorphComplete, /* A morph operation completed */ 895 AifDenVolumeExtendComplete, /* Volume expand operation completed */ 896 AifDriverNotifyDelay, 897 AifRawDeviceRemove /* Raw device Failure event */ 898 } AAC_AifEventNotifyType; 899 900 struct aac_AifEnsGeneric { 901 char text[132]; /* Generic text */ 902 } __packed; 903 904 struct aac_AifEnsDeviceFailure { 905 u_int32_t deviceHandle; /* SCSI device handle */ 906 } __packed; 907 908 struct aac_AifEnsMirrorFailover { 909 u_int32_t container; /* Container with failed element */ 910 u_int32_t failedSlice; /* Old slice which failed */ 911 u_int32_t creatingSlice; /* New slice used for auto-create */ 912 } __packed; 913 914 struct aac_AifEnsContainerChange { 915 u_int32_t container[2]; /* container that changed, -1 if no 916 * container */ 917 } __packed; 918 919 struct aac_AifEnsContainerEvent { 920 u_int32_t container; /* container number */ 921 u_int32_t eventType; /* event type */ 922 } __packed; 923 924 struct aac_AifEnsEnclosureEvent { 925 u_int32_t empID; /* enclosure management proc number */ 926 u_int32_t unitID; /* unitId, fan id, power supply id, 927 * slot id, tempsensor id. */ 928 u_int32_t eventType; /* event type */ 929 } __packed; 930 931 typedef enum { 932 AIF_EM_DRIVE_INSERTION=31, 933 AIF_EM_DRIVE_REMOVAL 934 } aac_AifEMEventType; 935 936 struct aac_AifEnsBatteryEvent { 937 AAC_NVBATT_TRANSITION transition_type; /* eg from low to ok */ 938 AAC_NVBATTSTATUS current_state; /* current batt state */ 939 AAC_NVBATTSTATUS prior_state; /* prev batt state */ 940 } __packed; 941 942 struct aac_AifEnsDiskSetEvent { 943 u_int32_t eventType; 944 u_int64_t DsNum; 945 u_int64_t CreatorId; 946 } __packed; 947 948 typedef enum { 949 CLUSTER_NULL_EVENT = 0, 950 CLUSTER_PARTNER_NAME_EVENT, /* change in partner hostname or 951 * adaptername from NULL to non-NULL */ 952 /* (partner's agent may be up) */ 953 CLUSTER_PARTNER_NULL_NAME_EVENT /* change in partner hostname or 954 * adaptername from non-null to NULL */ 955 /* (partner has rebooted) */ 956 } AAC_ClusterAifEvent; 957 958 struct aac_AifEnsClusterEvent { 959 AAC_ClusterAifEvent eventType; 960 } __packed; 961 962 struct aac_AifEventNotify { 963 AAC_AifEventNotifyType type; 964 union { 965 struct aac_AifEnsGeneric EG; 966 struct aac_AifEnsDeviceFailure EDF; 967 struct aac_AifEnsMirrorFailover EMF; 968 struct aac_AifEnsContainerChange ECC; 969 struct aac_AifEnsContainerEvent ECE; 970 struct aac_AifEnsEnclosureEvent EEE; 971 struct aac_AifEnsBatteryEvent EBE; 972 struct aac_AifEnsDiskSetEvent EDS; 973 /* struct aac_AifEnsSMARTEvent ES;*/ 974 struct aac_AifEnsClusterEvent ECLE; 975 } data; 976 } __packed; 977 978 /* 979 * Adapter Initiated FIB command structures. Start with the adapter 980 * initiated FIBs that really come from the adapter, and get responded 981 * to by the host. 982 */ 983 #define AAC_AIF_REPORT_MAX_SIZE 64 984 985 typedef enum { 986 AifCmdEventNotify = 1, /* Notify of event */ 987 AifCmdJobProgress, /* Progress report */ 988 AifCmdAPIReport, /* Report from other user of API */ 989 AifCmdDriverNotify, /* Notify host driver of event */ 990 AifReqJobList = 100, /* Gets back complete job list */ 991 AifReqJobsForCtr, /* Gets back jobs for specific container */ 992 AifReqJobsForScsi, /* Gets back jobs for specific SCSI device */ 993 AifReqJobReport, /* Gets back a specific job report or list */ 994 AifReqTerminateJob, /* Terminates job */ 995 AifReqSuspendJob, /* Suspends a job */ 996 AifReqResumeJob, /* Resumes a job */ 997 AifReqSendAPIReport, /* API generic report requests */ 998 AifReqAPIJobStart, /* Start a job from the API */ 999 AifReqAPIJobUpdate, /* Update a job report from the API */ 1000 AifReqAPIJobFinish, /* Finish a job from the API */ 1001 AifReqEvent = 200 /* PMC NEW COMM: Request the event data */ 1002 } AAC_AifCommand; 1003 1004 struct aac_aif_command { 1005 AAC_AifCommand command; /* Tell host what type of 1006 * notify this is */ 1007 u_int32_t seqNumber; /* To allow ordering of 1008 * reports (if necessary) */ 1009 union { 1010 struct aac_AifEventNotify EN; /* Event notify */ 1011 struct aac_AifJobProgressReport PR[1]; /* Progress report */ 1012 u_int8_t AR[AAC_AIF_REPORT_MAX_SIZE]; 1013 u_int8_t data[AAC_FIB_DATASIZE - 8]; 1014 } data; 1015 } __packed; 1016 1017 /* 1018 * Filesystem commands/data 1019 * 1020 * The adapter has a very complex filesystem interface, most of which we ignore. 1021 * (And which seems not to be implemented, anyway.) 1022 */ 1023 1024 /* 1025 * FSA commands 1026 * (not used?) 1027 */ 1028 typedef enum { 1029 Null = 0, 1030 GetAttributes, 1031 SetAttributes, 1032 Lookup, 1033 ReadLink, 1034 Read, 1035 Write, 1036 Create, 1037 MakeDirectory, 1038 SymbolicLink, 1039 MakeNode, 1040 Removex, 1041 RemoveDirectory, 1042 Rename, 1043 Link, 1044 ReadDirectory, 1045 ReadDirectoryPlus, 1046 FileSystemStatus, 1047 FileSystemInfo, 1048 PathConfigure, 1049 Commit, 1050 Mount, 1051 UnMount, 1052 Newfs, 1053 FsCheck, 1054 FsSync, 1055 SimReadWrite, 1056 SetFileSystemStatus, 1057 BlockRead, 1058 BlockWrite, 1059 NvramIoctl, 1060 FsSyncWait, 1061 ClearArchiveBit, 1062 SetAcl, 1063 GetAcl, 1064 AssignAcl, 1065 FaultInsertion, 1066 CrazyCache 1067 } AAC_FSACommand; 1068 1069 /* 1070 * Command status values 1071 */ 1072 typedef enum { 1073 ST_OK = 0, 1074 ST_PERM = 1, 1075 ST_NOENT = 2, 1076 ST_IO = 5, 1077 ST_NXIO = 6, 1078 ST_E2BIG = 7, 1079 ST_ACCES = 13, 1080 ST_EXIST = 17, 1081 ST_XDEV = 18, 1082 ST_NODEV = 19, 1083 ST_NOTDIR = 20, 1084 ST_ISDIR = 21, 1085 ST_INVAL = 22, 1086 ST_FBIG = 27, 1087 ST_NOSPC = 28, 1088 ST_ROFS = 30, 1089 ST_MLINK = 31, 1090 ST_WOULDBLOCK = 35, 1091 ST_NAMETOOLONG = 63, 1092 ST_NOTEMPTY = 66, 1093 ST_DQUOT = 69, 1094 ST_STALE = 70, 1095 ST_REMOTE = 71, 1096 ST_NOT_READY = 72, 1097 ST_BADHANDLE = 10001, 1098 ST_NOT_SYNC = 10002, 1099 ST_BAD_COOKIE = 10003, 1100 ST_NOTSUPP = 10004, 1101 ST_TOOSMALL = 10005, 1102 ST_SERVERFAULT = 10006, 1103 ST_BADTYPE = 10007, 1104 ST_JUKEBOX = 10008, 1105 ST_NOTMOUNTED = 10009, 1106 ST_MAINTMODE = 10010, 1107 ST_STALEACL = 10011, 1108 ST_BUS_RESET = 20001 1109 } AAC_FSAStatus; 1110 1111 /* 1112 * Volume manager commands 1113 */ 1114 typedef enum _VM_COMMANDS { 1115 VM_Null = 0, 1116 VM_NameServe, /* query for mountable objects (containers) */ 1117 VM_ContainerConfig, 1118 VM_Ioctl, 1119 VM_FilesystemIoctl, 1120 VM_CloseAll, 1121 VM_CtBlockRead, 1122 VM_CtBlockWrite, 1123 VM_SliceBlockRead, /* raw access to configured "storage objects" */ 1124 VM_SliceBlockWrite, 1125 VM_DriveBlockRead, /* raw access to physical devices */ 1126 VM_DriveBlockWrite, 1127 VM_EnclosureMgt, /* enclosure management */ 1128 VM_Unused, /* used to be diskset management */ 1129 VM_CtBlockVerify, 1130 VM_CtPerf, /* performance test */ 1131 VM_CtBlockRead64, 1132 VM_CtBlockWrite64, 1133 VM_CtBlockVerify64, 1134 VM_CtHostRead64, 1135 VM_CtHostWrite64, 1136 VM_DrvErrTblLog, /* drive error table/log type of command */ 1137 VM_NameServe64, /* query also for containers >2TB */ 1138 VM_SasNvsramAccess, /* for sas nvsram layout function */ 1139 VM_HandleExpiration, /* handles application expiration, internal use! */ 1140 VM_GetDynAdapProps, /* retrieves dynamic adapter properties */ 1141 VM_SetDynAdapProps, /* sets a dynamic adapter property */ 1142 VM_UpdateSSDODM, /* updates the on-disk metadata for SSD caching */ 1143 VM_GetSPMParameters, /* get SPM parameters for one of the perf. modes */ 1144 VM_SetSPMParameters, /* set SPM parameters for user defined perf. mode */ 1145 VM_NameServeAllBlk, /* query also for containers with 4KB sector size */ 1146 MAX_VMCOMMAND_NUM /* used for sizing stats array - leave last */ 1147 } AAC_VMCommand; 1148 1149 /* Container Configuration Sub-Commands */ 1150 #define CT_GET_SCSI_METHOD 64 1151 #define CT_PAUSE_IO 65 1152 #define CT_RELEASE_IO 66 1153 #define CT_GET_CONFIG_STATUS 147 1154 #define CT_COMMIT_CONFIG 152 1155 #define CT_CID_TO_32BITS_UID 165 1156 #define CT_PM_DRIVER_SUPPORT 245 1157 1158 /* General CT_xxx return status */ 1159 #define CT_OK 218 1160 1161 /* CT_PM_DRIVER_SUPPORT parameter */ 1162 typedef enum { 1163 AAC_PM_DRIVERSUP_GET_STATUS = 1, 1164 AAC_PM_DRIVERSUP_START_UNIT, 1165 AAC_PM_DRIVERSUP_STOP_UNIT 1166 } AAC_CT_PM_DRIVER_SUPPORT_SUB_COM; 1167 1168 /* 1169 * CT_PAUSE_IO is immediate minimal runtime command that is used 1170 * to restart the applications and cache. 1171 */ 1172 struct aac_pause_command { 1173 u_int32_t Command; 1174 u_int32_t Type; 1175 u_int32_t Timeout; 1176 u_int32_t Min; 1177 u_int32_t NoRescan; 1178 u_int32_t Parm3; 1179 u_int32_t Parm4; 1180 u_int32_t Count; 1181 } __packed; 1182 1183 /* Flag values for ContentState */ 1184 #define AAC_FSCS_NOTCLEAN 0x1 /* fscheck is necessary before mounting */ 1185 #define AAC_FSCS_READONLY 0x2 /* possible result of broken mirror */ 1186 #define AAC_FSCS_HIDDEN 0x4 /* container should be ignored by driver */ 1187 #define AAC_FSCS_NOT_READY 0x8 /* cnt is in spinn. state, not rdy for IO's */ 1188 1189 /* 1190 * "mountable object" 1191 */ 1192 struct aac_mntobj { 1193 u_int32_t ObjectId; 1194 char FileSystemName[16]; 1195 struct aac_container_creation CreateInfo; 1196 u_int32_t Capacity; 1197 u_int32_t VolType; 1198 u_int32_t ObjType; 1199 u_int32_t ContentState; 1200 union { 1201 u_int32_t pad[8]; 1202 struct { 1203 u_int32_t BlockSize; 1204 u_int32_t bdLgclPhysMap; 1205 } BlockDevice; 1206 } ObjExtension; 1207 u_int32_t AlterEgoId; 1208 u_int32_t CapacityHigh; 1209 } __packed; 1210 1211 struct aac_mntinfo { 1212 u_int32_t Command; 1213 u_int32_t MntType; 1214 u_int32_t MntCount; 1215 } __packed; 1216 1217 struct aac_mntinforesp { 1218 u_int32_t Status; 1219 u_int32_t MntType; 1220 u_int32_t MntRespCount; 1221 struct aac_mntobj MntTable[1]; 1222 } __packed; 1223 1224 /* 1225 * Container shutdown command. 1226 */ 1227 struct aac_closecommand { 1228 u_int32_t Command; 1229 u_int32_t ContainerId; 1230 } __packed; 1231 1232 /* 1233 * Container Config Command 1234 */ 1235 struct aac_ctcfg { 1236 u_int32_t Command; 1237 u_int32_t cmd; 1238 u_int32_t param; 1239 } __packed; 1240 1241 struct aac_ctcfg_resp { 1242 u_int32_t Status; 1243 u_int32_t resp; 1244 u_int32_t param; 1245 } __packed; 1246 1247 /* 1248 * 'Ioctl' commads 1249 */ 1250 #define AAC_SCSI_MAX_PORTS 10 1251 #define AAC_BUS_NO_EXIST 0 1252 #define AAC_BUS_VALID 1 1253 #define AAC_BUS_FAULTED 2 1254 #define AAC_BUS_DISABLED 3 1255 #define GetBusInfo 0x9 1256 1257 struct aac_getbusinf { 1258 u_int32_t ProbeComplete; 1259 u_int32_t BusCount; 1260 u_int32_t TargetsPerBus; 1261 u_int8_t InitiatorBusId[AAC_SCSI_MAX_PORTS]; 1262 u_int8_t BusValid[AAC_SCSI_MAX_PORTS]; 1263 } __packed; 1264 1265 struct aac_vmioctl { 1266 u_int32_t Command; 1267 u_int32_t ObjType; 1268 u_int32_t MethId; 1269 u_int32_t ObjId; 1270 u_int32_t IoctlCmd; 1271 u_int32_t IoctlBuf[1]; /* Placeholder? */ 1272 } __packed; 1273 1274 struct aac_vmi_businf_resp { 1275 u_int32_t Status; 1276 u_int32_t ObjType; 1277 u_int32_t MethId; 1278 u_int32_t ObjId; 1279 u_int32_t IoctlCmd; 1280 struct aac_getbusinf BusInf; 1281 } __packed; 1282 1283 struct aac_vmi_devinfo_resp { 1284 u_int32_t Status; 1285 u_int32_t ObjType; 1286 u_int32_t MethId; 1287 u_int32_t ObjId; 1288 u_int32_t IoctlCmd; 1289 u_int8_t VendorId[8]; 1290 u_int8_t ProductId[16]; 1291 u_int8_t ProductRev[4]; 1292 u_int32_t Inquiry7; 1293 u_int32_t align1; 1294 u_int32_t Inquiry0; 1295 u_int32_t align2; 1296 u_int32_t Inquiry1; 1297 u_int32_t align3; 1298 u_int32_t reserved[2]; 1299 u_int8_t VendorSpecific[20]; 1300 u_int32_t Smart:1; 1301 u_int32_t AAC_Managed:1; 1302 u_int32_t align4; 1303 u_int32_t reserved2:6; 1304 u_int32_t Bus; 1305 u_int32_t Target; 1306 u_int32_t Lun; 1307 u_int32_t ultraEnable:1, 1308 disconnectEnable:1, 1309 fast20EnabledW:1, 1310 scamDevice:1, 1311 scamTolerant:1, 1312 setForSync:1, 1313 setForWide:1, 1314 syncDevice:1, 1315 wideDevice:1, 1316 reserved1:7, 1317 ScsiRate:8, 1318 ScsiOffset:8; 1319 }; /* Do not pack */ 1320 1321 #define ResetBus 0x16 1322 struct aac_resetbus { 1323 u_int32_t BusNumber; 1324 }; 1325 1326 /* 1327 * Write 'stability' options. 1328 */ 1329 typedef enum { 1330 CSTABLE = 1, 1331 CUNSTABLE 1332 } AAC_CacheLevel; 1333 1334 /* 1335 * Commit level response for a write request. 1336 */ 1337 typedef enum { 1338 CMFILE_SYNC_NVRAM = 1, 1339 CMDATA_SYNC_NVRAM, 1340 CMFILE_SYNC, 1341 CMDATA_SYNC, 1342 CMUNSTABLE 1343 } AAC_CommitLevel; 1344 1345 #define CT_FIB_PARAMS 6 1346 #define MAX_FIB_PARAMS 10 1347 #define CT_PACKET_SIZE \ 1348 (AAC_FIB_DATASIZE - sizeof (u_int32_t) - \ 1349 ((sizeof (u_int32_t)) * (MAX_FIB_PARAMS + 1))) 1350 #define CNT_SIZE 5 1351 1352 struct aac_fsa_ctm { 1353 u_int32_t command; 1354 u_int32_t param[CT_FIB_PARAMS]; 1355 int8_t data[CT_PACKET_SIZE]; 1356 }; 1357 1358 struct aac_cnt_config { 1359 u_int32_t Command; 1360 struct aac_fsa_ctm CTCommand; 1361 }; 1362 1363 /* check config. */ 1364 enum { 1365 CFACT_CONTINUE = 0, /* continue without pause */ 1366 CFACT_PAUSE, /* pause, then continue */ 1367 CFACT_ABORT /* abort */ 1368 }; 1369 1370 struct aac_cf_status_hdr { 1371 u_int32_t action; 1372 u_int32_t flags; 1373 u_int32_t recordcount; 1374 }; 1375 1376 /* 1377 * Block read/write operations. 1378 * These structures are packed into the 'data' area in the FIB. 1379 */ 1380 1381 struct aac_blockread { 1382 u_int32_t Command; /* not FSACommand! */ 1383 u_int32_t ContainerId; 1384 u_int32_t BlockNumber; 1385 u_int32_t ByteCount; 1386 struct aac_sg_table SgMap; /* variable size */ 1387 } __packed; 1388 1389 struct aac_blockread64 { 1390 u_int32_t Command; 1391 u_int16_t ContainerId; 1392 u_int16_t SectorCount; 1393 u_int32_t BlockNumber; 1394 u_int16_t Pad; 1395 u_int16_t Flags; 1396 struct aac_sg_table64 SgMap64; 1397 } __packed; 1398 1399 struct aac_blockread_response { 1400 u_int32_t Status; 1401 u_int32_t ByteCount; 1402 } __packed; 1403 1404 struct aac_blockwrite { 1405 u_int32_t Command; /* not FSACommand! */ 1406 u_int32_t ContainerId; 1407 u_int32_t BlockNumber; 1408 u_int32_t ByteCount; 1409 u_int32_t Stable; 1410 struct aac_sg_table SgMap; /* variable size */ 1411 } __packed; 1412 1413 struct aac_blockwrite64 { 1414 u_int32_t Command; /* not FSACommand! */ 1415 u_int16_t ContainerId; 1416 u_int16_t SectorCount; 1417 u_int32_t BlockNumber; 1418 u_int16_t Pad; 1419 u_int16_t Flags; 1420 struct aac_sg_table64 SgMap64; /* variable size */ 1421 } __packed; 1422 1423 struct aac_blockwrite_response { 1424 u_int32_t Status; 1425 u_int32_t ByteCount; 1426 u_int32_t Committed; 1427 } __packed; 1428 1429 struct aac_raw_io { 1430 u_int64_t BlockNumber; 1431 u_int32_t ByteCount; 1432 u_int16_t ContainerId; 1433 u_int16_t Flags; /* 0: W, 1: R */ 1434 u_int16_t BpTotal; /* reserved for FW use */ 1435 u_int16_t BpComplete; /* reserved for FW use */ 1436 struct aac_sg_tableraw SgMapRaw; /* variable size */ 1437 } __packed; 1438 1439 #define RIO2_IO_TYPE 0x0003 1440 #define RIO2_IO_TYPE_WRITE 0x0000 1441 #define RIO2_IO_TYPE_READ 0x0001 1442 #define RIO2_IO_TYPE_VERIFY 0x0002 1443 #define RIO2_IO_ERROR 0x0004 1444 #define RIO2_IO_SUREWRITE 0x0008 1445 #define RIO2_SGL_CONFORMANT 0x0010 1446 #define RIO2_SG_FORMAT 0xF000 1447 #define RIO2_SG_FORMAT_ARC 0x0000 1448 #define RIO2_SG_FORMAT_SRL 0x1000 1449 #define RIO2_SG_FORMAT_IEEE1212 0x2000 1450 struct aac_raw_io2 { 1451 u_int32_t strtBlkLow; 1452 u_int32_t strtBlkHigh; 1453 u_int32_t byteCnt; 1454 u_int16_t ldNum; 1455 u_int16_t flags; /* RIO2_xxx */ 1456 u_int32_t sgeFirstSize; /* size of first SG element */ 1457 u_int32_t sgeNominalSize; /* size of 2nd SG element */ 1458 u_int8_t sgeCnt; 1459 u_int8_t bpTotal; /* reserved for FW use */ 1460 u_int8_t bpComplete; /* reserved for FW use */ 1461 u_int8_t sgeFirstIndex; /* reserved for FW use */ 1462 u_int8_t unused[4]; 1463 struct aac_sge_ieee1212 sge[0]; /* variable size */ 1464 } __packed; 1465 1466 /* 1467 * Container shutdown command. 1468 */ 1469 struct aac_close_command { 1470 u_int32_t Command; 1471 u_int32_t ContainerId; 1472 } __packed; 1473 1474 /* 1475 * SCSI Passthrough structures 1476 */ 1477 struct aac_srb { 1478 u_int32_t function; 1479 u_int32_t bus; 1480 u_int32_t target; 1481 u_int32_t lun; 1482 u_int32_t timeout; 1483 u_int32_t flags; 1484 u_int32_t data_len; 1485 u_int32_t retry_limit; 1486 u_int32_t cdb_len; 1487 u_int8_t cdb[16]; 1488 struct aac_sg_table sg_map; 1489 } __packed; 1490 1491 enum { 1492 AAC_SRB_FUNC_EXECUTE_SCSI = 0x00, 1493 AAC_SRB_FUNC_CLAIM_DEVICE, 1494 AAC_SRB_FUNC_IO_CONTROL, 1495 AAC_SRB_FUNC_RECEIVE_EVENT, 1496 AAC_SRB_FUNC_RELEASE_QUEUE, 1497 AAC_SRB_FUNC_ATTACH_DEVICE, 1498 AAC_SRB_FUNC_RELEASE_DEVICE, 1499 AAC_SRB_FUNC_SHUTDOWN, 1500 AAC_SRB_FUNC_FLUSH, 1501 AAC_SRB_FUNC_ABORT_COMMAND = 0x10, 1502 AAC_SRB_FUNC_RELEASE_RECOVERY, 1503 AAC_SRB_FUNC_RESET_BUS, 1504 AAC_SRB_FUNC_RESET_DEVICE, 1505 AAC_SRB_FUNC_TERMINATE_IO, 1506 AAC_SRB_FUNC_FLUSH_QUEUE, 1507 AAC_SRB_FUNC_REMOVE_DEVICE, 1508 AAC_SRB_FUNC_DOMAIN_VALIDATION 1509 }; 1510 1511 #define AAC_SRB_FLAGS_NO_DATA_XFER 0x0000 1512 #define AAC_SRB_FLAGS_DISABLE_DISCONNECT 0x0004 1513 #define AAC_SRB_FLAGS_DISABLE_SYNC_TRANSFER 0x0008 1514 #define AAC_SRB_FLAGS_BYPASS_FROZEN_QUEUE 0x0010 1515 #define AAC_SRB_FLAGS_DISABLE_AUTOSENSE 0x0020 1516 #define AAC_SRB_FLAGS_DATA_IN 0x0040 1517 #define AAC_SRB_FLAGS_DATA_OUT 0x0080 1518 #define AAC_SRB_FLAGS_UNSPECIFIED_DIRECTION \ 1519 (AAC_SRB_FLAGS_DATA_IN | AAC_SRB_FLAGS_DATA_OUT) 1520 1521 #define AAC_HOST_SENSE_DATA_MAX 30 1522 1523 struct aac_srb_response { 1524 u_int32_t fib_status; 1525 u_int32_t srb_status; 1526 u_int32_t scsi_status; 1527 u_int32_t data_len; 1528 u_int32_t sense_len; 1529 u_int8_t sense[AAC_HOST_SENSE_DATA_MAX]; 1530 } __packed; 1531 1532 /* 1533 * Status codes for SCSI passthrough commands. Since they are based on ASPI, 1534 * they also exactly match CAM status codes in both enumeration and meaning. 1535 * They seem to also be used as status codes for synchronous FIBs. 1536 */ 1537 enum { 1538 AAC_SRB_STS_PENDING = 0x00, 1539 AAC_SRB_STS_SUCCESS, 1540 AAC_SRB_STS_ABORTED, 1541 AAC_SRB_STS_ABORT_FAILED, 1542 AAC_SRB_STS_ERROR, 1543 AAC_SRB_STS_BUSY, 1544 AAC_SRB_STS_INVALID_REQUEST, 1545 AAC_SRB_STS_INVALID_PATH_ID, 1546 AAC_SRB_STS_NO_DEVICE, 1547 AAC_SRB_STS_TIMEOUT, 1548 AAC_SRB_STS_SELECTION_TIMEOUT, 1549 AAC_SRB_STS_COMMAND_TIMEOUT, 1550 AAC_SRB_STS_MESSAGE_REJECTED = 0x0D, 1551 AAC_SRB_STS_BUS_RESET, 1552 AAC_SRB_STS_PARITY_ERROR, 1553 AAC_SRB_STS_REQUEST_SENSE_FAILED, 1554 AAC_SRB_STS_NO_HBA, 1555 AAC_SRB_STS_DATA_OVERRUN, 1556 AAC_SRB_STS_UNEXPECTED_BUS_FREE, 1557 AAC_SRB_STS_PHASE_SEQUENCE_FAILURE, 1558 AAC_SRB_STS_BAD_SRB_BLOCK_LENGTH, 1559 AAC_SRB_STS_REQUEST_FLUSHED, 1560 AAC_SRB_STS_INVALID_LUN = 0x20, 1561 AAC_SRB_STS_INVALID_TARGET_ID, 1562 AAC_SRB_STS_BAD_FUNCTION, 1563 AAC_SRB_STS_ERROR_RECOVERY 1564 }; 1565 1566 /* 1567 * Register definitions for the Adaptec PMC SRC/SRCv adapters. 1568 */ 1569 /* accessible via BAR0 */ 1570 #define AAC_SRC_OMR 0xbc /* outbound message register */ 1571 #define AAC_SRC_IOAR 0x18 /* IOA->host interrupt register */ 1572 #define AAC_SRC_IDBR 0x20 /* inbound doorbell register */ 1573 #define AAC_SRC_IISR 0x24 /* inbound interrupt status register */ 1574 #define AAC_SRC_ODBR_R 0x9c /* outbound doorbell register read */ 1575 #define AAC_SRC_ODBR_C 0xa0 /* outbound doorbell register clear */ 1576 #define AAC_SRC_OIMR 0x34 /* outbound interrupt mask register */ 1577 #define AAC_SRC_IQUE32 0x40 /* inbound queue address 32-bit */ 1578 #define AAC_SRC_IQUE64_L 0xc0 /* inbound queue address 64-bit (low) */ 1579 #define AAC_SRC_IQUE64_H 0xc4 /* inbound queue address 64-bit (high)*/ 1580 #define AAC_SRC_ODBR_MSI 0xc8 /* MSI register for sync./AIF */ 1581 1582 #define AAC_SRC_MAILBOX 0x7fc60 /* mailbox (20 bytes) */ 1583 #define AAC_SRCV_MAILBOX 0x1000 /* mailbox (20 bytes) */ 1584 1585 #define AAC_SRC_ODR_SHIFT 12 /* outbound doorbell shift */ 1586 #define AAC_SRC_IDR_SHIFT 9 /* inbound doorbell shift */ 1587 1588 /* Sunrise Lake dual core reset */ 1589 #define AAC_IRCSR 0x38 /* inbound dual cores reset */ 1590 #define AAC_IRCSR_CORES_RST 3 1591 1592 /* 1593 * Common bit definitions for the doorbell registers. 1594 */ 1595 1596 /* 1597 * Status bits in the doorbell registers. 1598 */ 1599 #define AAC_DB_SYNC_COMMAND (1<<0) /* send/completed synchronous FIB */ 1600 #define AAC_DB_AIF_PENDING (1<<6) /* pending AIF (new comm. type1) */ 1601 /* PMC specific outbound doorbell bits */ 1602 #define AAC_DB_RESPONSE_SENT_NS (1<<1) /* response sent (not shifted)*/ 1603 1604 /* 1605 * The adapter can request the host print a message by setting the 1606 * DB_PRINTF flag in DOORBELL0. The driver responds by collecting the 1607 * message from the printf buffer, clearing the DB_PRINTF flag in 1608 * DOORBELL0 and setting it in DOORBELL1. 1609 * (ODBR and IDBR respectively for the i960Rx adapters) 1610 */ 1611 #define AAC_DB_PRINTF (1<<5) /* adapter requests host printf */ 1612 #define AAC_PRINTF_DONE (1<<5) /* Host completed printf processing */ 1613 1614 /* 1615 * Interrupts 1616 */ 1617 #define AAC_MAX_MSIX 32 /* vectors */ 1618 #define AAC_PCI_MSI_ENABLE 0x8000 1619 #define AAC_MSI_SYNC_STATUS 0x1000 1620 1621 enum { 1622 AAC_ENABLE_INTERRUPT = 0x0, 1623 AAC_DISABLE_INTERRUPT, 1624 AAC_ENABLE_MSIX, 1625 AAC_DISABLE_MSIX, 1626 AAC_CLEAR_AIF_BIT, 1627 AAC_CLEAR_SYNC_BIT, 1628 AAC_ENABLE_INTX 1629 }; 1630 1631 #define AAC_INT_MODE_INTX (1<<0) 1632 #define AAC_INT_MODE_MSI (1<<1) 1633 #define AAC_INT_MODE_AIF (1<<2) 1634 #define AAC_INT_MODE_SYNC (1<<3) 1635 1636 #define AAC_INT_ENABLE_TYPE1_INTX 0xfffffffb 1637 #define AAC_INT_ENABLE_TYPE1_MSIX 0xfffffffa 1638 #define AAC_INT_DISABLE_ALL 0xffffffff 1639 1640 /* Bit definitions in IOA->Host Interrupt Register */ 1641 #define PMC_TRANSITION_TO_OPERATIONAL (0x80000000 >> 0) 1642 #define PMC_IOARCB_TRANSFER_FAILED (0x80000000 >> 3) 1643 #define PMC_IOA_UNIT_CHECK (0x80000000 >> 4) 1644 #define PMC_NO_HOST_RRQ_FOR_CMD_RESPONSE (0x80000000 >> 5) 1645 #define PMC_CRITICAL_IOA_OP_IN_PROGRESS (0x80000000 >> 6) 1646 #define PMC_IOARRIN_LOST (0x80000000 >> 27) 1647 #define PMC_SYSTEM_BUS_MMIO_ERROR (0x80000000 >> 28) 1648 #define PMC_IOA_PROCESSOR_IN_ERROR_STATE (0x80000000 >> 29) 1649 #define PMC_HOST_RRQ_VALID (0x80000000 >> 30) 1650 #define PMC_OPERATIONAL_STATUS (0x80000000 >> 0) 1651 #define PMC_ALLOW_MSIX_VECTOR0 (0x80000000 >> 31) 1652 1653 #define PMC_IOA_ERROR_INTERRUPTS (PMC_IOARCB_TRANSFER_FAILED | \ 1654 PMC_IOA_UNIT_CHECK | \ 1655 PMC_NO_HOST_RRQ_FOR_CMD_RESPONSE | \ 1656 PMC_IOARRIN_LOST | \ 1657 PMC_SYSTEM_BUS_MMIO_ERROR | \ 1658 PMC_IOA_PROCESSOR_IN_ERROR_STATE) 1659 1660 #define PMC_ALL_INTERRUPT_BITS (PMC_IOA_ERROR_INTERRUPTS | \ 1661 PMC_HOST_RRQ_VALID | \ 1662 PMC_TRANSITION_TO_OPERATIONAL | \ 1663 PMC_ALLOW_MSIX_VECTOR0) 1664 1665 #define PMC_GLOBAL_INT_BIT2 0x00000004 1666 #define PMC_GLOBAL_INT_BIT0 0x00000001 1667