zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

ntdddisk.h (18880B) - Raw


      1 /*
      2  * ntdddisk.h
      3  *
      4  * Disk IOCTL interface.
      5  *
      6  * This file is part of the w32api package.
      7  *
      8  * Contributors:
      9  *   Created by Casper S. Hornstrup <chorns@users.sourceforge.net>
     10  *
     11  * THIS SOFTWARE IS NOT COPYRIGHTED
     12  *
     13  * This source code is offered for use in the public domain. You may
     14  * use, modify or distribute it freely.
     15  *
     16  * This code is distributed in the hope that it will be useful but
     17  * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
     18  * DISCLAIMED. This includes but is not limited to warranties of
     19  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
     20  *
     21  */
     22 
     23 #ifndef _NTDDDISK_H_
     24 #define _NTDDDISK_H_
     25 
     26 #include "ntddstor.h"
     27 
     28 #ifdef __cplusplus
     29 extern "C" {
     30 #endif
     31 
     32 #define DD_DISK_DEVICE_NAME               "\\Device\\UNKNOWN"
     33 #define DD_DISK_DEVICE_NAME_U             L"\\Device\\UNKNOWN"
     34 
     35 #define IOCTL_DISK_BASE                   FILE_DEVICE_DISK
     36 
     37 #define IOCTL_DISK_CHECK_VERIFY \
     38   CTL_CODE(IOCTL_DISK_BASE, 0x0200, METHOD_BUFFERED, FILE_READ_ACCESS)
     39 
     40 #define IOCTL_DISK_CONTROLLER_NUMBER \
     41   CTL_CODE(IOCTL_DISK_BASE, 0x0011, METHOD_BUFFERED, FILE_ANY_ACCESS)
     42 
     43 #define IOCTL_DISK_CREATE_DISK \
     44   CTL_CODE(IOCTL_DISK_BASE, 0x0016, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
     45 
     46 #define IOCTL_DISK_DELETE_DRIVE_LAYOUT \
     47   CTL_CODE(IOCTL_DISK_BASE, 0x0040, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
     48 
     49 #define IOCTL_DISK_FIND_NEW_DEVICES \
     50   CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS)
     51 
     52 #define IOCTL_DISK_FORMAT_TRACKS \
     53   CTL_CODE(IOCTL_DISK_BASE, 0x0006, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
     54 
     55 #define IOCTL_DISK_FORMAT_TRACKS_EX \
     56   CTL_CODE(IOCTL_DISK_BASE, 0x000b, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
     57 
     58 #define IOCTL_DISK_GET_CACHE_INFORMATION \
     59   CTL_CODE(IOCTL_DISK_BASE, 0x0035, METHOD_BUFFERED, FILE_READ_ACCESS)
     60 
     61 #define IOCTL_DISK_GET_DRIVE_GEOMETRY \
     62   CTL_CODE(IOCTL_DISK_BASE, 0x0000, METHOD_BUFFERED, FILE_ANY_ACCESS)
     63 
     64 #define IOCTL_DISK_GET_DRIVE_GEOMETRY_EX \
     65   CTL_CODE(IOCTL_DISK_BASE, 0x0028, METHOD_BUFFERED, FILE_ANY_ACCESS)
     66 
     67 #define IOCTL_DISK_GET_DRIVE_LAYOUT \
     68   CTL_CODE(IOCTL_DISK_BASE, 0x0003, METHOD_BUFFERED, FILE_READ_ACCESS)
     69 
     70 #define IOCTL_DISK_GET_DRIVE_LAYOUT_EX \
     71   CTL_CODE(IOCTL_DISK_BASE, 0x0014, METHOD_BUFFERED, FILE_ANY_ACCESS)
     72 
     73 #define IOCTL_DISK_GET_MEDIA_TYPES \
     74   CTL_CODE(IOCTL_DISK_BASE, 0x0300, METHOD_BUFFERED, FILE_ANY_ACCESS)
     75 
     76 #define IOCTL_DISK_GET_LENGTH_INFO \
     77   CTL_CODE(IOCTL_DISK_BASE, 0x0017, METHOD_BUFFERED, FILE_READ_ACCESS)
     78 
     79 #define IOCTL_DISK_GET_PARTITION_INFO \
     80   CTL_CODE(IOCTL_DISK_BASE, 0x0001, METHOD_BUFFERED, FILE_READ_ACCESS)
     81 
     82 #define IOCTL_DISK_GET_PARTITION_INFO_EX \
     83   CTL_CODE(IOCTL_DISK_BASE, 0x0012, METHOD_BUFFERED, FILE_ANY_ACCESS)
     84 
     85 #define IOCTL_DISK_GROW_PARTITION \
     86   CTL_CODE(IOCTL_DISK_BASE, 0x0034, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
     87 
     88 #define IOCTL_DISK_HISTOGRAM_STRUCTURE \
     89   CTL_CODE(IOCTL_DISK_BASE, 0x000c, METHOD_BUFFERED, FILE_ANY_ACCESS)
     90 
     91 #define IOCTL_DISK_HISTOGRAM_DATA \
     92   CTL_CODE(IOCTL_DISK_BASE, 0x000d, METHOD_BUFFERED, FILE_ANY_ACCESS)
     93 
     94 #define IOCTL_DISK_HISTOGRAM_RESET \
     95   CTL_CODE(IOCTL_DISK_BASE, 0x000e, METHOD_BUFFERED, FILE_ANY_ACCESS)
     96 
     97 #define IOCTL_DISK_INTERNAL_CLEAR_VERIFY \
     98   CTL_CODE(IOCTL_DISK_BASE, 0x0101, METHOD_NEITHER, FILE_ANY_ACCESS)
     99 
    100 #define IOCTL_DISK_INTERNAL_SET_VERIFY \
    101   CTL_CODE(IOCTL_DISK_BASE, 0x0100, METHOD_NEITHER, FILE_ANY_ACCESS)
    102 
    103 #define IOCTL_DISK_IS_WRITABLE \
    104   CTL_CODE(IOCTL_DISK_BASE, 0x0009, METHOD_BUFFERED, FILE_ANY_ACCESS)
    105 
    106 #define IOCTL_DISK_LOGGING \
    107   CTL_CODE(IOCTL_DISK_BASE, 0x000a, METHOD_BUFFERED, FILE_ANY_ACCESS)
    108 
    109 #define IOCTL_DISK_PERFORMANCE \
    110   CTL_CODE(IOCTL_DISK_BASE, 0x0008, METHOD_BUFFERED, FILE_ANY_ACCESS)
    111 
    112 #define IOCTL_DISK_PERFORMANCE_OFF \
    113   CTL_CODE(IOCTL_DISK_BASE, 0x0018, METHOD_BUFFERED, FILE_ANY_ACCESS)
    114 
    115 #define IOCTL_DISK_REASSIGN_BLOCKS \
    116   CTL_CODE(IOCTL_DISK_BASE, 0x0007, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    117 
    118 #define IOCTL_DISK_REQUEST_DATA \
    119   CTL_CODE(IOCTL_DISK_BASE, 0x0010, METHOD_BUFFERED, FILE_ANY_ACCESS)
    120 
    121 #define IOCTL_DISK_REQUEST_STRUCTURE \
    122   CTL_CODE(IOCTL_DISK_BASE, 0x000f, METHOD_BUFFERED, FILE_ANY_ACCESS)
    123 
    124 #define IOCTL_DISK_MEDIA_REMOVAL \
    125   CTL_CODE(IOCTL_DISK_BASE, 0x0201, METHOD_BUFFERED, FILE_READ_ACCESS)
    126 
    127 #define IOCTL_DISK_EJECT_MEDIA \
    128   CTL_CODE(IOCTL_DISK_BASE, 0x0202, METHOD_BUFFERED, FILE_READ_ACCESS)
    129 
    130 #define IOCTL_DISK_LOAD_MEDIA \
    131   CTL_CODE(IOCTL_DISK_BASE, 0x0203, METHOD_BUFFERED, FILE_READ_ACCESS)
    132 
    133 #define IOCTL_DISK_RESERVE \
    134   CTL_CODE(IOCTL_DISK_BASE, 0x0204, METHOD_BUFFERED, FILE_READ_ACCESS)
    135 
    136 #define IOCTL_DISK_RELEASE \
    137   CTL_CODE(IOCTL_DISK_BASE, 0x0205, METHOD_BUFFERED, FILE_READ_ACCESS)
    138 
    139 #define IOCTL_DISK_FIND_NEW_DEVICES \
    140   CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS)
    141 
    142 #define IOCTL_DISK_SET_CACHE_INFORMATION \
    143   CTL_CODE(IOCTL_DISK_BASE, 0x0036, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    144 
    145 #define IOCTL_DISK_SET_DRIVE_LAYOUT \
    146   CTL_CODE(IOCTL_DISK_BASE, 0x0004, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    147 
    148 #define IOCTL_DISK_SET_DRIVE_LAYOUT_EX \
    149   CTL_CODE(IOCTL_DISK_BASE, 0x0015, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    150 
    151 #define IOCTL_DISK_SET_PARTITION_INFO \
    152   CTL_CODE(IOCTL_DISK_BASE, 0x0002, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    153 
    154 #define IOCTL_DISK_SET_PARTITION_INFO_EX \
    155   CTL_CODE(IOCTL_DISK_BASE, 0x0013, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    156 
    157 #define IOCTL_DISK_UPDATE_DRIVE_SIZE \
    158   CTL_CODE(IOCTL_DISK_BASE, 0x0032, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    159 
    160 #define IOCTL_DISK_VERIFY \
    161   CTL_CODE(IOCTL_DISK_BASE, 0x0005, METHOD_BUFFERED, FILE_ANY_ACCESS)
    162 
    163 #define SMART_GET_VERSION \
    164   CTL_CODE(IOCTL_DISK_BASE, 0x0020, METHOD_BUFFERED, FILE_READ_ACCESS)
    165 
    166 #define SMART_RCV_DRIVE_DATA \
    167   CTL_CODE(IOCTL_DISK_BASE, 0x0022, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    168 
    169 #define SMART_SEND_DRIVE_COMMAND \
    170   CTL_CODE(IOCTL_DISK_BASE, 0x0021, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
    171 
    172 #define IOCTL_DISK_UPDATE_PROPERTIES \
    173   CTL_CODE(IOCTL_DISK_BASE, 0x50, METHOD_BUFFERED, FILE_ANY_ACCESS)
    174 
    175 #define PARTITION_ENTRY_UNUSED            0x00
    176 #define PARTITION_FAT_12                  0x01
    177 #define PARTITION_XENIX_1                 0x02
    178 #define PARTITION_XENIX_2                 0x03
    179 #define PARTITION_FAT_16                  0x04
    180 #define PARTITION_EXTENDED                0x05
    181 #define PARTITION_HUGE                    0x06
    182 #define PARTITION_IFS                     0x07
    183 #define PARTITION_OS2BOOTMGR              0x0A
    184 #define PARTITION_FAT32                   0x0B
    185 #define PARTITION_FAT32_XINT13            0x0C
    186 #define PARTITION_XINT13                  0x0E
    187 #define PARTITION_XINT13_EXTENDED         0x0F
    188 #define PARTITION_PREP                    0x41
    189 #define PARTITION_LDM                     0x42
    190 #define PARTITION_UNIX                    0x63
    191 #define VALID_NTFT                        0xC0
    192 #define PARTITION_NTFT                    0x80
    193 
    194 #define IsFTPartition( PartitionType ) \
    195   (((PartitionType) & PARTITION_NTFT) && \
    196   IsRecognizedPartition(PartitionType))
    197 
    198 #define IsContainerPartition(PartitionType) \
    199   (((PartitionType) == PARTITION_EXTENDED) || \
    200   ((PartitionType) == PARTITION_XINT13_EXTENDED))
    201 
    202 #define IsRecognizedPartition(PartitionType) ( \
    203 	(((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT_12)) || \
    204 	(((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_HUGE)) || \
    205 	(((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_IFS)) || \
    206 	(((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32)) || \
    207 	(((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32_XINT13)) || \
    208 	(((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_XINT13)) || \
    209 	((PartitionType) == PARTITION_FAT_12) || \
    210 	((PartitionType) == PARTITION_FAT_16) || \
    211 	((PartitionType) == PARTITION_HUGE) || \
    212 	((PartitionType) == PARTITION_IFS) || \
    213 	((PartitionType) == PARTITION_FAT32) || \
    214 	((PartitionType) == PARTITION_FAT32_XINT13) || \
    215 	((PartitionType) == PARTITION_XINT13))
    216 
    217 #define WMI_DISK_GEOMETRY_GUID \
    218   {0x25007f51, 0x57c2, 0x11d1, {0xa5, 0x28, 0x0, 0xa0, 0xc9, 0x6, 0x29, 0x10}}
    219 
    220 typedef USHORT BAD_TRACK_NUMBER;
    221 typedef USHORT *PBAD_TRACK_NUMBER;
    222 
    223 typedef enum _MEDIA_TYPE {
    224   Unknown,
    225   F5_1Pt2_512,
    226   F3_1Pt44_512,
    227   F3_2Pt88_512,
    228   F3_20Pt8_512,
    229   F3_720_512,
    230   F5_360_512,
    231   F5_320_512,
    232   F5_320_1024,
    233   F5_180_512,
    234   F5_160_512,
    235   RemovableMedia,
    236   FixedMedia,
    237   F3_120M_512,
    238   F3_640_512,
    239   F5_640_512,
    240   F5_720_512,
    241   F3_1Pt2_512,
    242   F3_1Pt23_1024,
    243   F5_1Pt23_1024,
    244   F3_128Mb_512,
    245   F3_230Mb_512,
    246   F8_256_128
    247 } MEDIA_TYPE, *PMEDIA_TYPE;
    248 
    249 typedef enum _DETECTION_TYPE {
    250   DetectNone,
    251   DetectInt13,
    252   DetectExInt13
    253 } DETECTION_TYPE;
    254 
    255 typedef struct _DISK_CONTROLLER_NUMBER {
    256   ULONG  ControllerNumber;
    257   ULONG  DiskNumber;
    258 } DISK_CONTROLLER_NUMBER, *PDISK_CONTROLLER_NUMBER;
    259 
    260 typedef struct _DISK_INT13_INFO {
    261   USHORT  DriveSelect;
    262   ULONG  MaxCylinders;
    263   USHORT  SectorsPerTrack;
    264   USHORT  MaxHeads;
    265   USHORT  NumberDrives;
    266 } DISK_INT13_INFO, *PDISK_INT13_INFO;
    267 
    268 typedef struct _DISK_EX_INT13_INFO {
    269   USHORT  ExBufferSize;
    270   USHORT  ExFlags;
    271   ULONG  ExCylinders;
    272   ULONG  ExHeads;
    273   ULONG  ExSectorsPerTrack;
    274   ULONG64  ExSectorsPerDrive;
    275   USHORT  ExSectorSize;
    276   USHORT  ExReserved;
    277 } DISK_EX_INT13_INFO, *PDISK_EX_INT13_INFO;
    278 
    279 typedef struct _DISK_DETECTION_INFO {
    280   ULONG  SizeOfDetectInfo;
    281   DETECTION_TYPE  DetectionType;
    282   _ANONYMOUS_UNION union {
    283     _ANONYMOUS_STRUCT struct {
    284       DISK_INT13_INFO  Int13;
    285       DISK_EX_INT13_INFO  ExInt13;
    286     } DUMMYSTRUCTNAME;
    287   } DUMMYUNIONNAME;
    288 } DISK_DETECTION_INFO, *PDISK_DETECTION_INFO;
    289 
    290 typedef struct _DISK_GEOMETRY {
    291   LARGE_INTEGER  Cylinders;
    292   MEDIA_TYPE  MediaType;
    293   ULONG  TracksPerCylinder;
    294   ULONG  SectorsPerTrack;
    295   ULONG  BytesPerSector;
    296 } DISK_GEOMETRY, *PDISK_GEOMETRY;
    297 
    298 typedef struct _DISK_GEOMETRY_EX {
    299   DISK_GEOMETRY  Geometry;
    300   LARGE_INTEGER  DiskSize;
    301   UCHAR  Data[1];
    302 } DISK_GEOMETRY_EX, *PDISK_GEOMETRY_EX;
    303 
    304 #define DiskGeometryGetPartition(Geometry) \
    305    ((PDISK_PARTITION_INFO)((Geometry) + 1))
    306 
    307 #define DiskGeometryGetDetect(Geometry)\
    308  ((PDISK_DETECTION_INFO)(((PBYTE)DiskGeometryGetPartition(Geometry) + \
    309   DiskGeometryGetPartition(Geometry)->SizeOfPartitionInfo)))
    310 
    311 typedef struct _PARTITION_INFORMATION {
    312   LARGE_INTEGER  StartingOffset;
    313   LARGE_INTEGER  PartitionLength;
    314   ULONG  HiddenSectors;
    315   ULONG  PartitionNumber;
    316   UCHAR  PartitionType;
    317   BOOLEAN  BootIndicator;
    318   BOOLEAN  RecognizedPartition;
    319   BOOLEAN  RewritePartition;
    320 } PARTITION_INFORMATION, *PPARTITION_INFORMATION;
    321 
    322 typedef struct _PARTITION_INFORMATION_GPT {
    323   GUID  PartitionType;
    324   GUID  PartitionId;
    325   ULONG64  Attributes;
    326   WCHAR Name  [36];
    327 } PARTITION_INFORMATION_GPT, *PPARTITION_INFORMATION_GPT;
    328 
    329 typedef enum _PARTITION_STYLE {
    330   PARTITION_STYLE_MBR,
    331   PARTITION_STYLE_GPT,
    332   PARTITION_STYLE_RAW
    333 } PARTITION_STYLE;
    334 
    335 typedef struct _DISK_PARTITION_INFO {
    336   ULONG  SizeOfPartitionInfo;
    337   PARTITION_STYLE  PartitionStyle;
    338   _ANONYMOUS_UNION union {
    339     struct {
    340       ULONG  Signature;
    341       ULONG  CheckSum;
    342     } Mbr;
    343     struct {
    344       GUID  DiskId;
    345     } Gpt;
    346   } DUMMYUNIONNAME;
    347 } DISK_PARTITION_INFO, *PDISK_PARTITION_INFO;
    348 
    349 typedef struct _DISK_PERFORMANCE {
    350   LARGE_INTEGER  BytesRead;
    351   LARGE_INTEGER  BytesWritten;
    352   LARGE_INTEGER  ReadTime;
    353   LARGE_INTEGER  WriteTime;
    354   LARGE_INTEGER  IdleTime;
    355   ULONG  ReadCount;
    356   ULONG  WriteCount;
    357   ULONG  QueueDepth;
    358   ULONG  SplitCount;
    359   LARGE_INTEGER  QueryTime;
    360   ULONG  StorageDeviceNumber;
    361   WCHAR  StorageManagerName[8];
    362 } DISK_PERFORMANCE, *PDISK_PERFORMANCE;
    363 
    364 typedef struct _PARTITION_INFORMATION_MBR {
    365   UCHAR  PartitionType;
    366   BOOLEAN  BootIndicator;
    367   BOOLEAN  RecognizedPartition;
    368   ULONG  HiddenSectors;
    369 #if NTDDI_VERSION > NTDDI_WINBLUE
    370   GUID PartitionId;
    371 #endif
    372 } PARTITION_INFORMATION_MBR, *PPARTITION_INFORMATION_MBR;
    373 
    374 typedef struct _PARTITION_INFORMATION_EX {
    375   PARTITION_STYLE  PartitionStyle;
    376   LARGE_INTEGER  StartingOffset;
    377   LARGE_INTEGER  PartitionLength;
    378   ULONG  PartitionNumber;
    379   BOOLEAN  RewritePartition;
    380 #if NTDDI_VERSION >= NTDDI_WIN10_RS3
    381   BOOLEAN  IsServicePartition;
    382 #endif
    383   _ANONYMOUS_UNION union {
    384     PARTITION_INFORMATION_MBR  Mbr;
    385     PARTITION_INFORMATION_GPT  Gpt;
    386   } DUMMYUNIONNAME;
    387 } PARTITION_INFORMATION_EX, *PPARTITION_INFORMATION_EX;
    388 
    389 typedef struct _DRIVE_LAYOUT_INFORMATION {
    390   ULONG  PartitionCount;
    391   ULONG  Signature;
    392   PARTITION_INFORMATION  PartitionEntry[1];
    393 } DRIVE_LAYOUT_INFORMATION, *PDRIVE_LAYOUT_INFORMATION;
    394 
    395 typedef struct _DRIVE_LAYOUT_INFORMATION_MBR {
    396   ULONG  Signature;
    397 } DRIVE_LAYOUT_INFORMATION_MBR, *PDRIVE_LAYOUT_INFORMATION_MBR;
    398 
    399 typedef struct _DRIVE_LAYOUT_INFORMATION_GPT {
    400   GUID  DiskId;
    401   LARGE_INTEGER  StartingUsableOffset;
    402   LARGE_INTEGER  UsableLength;
    403   ULONG  MaxPartitionCount;
    404 } DRIVE_LAYOUT_INFORMATION_GPT, *PDRIVE_LAYOUT_INFORMATION_GPT;
    405 
    406 typedef struct _DRIVE_LAYOUT_INFORMATION_EX {
    407   ULONG  PartitionStyle;
    408   ULONG  PartitionCount;
    409   __GNU_EXTENSION union {
    410     DRIVE_LAYOUT_INFORMATION_MBR  Mbr;
    411     DRIVE_LAYOUT_INFORMATION_GPT  Gpt;
    412   };
    413   PARTITION_INFORMATION_EX  PartitionEntry[1];
    414 } DRIVE_LAYOUT_INFORMATION_EX, *PDRIVE_LAYOUT_INFORMATION_EX;
    415 
    416 typedef struct _FORMAT_EX_PARAMETERS {
    417   MEDIA_TYPE  MediaType;
    418   ULONG  StartCylinderNumber;
    419   ULONG  EndCylinderNumber;
    420   ULONG  StartHeadNumber;
    421   ULONG  EndHeadNumber;
    422   USHORT  FormatGapLength;
    423   USHORT  SectorsPerTrack;
    424   USHORT  SectorNumber[1];
    425 } FORMAT_EX_PARAMETERS, *PFORMAT_EX_PARAMETERS;
    426 
    427 typedef struct _FORMAT_PARAMETERS {
    428   MEDIA_TYPE  MediaType;
    429   ULONG  StartCylinderNumber;
    430   ULONG  EndCylinderNumber;
    431   ULONG  StartHeadNumber;
    432   ULONG  EndHeadNumber;
    433 } FORMAT_PARAMETERS, *PFORMAT_PARAMETERS;
    434 
    435 typedef struct _GET_LENGTH_INFORMATION {
    436   LARGE_INTEGER  Length;
    437 } GET_LENGTH_INFORMATION, *PGET_LENGTH_INFORMATION;
    438 
    439 typedef struct _REASSIGN_BLOCKS {
    440   USHORT  Reserved;
    441   USHORT  Count;
    442   ULONG  BlockNumber[1];
    443 } REASSIGN_BLOCKS, *PREASSIGN_BLOCKS;
    444 
    445 typedef struct _SET_PARTITION_INFORMATION {
    446   UCHAR  PartitionType;
    447 } SET_PARTITION_INFORMATION, *PSET_PARTITION_INFORMATION;
    448 
    449 typedef SET_PARTITION_INFORMATION SET_PARTITION_INFORMATION_MBR;
    450 typedef PARTITION_INFORMATION_GPT SET_PARTITION_INFORMATION_GPT;
    451 
    452 typedef struct _SET_PARTITION_INFORMATION_EX {
    453   PARTITION_STYLE  PartitionStyle;
    454   _ANONYMOUS_UNION union {
    455     SET_PARTITION_INFORMATION_MBR  Mbr;
    456     SET_PARTITION_INFORMATION_GPT  Gpt;
    457   } DUMMYUNIONNAME;
    458 } SET_PARTITION_INFORMATION_EX, *PSET_PARTITION_INFORMATION_EX;
    459 
    460 typedef struct _VERIFY_INFORMATION {
    461   LARGE_INTEGER  StartingOffset;
    462   ULONG  Length;
    463 } VERIFY_INFORMATION, *PVERIFY_INFORMATION;
    464 
    465 typedef enum {
    466 	EqualPriority,
    467 	KeepPrefetchedData,
    468 	KeepReadData
    469 } DISK_CACHE_RETENTION_PRIORITY;
    470 
    471 typedef struct _DISK_CACHE_INFORMATION {
    472 	BOOLEAN  ParametersSavable;
    473 	BOOLEAN  ReadCacheEnabled;
    474 	BOOLEAN  WriteCacheEnabled;
    475 	DISK_CACHE_RETENTION_PRIORITY  ReadRetentionPriority;
    476 	DISK_CACHE_RETENTION_PRIORITY  WriteRetentionPriority;
    477 	USHORT  DisablePrefetchTransferLength;
    478 	BOOLEAN  PrefetchScalar;
    479 	_ANONYMOUS_UNION union {
    480 		struct {
    481 			USHORT  Minimum;
    482 			USHORT  Maximum;
    483 			USHORT  MaximumBlocks;
    484 		} ScalarPrefetch;
    485 		struct {
    486 			USHORT  Minimum;
    487 			USHORT  Maximum;
    488 		} BlockPrefetch;
    489 	} DUMMYUNIONNAME;
    490 } DISK_CACHE_INFORMATION, *PDISK_CACHE_INFORMATION;
    491 
    492 typedef struct _DISK_GROW_PARTITION {
    493   ULONG  PartitionNumber;
    494   LARGE_INTEGER  BytesToGrow;
    495 } DISK_GROW_PARTITION, *PDISK_GROW_PARTITION;
    496 
    497 /* GETVERSIONINPARAMS.fCapabilities constants */
    498 #define CAP_ATA_ID_CMD                    1
    499 #define CAP_ATAPI_ID_CMD                  2
    500 #define CAP_SMART_CMD                     4
    501 
    502 typedef struct _GETVERSIONINPARAMS {
    503 	UCHAR  bVersion;
    504 	UCHAR  bRevision;
    505 	UCHAR  bReserved;
    506 	UCHAR  bIDEDeviceMap;
    507 	ULONG  fCapabilities;
    508 	ULONG  dwReserved[4];
    509 } GETVERSIONINPARAMS, *PGETVERSIONINPARAMS, *LPGETVERSIONINPARAMS;
    510 
    511 /* IDEREGS.bCommandReg constants */
    512 #define ATAPI_ID_CMD                      0xA1
    513 #define ID_CMD                            0xEC
    514 #define SMART_CMD                         0xB0
    515 
    516 #define SMART_CYL_LOW                     0x4F
    517 #define SMART_CYL_HI                      0xC2
    518 
    519 typedef struct _IDEREGS {
    520 	UCHAR  bFeaturesReg;
    521 	UCHAR  bSectorCountReg;
    522 	UCHAR  bSectorNumberReg;
    523 	UCHAR  bCylLowReg;
    524 	UCHAR  bCylHighReg;
    525 	UCHAR  bDriveHeadReg;
    526 	UCHAR  bCommandReg;
    527 	UCHAR  bReserved;
    528 } IDEREGS, *PIDEREGS, *LPIDEREGS;
    529 
    530 #include <pshpack1.h>
    531 typedef struct _SENDCMDINPARAMS {
    532 	ULONG  cBufferSize;
    533 	IDEREGS  irDriveRegs;
    534 	UCHAR  bDriveNumber;
    535 	UCHAR  bReserved[3];
    536 	ULONG  dwReserved[4];
    537 	UCHAR  bBuffer[1];
    538 } SENDCMDINPARAMS, *PSENDCMDINPARAMS, *LPSENDCMDINPARAMS;
    539 #include <poppack.h>
    540 
    541 /* DRIVERSTATUS.bDriverError constants */
    542 #define SMART_NO_ERROR                    0
    543 #define SMART_IDE_ERROR                   1
    544 #define SMART_INVALID_FLAG                2
    545 #define SMART_INVALID_COMMAND             3
    546 #define SMART_INVALID_BUFFER              4
    547 #define SMART_INVALID_DRIVE               5
    548 #define SMART_INVALID_IOCTL               6
    549 #define SMART_ERROR_NO_MEM                7
    550 #define SMART_INVALID_REGISTER            8
    551 #define SMART_NOT_SUPPORTED               9
    552 #define SMART_NO_IDE_DEVICE               10
    553 
    554 #define SMART_OFFLINE_ROUTINE_OFFLINE     0
    555 #define SMART_SHORT_SELFTEST_OFFLINE      1
    556 #define SMART_EXTENDED_SELFTEST_OFFLINE   2
    557 #define SMART_ABORT_OFFLINE_SELFTEST      127
    558 #define SMART_SHORT_SELFTEST_CAPTIVE      129
    559 #define SMART_EXTENDED_SELFTEST_CAPTIVE   130
    560 
    561 typedef struct _DRIVERSTATUS {
    562 	UCHAR  bDriverError;
    563 	UCHAR  bIDEError;
    564 	UCHAR  bReserved[2];
    565 	ULONG  dwReserved[2];
    566 } DRIVERSTATUS, *PDRIVERSTATUS, *LPDRIVERSTATUS;
    567 
    568 #define READ_ATTRIBUTE_BUFFER_SIZE        512
    569 #define IDENTIFY_BUFFER_SIZE              512
    570 #define READ_THRESHOLD_BUFFER_SIZE        512
    571 #define SMART_LOG_SECTOR_SIZE             512
    572 
    573 #include <pshpack1.h>
    574 typedef struct _SENDCMDOUTPARAMS {
    575 	ULONG  cBufferSize;
    576 	DRIVERSTATUS  DriverStatus;
    577 	UCHAR  bBuffer[1];
    578 } SENDCMDOUTPARAMS, *PSENDCMDOUTPARAMS, *LPSENDCMDOUTPARAMS;
    579 #include <poppack.h>
    580 
    581 #define READ_ATTRIBUTES                   0xD0
    582 #define READ_THRESHOLDS                   0xD1
    583 #define ENABLE_DISABLE_AUTOSAVE           0xD2
    584 #define SAVE_ATTRIBUTE_VALUES             0xD3
    585 #define EXECUTE_OFFLINE_DIAGS             0xD4
    586 #define SMART_READ_LOG                    0xD5
    587 #define SMART_WRITE_LOG                   0xd6
    588 #define ENABLE_SMART                      0xD8
    589 #define DISABLE_SMART                     0xD9
    590 #define RETURN_SMART_STATUS               0xDA
    591 #define ENABLE_DISABLE_AUTO_OFFLINE       0xDB
    592 
    593 typedef struct _MAPPED_ADDRESS {
    594   struct _MAPPED_ADDRESS *NextMappedAddress;
    595   PVOID MappedAddress;
    596   ULONG NumberOfBytes;
    597   LARGE_INTEGER IoAddress;
    598   ULONG BusNumber;
    599 } MAPPED_ADDRESS, *PMAPPED_ADDRESS;
    600 
    601 
    602 #ifdef __cplusplus
    603 }
    604 #endif
    605 
    606 #endif /* _NTDDDISK_H_ */