]> git.proxmox.com Git - mirror_edk2.git/blobdiff - MdePkg/Include/IndustryStandard/Scsi.h
MdePkg: Apply uncrustify changes
[mirror_edk2.git] / MdePkg / Include / IndustryStandard / Scsi.h
index 64b9918b82a01d5f5667fb68dc65358ca1d07510..be8adca8fc5a664cb1e830d12846a61924e54944 100644 (file)
 //\r
 // Commands for all device types\r
 //\r
-#define EFI_SCSI_OP_CHANGE_DEFINITION 0x40\r
-#define EFI_SCSI_OP_COMPARE           0x39\r
-#define EFI_SCSI_OP_COPY              0x18\r
-#define EFI_SCSI_OP_COPY_VERIFY       0x3a\r
-#define EFI_SCSI_OP_INQUIRY           0x12\r
-#define EFI_SCSI_OP_LOG_SELECT        0x4c\r
-#define EFI_SCSI_OP_LOG_SENSE         0x4d\r
-#define EFI_SCSI_OP_MODE_SEL6         0x15\r
-#define EFI_SCSI_OP_MODE_SEL10        0x55\r
-#define EFI_SCSI_OP_MODE_SEN6         0x1a\r
-#define EFI_SCSI_OP_MODE_SEN10        0x5a\r
-#define EFI_SCSI_OP_READ_BUFFER       0x3c\r
-#define EFI_SCSI_OP_RECEIVE_DIAG      0x1c\r
-#define EFI_SCSI_OP_REQUEST_SENSE     0x03\r
-#define EFI_SCSI_OP_SEND_DIAG         0x1d\r
-#define EFI_SCSI_OP_TEST_UNIT_READY   0x00\r
-#define EFI_SCSI_OP_WRITE_BUFF        0x3b\r
+#define EFI_SCSI_OP_CHANGE_DEFINITION  0x40\r
+#define EFI_SCSI_OP_COMPARE            0x39\r
+#define EFI_SCSI_OP_COPY               0x18\r
+#define EFI_SCSI_OP_COPY_VERIFY        0x3a\r
+#define EFI_SCSI_OP_INQUIRY            0x12\r
+#define EFI_SCSI_OP_LOG_SELECT         0x4c\r
+#define EFI_SCSI_OP_LOG_SENSE          0x4d\r
+#define EFI_SCSI_OP_MODE_SEL6          0x15\r
+#define EFI_SCSI_OP_MODE_SEL10         0x55\r
+#define EFI_SCSI_OP_MODE_SEN6          0x1a\r
+#define EFI_SCSI_OP_MODE_SEN10         0x5a\r
+#define EFI_SCSI_OP_READ_BUFFER        0x3c\r
+#define EFI_SCSI_OP_RECEIVE_DIAG       0x1c\r
+#define EFI_SCSI_OP_REQUEST_SENSE      0x03\r
+#define EFI_SCSI_OP_SEND_DIAG          0x1d\r
+#define EFI_SCSI_OP_TEST_UNIT_READY    0x00\r
+#define EFI_SCSI_OP_WRITE_BUFF         0x3b\r
 \r
 //\r
 // Additional commands for Direct Access Devices\r
 //\r
-#define EFI_SCSI_OP_FORMAT          0x04\r
-#define EFI_SCSI_OP_LOCK_UN_CACHE   0x36\r
-#define EFI_SCSI_OP_PREFETCH        0x34\r
-#define EFI_SCSI_OP_MEDIA_REMOVAL   0x1e\r
-#define EFI_SCSI_OP_READ6           0x08\r
-#define EFI_SCSI_OP_READ10          0x28\r
-#define EFI_SCSI_OP_READ16          0x88\r
-#define EFI_SCSI_OP_READ_CAPACITY   0x25\r
-#define EFI_SCSI_OP_READ_CAPACITY16 0x9e\r
-#define EFI_SCSI_OP_READ_DEFECT     0x37\r
-#define EFI_SCSI_OP_READ_LONG       0x3e\r
-#define EFI_SCSI_OP_REASSIGN_BLK    0x07\r
-#define EFI_SCSI_OP_RELEASE         0x17\r
-#define EFI_SCSI_OP_REZERO          0x01\r
-#define EFI_SCSI_OP_SEARCH_DATA_E   0x31\r
-#define EFI_SCSI_OP_SEARCH_DATA_H   0x30\r
-#define EFI_SCSI_OP_SEARCH_DATA_L   0x32\r
-#define EFI_SCSI_OP_SEEK6           0x0b\r
-#define EFI_SCSI_OP_SEEK10          0x2b\r
-#define EFI_SCSI_OP_SEND_DIAG       0x1d\r
-#define EFI_SCSI_OP_SET_LIMIT       0x33\r
-#define EFI_SCSI_OP_START_STOP_UNIT 0x1b\r
-#define EFI_SCSI_OP_SYNC_CACHE      0x35\r
-#define EFI_SCSI_OP_VERIFY          0x2f\r
-#define EFI_SCSI_OP_WRITE6          0x0a\r
-#define EFI_SCSI_OP_WRITE10         0x2a\r
-#define EFI_SCSI_OP_WRITE16         0x8a\r
-#define EFI_SCSI_OP_WRITE_VERIFY    0x2e\r
-#define EFI_SCSI_OP_WRITE_LONG      0x3f\r
-#define EFI_SCSI_OP_WRITE_SAME      0x41\r
-#define EFI_SCSI_OP_UNMAP           0x42\r
+#define EFI_SCSI_OP_FORMAT           0x04\r
+#define EFI_SCSI_OP_LOCK_UN_CACHE    0x36\r
+#define EFI_SCSI_OP_PREFETCH         0x34\r
+#define EFI_SCSI_OP_MEDIA_REMOVAL    0x1e\r
+#define EFI_SCSI_OP_READ6            0x08\r
+#define EFI_SCSI_OP_READ10           0x28\r
+#define EFI_SCSI_OP_READ16           0x88\r
+#define EFI_SCSI_OP_READ_CAPACITY    0x25\r
+#define EFI_SCSI_OP_READ_CAPACITY16  0x9e\r
+#define EFI_SCSI_OP_READ_DEFECT      0x37\r
+#define EFI_SCSI_OP_READ_LONG        0x3e\r
+#define EFI_SCSI_OP_REASSIGN_BLK     0x07\r
+#define EFI_SCSI_OP_RELEASE          0x17\r
+#define EFI_SCSI_OP_REZERO           0x01\r
+#define EFI_SCSI_OP_SEARCH_DATA_E    0x31\r
+#define EFI_SCSI_OP_SEARCH_DATA_H    0x30\r
+#define EFI_SCSI_OP_SEARCH_DATA_L    0x32\r
+#define EFI_SCSI_OP_SEEK6            0x0b\r
+#define EFI_SCSI_OP_SEEK10           0x2b\r
+#define EFI_SCSI_OP_SEND_DIAG        0x1d\r
+#define EFI_SCSI_OP_SET_LIMIT        0x33\r
+#define EFI_SCSI_OP_START_STOP_UNIT  0x1b\r
+#define EFI_SCSI_OP_SYNC_CACHE       0x35\r
+#define EFI_SCSI_OP_VERIFY           0x2f\r
+#define EFI_SCSI_OP_WRITE6           0x0a\r
+#define EFI_SCSI_OP_WRITE10          0x2a\r
+#define EFI_SCSI_OP_WRITE16          0x8a\r
+#define EFI_SCSI_OP_WRITE_VERIFY     0x2e\r
+#define EFI_SCSI_OP_WRITE_LONG       0x3f\r
+#define EFI_SCSI_OP_WRITE_SAME       0x41\r
+#define EFI_SCSI_OP_UNMAP            0x42\r
 \r
 //\r
 // Additional commands for Sequential Access Devices\r
@@ -95,8 +95,8 @@
 //\r
 // Additional commands for Processor Devices\r
 //\r
-#define EFI_SCSI_OP_RECEIVE 0x08\r
-#define EFI_SCSI_OP_SEND    0x0a\r
+#define EFI_SCSI_OP_RECEIVE  0x08\r
+#define EFI_SCSI_OP_SEND     0x0a\r
 \r
 //\r
 // Additional commands for Write-Once Devices\r
 //\r
 // Additional commands for Scanner Devices\r
 //\r
-#define EFI_SCSI_OP_GET_DATABUFF_STAT 0x34\r
-#define EFI_SCSI_OP_GET_WINDOW        0x25\r
-#define EFI_SCSI_OP_OBJECT_POS        0x31\r
-#define EFI_SCSI_OP_SCAN              0x1b\r
-#define EFI_SCSI_OP_SET_WINDOW        0x24\r
+#define EFI_SCSI_OP_GET_DATABUFF_STAT  0x34\r
+#define EFI_SCSI_OP_GET_WINDOW         0x25\r
+#define EFI_SCSI_OP_OBJECT_POS         0x31\r
+#define EFI_SCSI_OP_SCAN               0x1b\r
+#define EFI_SCSI_OP_SET_WINDOW         0x24\r
 \r
 //\r
 // Additional commands for Optical Memory Devices\r
 //\r
 // Additional commands for Medium Changer Devices\r
 //\r
-#define EFI_SCSI_OP_EXCHANGE_MEDIUM   0xa6\r
-#define EFI_SCSI_OP_INIT_ELEMENT_STAT 0x07\r
-#define EFI_SCSI_OP_POS_TO_ELEMENT    0x2b\r
-#define EFI_SCSI_OP_REQUEST_VE_ADDR   0xb5\r
-#define EFI_SCSI_OP_SEND_VOL_TAG      0xb6\r
+#define EFI_SCSI_OP_EXCHANGE_MEDIUM    0xa6\r
+#define EFI_SCSI_OP_INIT_ELEMENT_STAT  0x07\r
+#define EFI_SCSI_OP_POS_TO_ELEMENT     0x2b\r
+#define EFI_SCSI_OP_REQUEST_VE_ADDR    0xb5\r
+#define EFI_SCSI_OP_SEND_VOL_TAG       0xb6\r
 \r
 //\r
 // Additional commands for Communication Devices\r
 //\r
 // Additional commands for Secure Transactions\r
 //\r
-#define EFI_SCSI_OP_SECURITY_PROTOCOL_IN  0xa2\r
-#define EFI_SCSI_OP_SECURITY_PROTOCOL_OUT 0xb5\r
+#define EFI_SCSI_OP_SECURITY_PROTOCOL_IN   0xa2\r
+#define EFI_SCSI_OP_SECURITY_PROTOCOL_OUT  0xb5\r
 \r
 //\r
 // SCSI Data Transfer Direction\r
 //\r
-#define EFI_SCSI_DATA_IN  0\r
-#define EFI_SCSI_DATA_OUT 1\r
+#define EFI_SCSI_DATA_IN   0\r
+#define EFI_SCSI_DATA_OUT  1\r
 \r
 //\r
 // SCSI Block Command Cache Control Parameters\r
 //\r
 // Peripheral Device Type Definitions\r
 //\r
-#define EFI_SCSI_TYPE_DISK            0x00  ///< Direct-access device (e.g. magnetic disk)\r
-#define EFI_SCSI_TYPE_TAPE            0x01  ///< Sequential-access device (e.g. magnetic tape)\r
-#define EFI_SCSI_TYPE_PRINTER         0x02  ///< Printer device\r
-#define EFI_SCSI_TYPE_PROCESSOR       0x03  ///< Processor device\r
-#define EFI_SCSI_TYPE_WORM            0x04  ///< Write-once device (e.g. some optical disks)\r
-#define EFI_SCSI_TYPE_CDROM           0x05  ///< CD/DVD device\r
-#define EFI_SCSI_TYPE_SCANNER         0x06  ///< Scanner device (obsolete)\r
-#define EFI_SCSI_TYPE_OPTICAL         0x07  ///< Optical memory device (e.g. some optical disks)\r
-#define EFI_SCSI_TYPE_MEDIUMCHANGER   0x08  ///< Medium changer device (e.g. jukeboxes)\r
-#define EFI_SCSI_TYPE_COMMUNICATION   0x09  ///< Communications device (obsolete)\r
-#define EFI_SCSI_TYPE_ASCIT8_1        0x0A  ///< Defined by ASC IT8 (Graphic arts pre-press devices)\r
-#define EFI_SCSI_TYPE_ASCIT8_2        0x0B  ///< Defined by ASC IT8 (Graphic arts pre-press devices)\r
-#define EFI_SCSI_TYPE_RAID            0x0C  ///< Storage array controller device (e.g., RAID)\r
-#define EFI_SCSI_TYPE_SES             0x0D  ///< Enclosure services device\r
-#define EFI_SCSI_TYPE_RBC             0x0E  ///< Simplified direct-access device (e.g., magnetic disk)\r
-#define EFI_SCSI_TYPE_OCRW            0x0F  ///< Optical card reader/writer device\r
-#define EFI_SCSI_TYPE_BRIDGE          0x10  ///< Bridge Controller Commands\r
-#define EFI_SCSI_TYPE_OSD             0x11  ///< Object-based Storage Device\r
-#define EFI_SCSI_TYPE_AUTOMATION      0x12  ///< Automation/Drive Interface\r
-#define EFI_SCSI_TYPE_SECURITYMANAGER 0x13  ///< Security manager device\r
-#define EFI_SCSI_TYPE_RESERVED_LOW    0x14  ///< Reserved (low)\r
-#define EFI_SCSI_TYPE_RESERVED_HIGH   0x1D  ///< Reserved (high)\r
-#define EFI_SCSI_TYPE_WLUN            0x1E  ///< Well known logical unit\r
-#define EFI_SCSI_TYPE_UNKNOWN         0x1F  ///< Unknown or no device type\r
+#define EFI_SCSI_TYPE_DISK             0x00 ///< Direct-access device (e.g. magnetic disk)\r
+#define EFI_SCSI_TYPE_TAPE             0x01 ///< Sequential-access device (e.g. magnetic tape)\r
+#define EFI_SCSI_TYPE_PRINTER          0x02 ///< Printer device\r
+#define EFI_SCSI_TYPE_PROCESSOR        0x03 ///< Processor device\r
+#define EFI_SCSI_TYPE_WORM             0x04 ///< Write-once device (e.g. some optical disks)\r
+#define EFI_SCSI_TYPE_CDROM            0x05 ///< CD/DVD device\r
+#define EFI_SCSI_TYPE_SCANNER          0x06 ///< Scanner device (obsolete)\r
+#define EFI_SCSI_TYPE_OPTICAL          0x07 ///< Optical memory device (e.g. some optical disks)\r
+#define EFI_SCSI_TYPE_MEDIUMCHANGER    0x08 ///< Medium changer device (e.g. jukeboxes)\r
+#define EFI_SCSI_TYPE_COMMUNICATION    0x09 ///< Communications device (obsolete)\r
+#define EFI_SCSI_TYPE_ASCIT8_1         0x0A ///< Defined by ASC IT8 (Graphic arts pre-press devices)\r
+#define EFI_SCSI_TYPE_ASCIT8_2         0x0B ///< Defined by ASC IT8 (Graphic arts pre-press devices)\r
+#define EFI_SCSI_TYPE_RAID             0x0C ///< Storage array controller device (e.g., RAID)\r
+#define EFI_SCSI_TYPE_SES              0x0D ///< Enclosure services device\r
+#define EFI_SCSI_TYPE_RBC              0x0E ///< Simplified direct-access device (e.g., magnetic disk)\r
+#define EFI_SCSI_TYPE_OCRW             0x0F ///< Optical card reader/writer device\r
+#define EFI_SCSI_TYPE_BRIDGE           0x10 ///< Bridge Controller Commands\r
+#define EFI_SCSI_TYPE_OSD              0x11 ///< Object-based Storage Device\r
+#define EFI_SCSI_TYPE_AUTOMATION       0x12 ///< Automation/Drive Interface\r
+#define EFI_SCSI_TYPE_SECURITYMANAGER  0x13 ///< Security manager device\r
+#define EFI_SCSI_TYPE_RESERVED_LOW     0x14 ///< Reserved (low)\r
+#define EFI_SCSI_TYPE_RESERVED_HIGH    0x1D ///< Reserved (high)\r
+#define EFI_SCSI_TYPE_WLUN             0x1E ///< Well known logical unit\r
+#define EFI_SCSI_TYPE_UNKNOWN          0x1F ///< Unknown or no device type\r
 \r
 //\r
 // Page Codes for INQUIRY command\r
 //\r
-#define EFI_SCSI_PAGE_CODE_SUPPORTED_VPD    0x00\r
-#define EFI_SCSI_PAGE_CODE_BLOCK_LIMITS_VPD 0xB0\r
+#define EFI_SCSI_PAGE_CODE_SUPPORTED_VPD     0x00\r
+#define EFI_SCSI_PAGE_CODE_BLOCK_LIMITS_VPD  0xB0\r
 \r
 #pragma pack(1)\r
 ///\r
 /// Standard INQUIRY data format\r
 ///\r
 typedef struct {\r
-  UINT8 Peripheral_Type : 5;\r
-  UINT8 Peripheral_Qualifier : 3;\r
-  UINT8 DeviceType_Modifier : 7;\r
-  UINT8 Rmb : 1;\r
-  UINT8 Version;\r
-  UINT8 Response_Data_Format;\r
-  UINT8 Addnl_Length;\r
-  UINT8 Reserved_5_95[95 - 5 + 1];\r
+  UINT8    Peripheral_Type      : 5;\r
+  UINT8    Peripheral_Qualifier : 3;\r
+  UINT8    DeviceType_Modifier  : 7;\r
+  UINT8    Rmb                  : 1;\r
+  UINT8    Version;\r
+  UINT8    Response_Data_Format;\r
+  UINT8    Addnl_Length;\r
+  UINT8    Reserved_5_95[95 - 5 + 1];\r
 } EFI_SCSI_INQUIRY_DATA;\r
 \r
 ///\r
 /// Supported VPD Pages VPD page\r
 ///\r
 typedef struct {\r
-  UINT8 Peripheral_Type : 5;\r
-  UINT8 Peripheral_Qualifier : 3;\r
-  UINT8 PageCode;\r
-  UINT8 PageLength2;\r
-  UINT8 PageLength1;\r
-  UINT8 SupportedVpdPageList[0x100];\r
+  UINT8    Peripheral_Type      : 5;\r
+  UINT8    Peripheral_Qualifier : 3;\r
+  UINT8    PageCode;\r
+  UINT8    PageLength2;\r
+  UINT8    PageLength1;\r
+  UINT8    SupportedVpdPageList[0x100];\r
 } EFI_SCSI_SUPPORTED_VPD_PAGES_VPD_PAGE;\r
 \r
 ///\r
 /// Block Limits VPD page\r
 ///\r
 typedef struct {\r
-  UINT8 Peripheral_Type : 5;\r
-  UINT8 Peripheral_Qualifier : 3;\r
-  UINT8 PageCode;\r
-  UINT8 PageLength2;\r
-  UINT8 PageLength1;\r
-  UINT8 WriteSameNonZero : 1;\r
-  UINT8 Reserved_4 : 7;\r
-  UINT8 MaximumCompareAndWriteLength;\r
-  UINT8 OptimalTransferLengthGranularity2;\r
-  UINT8 OptimalTransferLengthGranularity1;\r
-  UINT8 MaximumTransferLength4;\r
-  UINT8 MaximumTransferLength3;\r
-  UINT8 MaximumTransferLength2;\r
-  UINT8 MaximumTransferLength1;\r
-  UINT8 OptimalTransferLength4;\r
-  UINT8 OptimalTransferLength3;\r
-  UINT8 OptimalTransferLength2;\r
-  UINT8 OptimalTransferLength1;\r
-  UINT8 MaximumPrefetchXdreadXdwriteTransferLength4;\r
-  UINT8 MaximumPrefetchXdreadXdwriteTransferLength3;\r
-  UINT8 MaximumPrefetchXdreadXdwriteTransferLength2;\r
-  UINT8 MaximumPrefetchXdreadXdwriteTransferLength1;\r
-  UINT8 MaximumUnmapLbaCount4;\r
-  UINT8 MaximumUnmapLbaCount3;\r
-  UINT8 MaximumUnmapLbaCount2;\r
-  UINT8 MaximumUnmapLbaCount1;\r
-  UINT8 MaximumUnmapBlockDescriptorCount4;\r
-  UINT8 MaximumUnmapBlockDescriptorCount3;\r
-  UINT8 MaximumUnmapBlockDescriptorCount2;\r
-  UINT8 MaximumUnmapBlockDescriptorCount1;\r
-  UINT8 OptimalUnmapGranularity4;\r
-  UINT8 OptimalUnmapGranularity3;\r
-  UINT8 OptimalUnmapGranularity2;\r
-  UINT8 OptimalUnmapGranularity1;\r
-  UINT8 UnmapGranularityAlignment4 : 7;\r
-  UINT8 UnmapGranularityAlignmentValid : 1;\r
-  UINT8 UnmapGranularityAlignment3;\r
-  UINT8 UnmapGranularityAlignment2;\r
-  UINT8 UnmapGranularityAlignment1;\r
-  UINT8 MaximumWriteSameLength4;\r
-  UINT8 MaximumWriteSameLength3;\r
-  UINT8 MaximumWriteSameLength2;\r
-  UINT8 MaximumWriteSameLength1;\r
-  UINT8 MaximumAtomicTransferLength4;\r
-  UINT8 MaximumAtomicTransferLength3;\r
-  UINT8 MaximumAtomicTransferLength2;\r
-  UINT8 MaximumAtomicTransferLength1;\r
-  UINT8 AtomicAlignment4;\r
-  UINT8 AtomicAlignment3;\r
-  UINT8 AtomicAlignment2;\r
-  UINT8 AtomicAlignment1;\r
-  UINT8 AtomicTransferLengthGranularity4;\r
-  UINT8 AtomicTransferLengthGranularity3;\r
-  UINT8 AtomicTransferLengthGranularity2;\r
-  UINT8 AtomicTransferLengthGranularity1;\r
-  UINT8 MaximumAtomicTransferLengthWithAtomicBoundary4;\r
-  UINT8 MaximumAtomicTransferLengthWithAtomicBoundary3;\r
-  UINT8 MaximumAtomicTransferLengthWithAtomicBoundary2;\r
-  UINT8 MaximumAtomicTransferLengthWithAtomicBoundary1;\r
-  UINT8 MaximumAtomicBoundarySize4;\r
-  UINT8 MaximumAtomicBoundarySize3;\r
-  UINT8 MaximumAtomicBoundarySize2;\r
-  UINT8 MaximumAtomicBoundarySize1;\r
+  UINT8    Peripheral_Type      : 5;\r
+  UINT8    Peripheral_Qualifier : 3;\r
+  UINT8    PageCode;\r
+  UINT8    PageLength2;\r
+  UINT8    PageLength1;\r
+  UINT8    WriteSameNonZero     : 1;\r
+  UINT8    Reserved_4           : 7;\r
+  UINT8    MaximumCompareAndWriteLength;\r
+  UINT8    OptimalTransferLengthGranularity2;\r
+  UINT8    OptimalTransferLengthGranularity1;\r
+  UINT8    MaximumTransferLength4;\r
+  UINT8    MaximumTransferLength3;\r
+  UINT8    MaximumTransferLength2;\r
+  UINT8    MaximumTransferLength1;\r
+  UINT8    OptimalTransferLength4;\r
+  UINT8    OptimalTransferLength3;\r
+  UINT8    OptimalTransferLength2;\r
+  UINT8    OptimalTransferLength1;\r
+  UINT8    MaximumPrefetchXdreadXdwriteTransferLength4;\r
+  UINT8    MaximumPrefetchXdreadXdwriteTransferLength3;\r
+  UINT8    MaximumPrefetchXdreadXdwriteTransferLength2;\r
+  UINT8    MaximumPrefetchXdreadXdwriteTransferLength1;\r
+  UINT8    MaximumUnmapLbaCount4;\r
+  UINT8    MaximumUnmapLbaCount3;\r
+  UINT8    MaximumUnmapLbaCount2;\r
+  UINT8    MaximumUnmapLbaCount1;\r
+  UINT8    MaximumUnmapBlockDescriptorCount4;\r
+  UINT8    MaximumUnmapBlockDescriptorCount3;\r
+  UINT8    MaximumUnmapBlockDescriptorCount2;\r
+  UINT8    MaximumUnmapBlockDescriptorCount1;\r
+  UINT8    OptimalUnmapGranularity4;\r
+  UINT8    OptimalUnmapGranularity3;\r
+  UINT8    OptimalUnmapGranularity2;\r
+  UINT8    OptimalUnmapGranularity1;\r
+  UINT8    UnmapGranularityAlignment4     : 7;\r
+  UINT8    UnmapGranularityAlignmentValid : 1;\r
+  UINT8    UnmapGranularityAlignment3;\r
+  UINT8    UnmapGranularityAlignment2;\r
+  UINT8    UnmapGranularityAlignment1;\r
+  UINT8    MaximumWriteSameLength4;\r
+  UINT8    MaximumWriteSameLength3;\r
+  UINT8    MaximumWriteSameLength2;\r
+  UINT8    MaximumWriteSameLength1;\r
+  UINT8    MaximumAtomicTransferLength4;\r
+  UINT8    MaximumAtomicTransferLength3;\r
+  UINT8    MaximumAtomicTransferLength2;\r
+  UINT8    MaximumAtomicTransferLength1;\r
+  UINT8    AtomicAlignment4;\r
+  UINT8    AtomicAlignment3;\r
+  UINT8    AtomicAlignment2;\r
+  UINT8    AtomicAlignment1;\r
+  UINT8    AtomicTransferLengthGranularity4;\r
+  UINT8    AtomicTransferLengthGranularity3;\r
+  UINT8    AtomicTransferLengthGranularity2;\r
+  UINT8    AtomicTransferLengthGranularity1;\r
+  UINT8    MaximumAtomicTransferLengthWithAtomicBoundary4;\r
+  UINT8    MaximumAtomicTransferLengthWithAtomicBoundary3;\r
+  UINT8    MaximumAtomicTransferLengthWithAtomicBoundary2;\r
+  UINT8    MaximumAtomicTransferLengthWithAtomicBoundary1;\r
+  UINT8    MaximumAtomicBoundarySize4;\r
+  UINT8    MaximumAtomicBoundarySize3;\r
+  UINT8    MaximumAtomicBoundarySize2;\r
+  UINT8    MaximumAtomicBoundarySize1;\r
 } EFI_SCSI_BLOCK_LIMITS_VPD_PAGE;\r
 \r
 ///\r
 /// Error codes 70h and 71h sense data format\r
 ///\r
 typedef struct {\r
-  UINT8 Error_Code : 7;\r
-  UINT8 Valid : 1;\r
-  UINT8 Segment_Number;\r
-  UINT8 Sense_Key : 4;\r
-  UINT8 Reserved_21 : 1;\r
-  UINT8 Ili : 1;\r
-  UINT8 Reserved_22 : 2;\r
-  UINT8 Information_3_6[4];\r
-  UINT8 Addnl_Sense_Length;           ///< Additional sense length (n-7)\r
-  UINT8 Vendor_Specific_8_11[4];\r
-  UINT8 Addnl_Sense_Code;             ///< Additional sense code\r
-  UINT8 Addnl_Sense_Code_Qualifier;   ///< Additional sense code qualifier\r
-  UINT8 Field_Replaceable_Unit_Code;  ///< Field replaceable unit code\r
-  UINT8 Reserved_15_17[3];\r
+  UINT8    Error_Code  : 7;\r
+  UINT8    Valid       : 1;\r
+  UINT8    Segment_Number;\r
+  UINT8    Sense_Key   : 4;\r
+  UINT8    Reserved_21 : 1;\r
+  UINT8    Ili         : 1;\r
+  UINT8    Reserved_22 : 2;\r
+  UINT8    Information_3_6[4];\r
+  UINT8    Addnl_Sense_Length;        ///< Additional sense length (n-7)\r
+  UINT8    Vendor_Specific_8_11[4];\r
+  UINT8    Addnl_Sense_Code;            ///< Additional sense code\r
+  UINT8    Addnl_Sense_Code_Qualifier;  ///< Additional sense code qualifier\r
+  UINT8    Field_Replaceable_Unit_Code; ///< Field replaceable unit code\r
+  UINT8    Reserved_15_17[3];\r
 } EFI_SCSI_SENSE_DATA;\r
 \r
 ///\r
 /// SCSI Disk READ CAPACITY Data\r
 ///\r
 typedef struct {\r
-  UINT8 LastLba3;\r
-  UINT8 LastLba2;\r
-  UINT8 LastLba1;\r
-  UINT8 LastLba0;\r
-  UINT8 BlockSize3;\r
-  UINT8 BlockSize2;\r
-  UINT8 BlockSize1;\r
-  UINT8 BlockSize0;\r
+  UINT8    LastLba3;\r
+  UINT8    LastLba2;\r
+  UINT8    LastLba1;\r
+  UINT8    LastLba0;\r
+  UINT8    BlockSize3;\r
+  UINT8    BlockSize2;\r
+  UINT8    BlockSize1;\r
+  UINT8    BlockSize0;\r
 } EFI_SCSI_DISK_CAPACITY_DATA;\r
 \r
 typedef struct {\r
-  UINT8 LastLba7;\r
-  UINT8 LastLba6;\r
-  UINT8 LastLba5;\r
-  UINT8 LastLba4;\r
-  UINT8 LastLba3;\r
-  UINT8 LastLba2;\r
-  UINT8 LastLba1;\r
-  UINT8 LastLba0;\r
-  UINT8 BlockSize3;\r
-  UINT8 BlockSize2;\r
-  UINT8 BlockSize1;\r
-  UINT8 BlockSize0;\r
-  UINT8 Protection;\r
-  UINT8 LogicPerPhysical;\r
-  UINT8 LowestAlignLogic2;\r
-  UINT8 LowestAlignLogic1;\r
-  UINT8 Reserved[16];\r
+  UINT8    LastLba7;\r
+  UINT8    LastLba6;\r
+  UINT8    LastLba5;\r
+  UINT8    LastLba4;\r
+  UINT8    LastLba3;\r
+  UINT8    LastLba2;\r
+  UINT8    LastLba1;\r
+  UINT8    LastLba0;\r
+  UINT8    BlockSize3;\r
+  UINT8    BlockSize2;\r
+  UINT8    BlockSize1;\r
+  UINT8    BlockSize0;\r
+  UINT8    Protection;\r
+  UINT8    LogicPerPhysical;\r
+  UINT8    LowestAlignLogic2;\r
+  UINT8    LowestAlignLogic1;\r
+  UINT8    Reserved[16];\r
 } EFI_SCSI_DISK_CAPACITY_DATA16;\r
 \r
 typedef struct {\r
-  UINT16 DataLen;\r
-  UINT16 BlkDespDataLen;\r
-  UINT8  Reserved[4];\r
+  UINT16    DataLen;\r
+  UINT16    BlkDespDataLen;\r
+  UINT8     Reserved[4];\r
 } EFI_SCSI_DISK_UNMAP_PARAM_LIST_HEADER;\r
 \r
 typedef struct {\r
-  UINT64 Lba;\r
-  UINT32 BlockNum;\r
-  UINT8  Reserved[4];\r
+  UINT64    Lba;\r
+  UINT32    BlockNum;\r
+  UINT8     Reserved[4];\r
 } EFI_SCSI_DISK_UNMAP_BLOCK_DESP;\r
 \r
-\r
 #pragma pack()\r
 \r
 //\r
 // Sense Key\r
 //\r
-#define EFI_SCSI_SK_NO_SENSE          (0x0)\r
-#define EFI_SCSI_SK_RECOVERY_ERROR    (0x1)\r
-#define EFI_SCSI_SK_NOT_READY         (0x2)\r
-#define EFI_SCSI_SK_MEDIUM_ERROR      (0x3)\r
-#define EFI_SCSI_SK_HARDWARE_ERROR    (0x4)\r
-#define EFI_SCSI_SK_ILLEGAL_REQUEST   (0x5)\r
-#define EFI_SCSI_SK_UNIT_ATTENTION    (0x6)\r
-#define EFI_SCSI_SK_DATA_PROTECT      (0x7)\r
-#define EFI_SCSI_SK_BLANK_CHECK       (0x8)\r
-#define EFI_SCSI_SK_VENDOR_SPECIFIC   (0x9)\r
-#define EFI_SCSI_SK_RESERVED_A        (0xA)\r
-#define EFI_SCSI_SK_ABORT             (0xB)\r
-#define EFI_SCSI_SK_RESERVED_C        (0xC)\r
-#define EFI_SCSI_SK_OVERFLOW          (0xD)\r
-#define EFI_SCSI_SK_MISCOMPARE        (0xE)\r
-#define EFI_SCSI_SK_RESERVED_F        (0xF)\r
+#define EFI_SCSI_SK_NO_SENSE         (0x0)\r
+#define EFI_SCSI_SK_RECOVERY_ERROR   (0x1)\r
+#define EFI_SCSI_SK_NOT_READY        (0x2)\r
+#define EFI_SCSI_SK_MEDIUM_ERROR     (0x3)\r
+#define EFI_SCSI_SK_HARDWARE_ERROR   (0x4)\r
+#define EFI_SCSI_SK_ILLEGAL_REQUEST  (0x5)\r
+#define EFI_SCSI_SK_UNIT_ATTENTION   (0x6)\r
+#define EFI_SCSI_SK_DATA_PROTECT     (0x7)\r
+#define EFI_SCSI_SK_BLANK_CHECK      (0x8)\r
+#define EFI_SCSI_SK_VENDOR_SPECIFIC  (0x9)\r
+#define EFI_SCSI_SK_RESERVED_A       (0xA)\r
+#define EFI_SCSI_SK_ABORT            (0xB)\r
+#define EFI_SCSI_SK_RESERVED_C       (0xC)\r
+#define EFI_SCSI_SK_OVERFLOW         (0xD)\r
+#define EFI_SCSI_SK_MISCOMPARE       (0xE)\r
+#define EFI_SCSI_SK_RESERVED_F       (0xF)\r
 \r
 //\r
 // Additional Sense Codes and Sense Code Qualifiers.\r
 // Only some frequently used additional sense codes and qualifiers are\r
 // defined here. Please refer to SCSI standard for full value definition.\r
 //\r
-#define EFI_SCSI_ASC_NOT_READY                    (0x04)\r
-#define EFI_SCSI_ASCQ_IN_PROGRESS                 (0x01)\r
+#define EFI_SCSI_ASC_NOT_READY     (0x04)\r
+#define EFI_SCSI_ASCQ_IN_PROGRESS  (0x01)\r
 \r
 #define EFI_SCSI_ASC_MEDIA_ERR1                   (0x10)\r
 #define EFI_SCSI_ASC_MEDIA_ERR2                   (0x11)\r