| 
     1 /*-
    2  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
    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
Cache object: a9993814cba574537153205622dfa663 
 
 |