root/drivers/scsi/mpt3sas/mpi/mpi2_tool.h
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Copyright 2000-2020 Broadcom Inc. All rights reserved.
 *
 *
 *          Name:  mpi2_tool.h
 *         Title:  MPI diagnostic tool structures and definitions
 * Creation Date:  March 26, 2007
 *
 *   mpi2_tool.h Version:  02.00.16
 *
 * Version History
 * ---------------
 *
 * Date      Version   Description
 * --------  --------  ------------------------------------------------------
 * 04-30-07  02.00.00  Corresponds to Fusion-MPT MPI Specification Rev A.
 * 12-18-07  02.00.01  Added Diagnostic Buffer Post and Diagnostic Release
 *                     structures and defines.
 * 02-29-08  02.00.02  Modified various names to make them 32-character unique.
 * 05-06-09  02.00.03  Added ISTWI Read Write Tool and Diagnostic CLI Tool.
 * 07-30-09  02.00.04  Added ExtendedType field to DiagnosticBufferPost request
 *                     and reply messages.
 *                     Added MPI2_DIAG_BUF_TYPE_EXTENDED.
 *                     Incremented MPI2_DIAG_BUF_TYPE_COUNT.
 * 05-12-10  02.00.05  Added Diagnostic Data Upload tool.
 * 08-11-10  02.00.06  Added defines that were missing for Diagnostic Buffer
 *                     Post Request.
 * 05-25-11  02.00.07  Added Flags field and related defines to
 *                     MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST.
 * 11-18-11  02.00.08  Incorporating additions for MPI v2.5.
 * 07-10-12  02.00.09  Add MPI v2.5 Toolbox Diagnostic CLI Tool Request
 *                     message.
 * 07-26-12  02.00.10  Modified MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST so that
 *                     it uses MPI Chain SGE as well as MPI Simple SGE.
 * 08-19-13  02.00.11  Added MPI2_TOOLBOX_TEXT_DISPLAY_TOOL and related info.
 * 01-08-14  02.00.12  Added MPI2_TOOLBOX_CLEAN_BIT26_PRODUCT_SPECIFIC.
 * 11-18-14  02.00.13  Updated copyright information.
 * 08-25-16  02.00.14  Added new values for the Flags field of Toolbox Clean
 *                     Tool Request Message.
 * 07-22-18  02.00.15  Added defines for new TOOLBOX_PCIE_LANE_MARGINING tool.
 *                     Added option for DeviceInfo field in ISTWI tool.
 * 12-17-18  02.00.16  Shorten some defines to be compatible with DOS.
 * --------------------------------------------------------------------------
 */

#ifndef MPI2_TOOL_H
#define MPI2_TOOL_H

/*****************************************************************************
*
*              Toolbox Messages
*
*****************************************************************************/

/*defines for the Tools */
#define MPI2_TOOLBOX_CLEAN_TOOL                     (0x00)
#define MPI2_TOOLBOX_MEMORY_MOVE_TOOL               (0x01)
#define MPI2_TOOLBOX_DIAG_DATA_UPLOAD_TOOL          (0x02)
#define MPI2_TOOLBOX_ISTWI_READ_WRITE_TOOL          (0x03)
#define MPI2_TOOLBOX_BEACON_TOOL                    (0x05)
#define MPI2_TOOLBOX_DIAGNOSTIC_CLI_TOOL            (0x06)
#define MPI2_TOOLBOX_TEXT_DISPLAY_TOOL              (0x07)
#define MPI26_TOOLBOX_BACKEND_PCIE_LANE_MARGIN      (0x08)

/****************************************************************************
* Toolbox reply
****************************************************************************/

typedef struct _MPI2_TOOLBOX_REPLY {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 MsgLength;           /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U16 Reserved5;          /*0x0C */
        U16 IOCStatus;          /*0x0E */
        U32 IOCLogInfo;         /*0x10 */
} MPI2_TOOLBOX_REPLY, *PTR_MPI2_TOOLBOX_REPLY,
        Mpi2ToolboxReply_t, *pMpi2ToolboxReply_t;

/****************************************************************************
* Toolbox Clean Tool request
****************************************************************************/

typedef struct _MPI2_TOOLBOX_CLEAN_REQUEST {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U32 Flags;              /*0x0C */
} MPI2_TOOLBOX_CLEAN_REQUEST, *PTR_MPI2_TOOLBOX_CLEAN_REQUEST,
        Mpi2ToolboxCleanRequest_t, *pMpi2ToolboxCleanRequest_t;

/*values for the Flags field */
#define MPI2_TOOLBOX_CLEAN_BOOT_SERVICES            (0x80000000)
#define MPI2_TOOLBOX_CLEAN_PERSIST_MANUFACT_PAGES   (0x40000000)
#define MPI2_TOOLBOX_CLEAN_OTHER_PERSIST_PAGES      (0x20000000)
#define MPI2_TOOLBOX_CLEAN_FW_CURRENT               (0x10000000)
#define MPI2_TOOLBOX_CLEAN_FW_BACKUP                (0x08000000)
#define MPI2_TOOLBOX_CLEAN_BIT26_PRODUCT_SPECIFIC   (0x04000000)
#define MPI2_TOOLBOX_CLEAN_MEGARAID                 (0x02000000)
#define MPI2_TOOLBOX_CLEAN_INITIALIZATION           (0x01000000)
#define MPI2_TOOLBOX_CLEAN_SBR                      (0x00800000)
#define MPI2_TOOLBOX_CLEAN_SBR_BACKUP               (0x00400000)
#define MPI2_TOOLBOX_CLEAN_HIIM                     (0x00200000)
#define MPI2_TOOLBOX_CLEAN_HIIA                     (0x00100000)
#define MPI2_TOOLBOX_CLEAN_CTLR                     (0x00080000)
#define MPI2_TOOLBOX_CLEAN_IMR_FIRMWARE             (0x00040000)
#define MPI2_TOOLBOX_CLEAN_MR_NVDATA                (0x00020000)
#define MPI2_TOOLBOX_CLEAN_RESERVED_5_16            (0x0001FFE0)
#define MPI2_TOOLBOX_CLEAN_ALL_BUT_MPB              (0x00000010)
#define MPI2_TOOLBOX_CLEAN_ENTIRE_FLASH             (0x00000008)
#define MPI2_TOOLBOX_CLEAN_FLASH                    (0x00000004)
#define MPI2_TOOLBOX_CLEAN_SEEPROM                  (0x00000002)
#define MPI2_TOOLBOX_CLEAN_NVSRAM                   (0x00000001)

/****************************************************************************
* Toolbox Memory Move request
****************************************************************************/

typedef struct _MPI2_TOOLBOX_MEM_MOVE_REQUEST {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        MPI2_SGE_SIMPLE_UNION SGL;      /*0x0C */
} MPI2_TOOLBOX_MEM_MOVE_REQUEST, *PTR_MPI2_TOOLBOX_MEM_MOVE_REQUEST,
        Mpi2ToolboxMemMoveRequest_t, *pMpi2ToolboxMemMoveRequest_t;

/****************************************************************************
* Toolbox Diagnostic Data Upload request
****************************************************************************/

typedef struct _MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U8 SGLFlags;            /*0x0C */
        U8 Reserved5;           /*0x0D */
        U16 Reserved6;          /*0x0E */
        U32 Flags;              /*0x10 */
        U32 DataLength;         /*0x14 */
        MPI2_SGE_SIMPLE_UNION SGL;      /*0x18 */
} MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST,
        *PTR_MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST,
        Mpi2ToolboxDiagDataUploadRequest_t,
        *pMpi2ToolboxDiagDataUploadRequest_t;

/*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */

typedef struct _MPI2_DIAG_DATA_UPLOAD_HEADER {
        U32 DiagDataLength;     /*00h */
        U8 FormatCode;          /*04h */
        U8 Reserved1;           /*05h */
        U16 Reserved2;          /*06h */
} MPI2_DIAG_DATA_UPLOAD_HEADER, *PTR_MPI2_DIAG_DATA_UPLOAD_HEADER,
        Mpi2DiagDataUploadHeader_t, *pMpi2DiagDataUploadHeader_t;

/****************************************************************************
* Toolbox ISTWI Read Write Tool
****************************************************************************/

/*Toolbox ISTWI Read Write Tool request message */
typedef struct _MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U32 Reserved5;          /*0x0C */
        U32 Reserved6;          /*0x10 */
        U8 DevIndex;            /*0x14 */
        U8 Action;              /*0x15 */
        U8 SGLFlags;            /*0x16 */
        U8 Flags;               /*0x17 */
        U16 TxDataLength;       /*0x18 */
        U16 RxDataLength;       /*0x1A */
        U32 Reserved8;          /*0x1C */
        U32 Reserved9;          /*0x20 */
        U32 Reserved10;         /*0x24 */
        U32 Reserved11;         /*0x28 */
        U32 Reserved12;         /*0x2C */
        MPI2_SGE_SIMPLE_UNION SGL;      /*0x30 */
} MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST,
        *PTR_MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST,
        Mpi2ToolboxIstwiReadWriteRequest_t,
        *pMpi2ToolboxIstwiReadWriteRequest_t;

/*values for the Action field */
#define MPI2_TOOL_ISTWI_ACTION_READ_DATA            (0x01)
#define MPI2_TOOL_ISTWI_ACTION_WRITE_DATA           (0x02)
#define MPI2_TOOL_ISTWI_ACTION_SEQUENCE             (0x03)
#define MPI2_TOOL_ISTWI_ACTION_RESERVE_BUS          (0x10)
#define MPI2_TOOL_ISTWI_ACTION_RELEASE_BUS          (0x11)
#define MPI2_TOOL_ISTWI_ACTION_RESET                (0x12)

/*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */

/*values for the Flags field */
#define MPI2_TOOL_ISTWI_FLAG_AUTO_RESERVE_RELEASE   (0x80)
#define MPI2_TOOL_ISTWI_FLAG_PAGE_ADDR_MASK         (0x07)

/*MPI26 TOOLBOX Request MsgFlags defines */
#define MPI26_TOOL_ISTWI_MSGFLG_ADDR_MASK           (0x01)
/*Request uses Man Page 43 device index addressing */
#define MPI26_TOOL_ISTWI_MSGFLG_ADDR_INDEX          (0x00)
/*Request uses Man Page 43 device info struct addressing */
#define MPI26_TOOL_ISTWI_MSGFLG_ADDR_INFO           (0x01)

/*Toolbox ISTWI Read Write Tool reply message */
typedef struct _MPI2_TOOLBOX_ISTWI_REPLY {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 MsgLength;           /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U16 Reserved5;          /*0x0C */
        U16 IOCStatus;          /*0x0E */
        U32 IOCLogInfo;         /*0x10 */
        U8 DevIndex;            /*0x14 */
        U8 Action;              /*0x15 */
        U8 IstwiStatus;         /*0x16 */
        U8 Reserved6;           /*0x17 */
        U16 TxDataCount;        /*0x18 */
        U16 RxDataCount;        /*0x1A */
} MPI2_TOOLBOX_ISTWI_REPLY, *PTR_MPI2_TOOLBOX_ISTWI_REPLY,
        Mpi2ToolboxIstwiReply_t, *pMpi2ToolboxIstwiReply_t;

/****************************************************************************
* Toolbox Beacon Tool request
****************************************************************************/

typedef struct _MPI2_TOOLBOX_BEACON_REQUEST {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U8 Reserved5;           /*0x0C */
        U8 PhysicalPort;        /*0x0D */
        U8 Reserved6;           /*0x0E */
        U8 Flags;               /*0x0F */
} MPI2_TOOLBOX_BEACON_REQUEST, *PTR_MPI2_TOOLBOX_BEACON_REQUEST,
        Mpi2ToolboxBeaconRequest_t, *pMpi2ToolboxBeaconRequest_t;

/*values for the Flags field */
#define MPI2_TOOLBOX_FLAGS_BEACONMODE_OFF       (0x00)
#define MPI2_TOOLBOX_FLAGS_BEACONMODE_ON        (0x01)

/****************************************************************************
* Toolbox Diagnostic CLI Tool
****************************************************************************/

#define MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH    (0x5C)

/*MPI v2.0 Toolbox Diagnostic CLI Tool request message */
typedef struct _MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U8 SGLFlags;            /*0x0C */
        U8 Reserved5;           /*0x0D */
        U16 Reserved6;          /*0x0E */
        U32 DataLength;         /*0x10 */
        U8 DiagnosticCliCommand[MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH];/*0x14 */
        MPI2_MPI_SGE_IO_UNION SGL;      /*0x70 */
} MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
        *PTR_MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
        Mpi2ToolboxDiagnosticCliRequest_t,
        *pMpi2ToolboxDiagnosticCliRequest_t;

/*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */

/*MPI v2.5 Toolbox Diagnostic CLI Tool request message */
typedef struct _MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U32 Reserved5;          /*0x0C */
        U32 DataLength;         /*0x10 */
        U8 DiagnosticCliCommand[MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH];/*0x14 */
        MPI25_SGE_IO_UNION      SGL;                        /* 0x70 */
} MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
        *PTR_MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
        Mpi25ToolboxDiagnosticCliRequest_t,
        *pMpi25ToolboxDiagnosticCliRequest_t;

/*Toolbox Diagnostic CLI Tool reply message */
typedef struct _MPI2_TOOLBOX_DIAGNOSTIC_CLI_REPLY {
        U8 Tool;                /*0x00 */
        U8 Reserved1;           /*0x01 */
        U8 MsgLength;           /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U16 Reserved5;          /*0x0C */
        U16 IOCStatus;          /*0x0E */
        U32 IOCLogInfo;         /*0x10 */
        U32 ReturnedDataLength; /*0x14 */
} MPI2_TOOLBOX_DIAGNOSTIC_CLI_REPLY,
        *PTR_MPI2_TOOLBOX_DIAG_CLI_REPLY,
        Mpi2ToolboxDiagnosticCliReply_t,
        *pMpi2ToolboxDiagnosticCliReply_t;


/****************************************************************************
*  Toolbox Console Text Display Tool
****************************************************************************/

/* Toolbox Console Text Display Tool request message */
typedef struct _MPI2_TOOLBOX_TEXT_DISPLAY_REQUEST {
        U8                      Tool;                   /* 0x00 */
        U8                      Reserved1;              /* 0x01 */
        U8                      ChainOffset;            /* 0x02 */
        U8                      Function;               /* 0x03 */
        U16                     Reserved2;              /* 0x04 */
        U8                      Reserved3;              /* 0x06 */
        U8                      MsgFlags;               /* 0x07 */
        U8                      VP_ID;                  /* 0x08 */
        U8                      VF_ID;                  /* 0x09 */
        U16                     Reserved4;              /* 0x0A */
        U8                      Console;                /* 0x0C */
        U8                      Flags;                  /* 0x0D */
        U16                     Reserved6;              /* 0x0E */
        U8                      TextToDisplay[4];       /* 0x10 */
} MPI2_TOOLBOX_TEXT_DISPLAY_REQUEST,
*PTR_MPI2_TOOLBOX_TEXT_DISPLAY_REQUEST,
Mpi2ToolboxTextDisplayRequest_t,
*pMpi2ToolboxTextDisplayRequest_t;

/* defines for the Console field */
#define MPI2_TOOLBOX_CONSOLE_TYPE_MASK          (0xF0)
#define MPI2_TOOLBOX_CONSOLE_TYPE_DEFAULT       (0x00)
#define MPI2_TOOLBOX_CONSOLE_TYPE_UART          (0x10)
#define MPI2_TOOLBOX_CONSOLE_TYPE_ETHERNET      (0x20)

#define MPI2_TOOLBOX_CONSOLE_NUMBER_MASK        (0x0F)

/* defines for the Flags field */
#define MPI2_TOOLBOX_CONSOLE_FLAG_TIMESTAMP     (0x01)


/***************************************************************************
 *  Toolbox Backend Lane Margining Tool
 ***************************************************************************
 */

/*Toolbox Backend Lane Margining Tool request message */
typedef struct _MPI26_TOOLBOX_LANE_MARGIN_REQUEST {
        U8 Tool;                        /*0x00 */
        U8 Reserved1;                   /*0x01 */
        U8 ChainOffset;                 /*0x02 */
        U8 Function;                    /*0x03 */
        U16 Reserved2;                  /*0x04 */
        U8 Reserved3;                   /*0x06 */
        U8 MsgFlags;                    /*0x07 */
        U8 VP_ID;                       /*0x08 */
        U8 VF_ID;                       /*0x09 */
        U16 Reserved4;                  /*0x0A */
        U8 Command;                     /*0x0C */
        U8 SwitchPort;                  /*0x0D */
        U16 DevHandle;                  /*0x0E */
        U8 RegisterOffset;              /*0x10 */
        U8 Reserved5;                   /*0x11 */
        U16 DataLength;                 /*0x12 */
        MPI25_SGE_IO_UNION SGL;         /*0x14 */
} MPI26_TOOLBOX_LANE_MARGINING_REQUEST,
        *PTR_MPI2_TOOLBOX_LANE_MARGINING_REQUEST,
        Mpi26ToolboxLaneMarginingRequest_t,
        *pMpi2ToolboxLaneMarginingRequest_t;

/* defines for the Command field */
#define MPI26_TOOL_MARGIN_COMMAND_ENTER_MARGIN_MODE        (0x01)
#define MPI26_TOOL_MARGIN_COMMAND_READ_REGISTER_DATA       (0x02)
#define MPI26_TOOL_MARGIN_COMMAND_WRITE_REGISTER_DATA      (0x03)
#define MPI26_TOOL_MARGIN_COMMAND_EXIT_MARGIN_MODE         (0x04)


/*Toolbox Backend Lane Margining Tool reply message */
typedef struct _MPI26_TOOLBOX_LANE_MARGIN_REPLY {
        U8 Tool;                        /*0x00 */
        U8 Reserved1;                   /*0x01 */
        U8 MsgLength;                   /*0x02 */
        U8 Function;                    /*0x03 */
        U16 Reserved2;                  /*0x04 */
        U8 Reserved3;                   /*0x06 */
        U8 MsgFlags;                    /*0x07 */
        U8 VP_ID;                       /*0x08 */
        U8 VF_ID;                       /*0x09 */
        U16 Reserved4;                  /*0x0A */
        U16 Reserved5;                  /*0x0C */
        U16 IOCStatus;                  /*0x0E */
        U32 IOCLogInfo;                 /*0x10 */
        U16 ReturnedDataLength;         /*0x14 */
        U16 Reserved6;                  /*0x16 */
} MPI26_TOOLBOX_LANE_MARGINING_REPLY,
        *PTR_MPI26_TOOLBOX_LANE_MARGINING_REPLY,
        Mpi26ToolboxLaneMarginingReply_t,
        *pMpi26ToolboxLaneMarginingReply_t;


/*****************************************************************************
*
*      Diagnostic Buffer Messages
*
*****************************************************************************/

/****************************************************************************
* Diagnostic Buffer Post request
****************************************************************************/

typedef struct _MPI2_DIAG_BUFFER_POST_REQUEST {
        U8 ExtendedType;        /*0x00 */
        U8 BufferType;          /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U64 BufferAddress;      /*0x0C */
        U32 BufferLength;       /*0x14 */
        U32 Reserved5;          /*0x18 */
        U32 Reserved6;          /*0x1C */
        U32 Flags;              /*0x20 */
        U32 ProductSpecific[23];        /*0x24 */
} MPI2_DIAG_BUFFER_POST_REQUEST, *PTR_MPI2_DIAG_BUFFER_POST_REQUEST,
        Mpi2DiagBufferPostRequest_t, *pMpi2DiagBufferPostRequest_t;

/*values for the ExtendedType field */
#define MPI2_DIAG_EXTENDED_TYPE_UTILIZATION         (0x02)

/*values for the BufferType field */
#define MPI2_DIAG_BUF_TYPE_TRACE                    (0x00)
#define MPI2_DIAG_BUF_TYPE_SNAPSHOT                 (0x01)
#define MPI2_DIAG_BUF_TYPE_EXTENDED                 (0x02)
/*count of the number of buffer types */
#define MPI2_DIAG_BUF_TYPE_COUNT                    (0x03)

/*values for the Flags field */
#define MPI2_DIAG_BUF_FLAG_RELEASE_ON_FULL          (0x00000002)
#define MPI2_DIAG_BUF_FLAG_IMMEDIATE_RELEASE        (0x00000001)

/****************************************************************************
* Diagnostic Buffer Post reply
****************************************************************************/

typedef struct _MPI2_DIAG_BUFFER_POST_REPLY {
        U8 ExtendedType;        /*0x00 */
        U8 BufferType;          /*0x01 */
        U8 MsgLength;           /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U16 Reserved5;          /*0x0C */
        U16 IOCStatus;          /*0x0E */
        U32 IOCLogInfo;         /*0x10 */
        U32 TransferLength;     /*0x14 */
} MPI2_DIAG_BUFFER_POST_REPLY, *PTR_MPI2_DIAG_BUFFER_POST_REPLY,
        Mpi2DiagBufferPostReply_t, *pMpi2DiagBufferPostReply_t;

/****************************************************************************
* Diagnostic Release request
****************************************************************************/

typedef struct _MPI2_DIAG_RELEASE_REQUEST {
        U8 Reserved1;           /*0x00 */
        U8 BufferType;          /*0x01 */
        U8 ChainOffset;         /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
} MPI2_DIAG_RELEASE_REQUEST, *PTR_MPI2_DIAG_RELEASE_REQUEST,
        Mpi2DiagReleaseRequest_t, *pMpi2DiagReleaseRequest_t;

/****************************************************************************
* Diagnostic Buffer Post reply
****************************************************************************/

typedef struct _MPI2_DIAG_RELEASE_REPLY {
        U8 Reserved1;           /*0x00 */
        U8 BufferType;          /*0x01 */
        U8 MsgLength;           /*0x02 */
        U8 Function;            /*0x03 */
        U16 Reserved2;          /*0x04 */
        U8 Reserved3;           /*0x06 */
        U8 MsgFlags;            /*0x07 */
        U8 VP_ID;               /*0x08 */
        U8 VF_ID;               /*0x09 */
        U16 Reserved4;          /*0x0A */
        U16 Reserved5;          /*0x0C */
        U16 IOCStatus;          /*0x0E */
        U32 IOCLogInfo;         /*0x10 */
} MPI2_DIAG_RELEASE_REPLY, *PTR_MPI2_DIAG_RELEASE_REPLY,
        Mpi2DiagReleaseReply_t, *pMpi2DiagReleaseReply_t;

#endif