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 /* Helper macro to enable gcc's extension. */ 27 #ifndef __GNU_EXTENSION 28 #ifdef __GNUC__ 29 #define __GNU_EXTENSION __extension__ 30 #else 31 #define __GNU_EXTENSION 32 #endif 33 #endif 34 35 #include "ntddstor.h" 36 37 #ifdef __cplusplus 38 extern "C" { 39 #endif 40 41 #define DD_DISK_DEVICE_NAME "\\Device\\UNKNOWN" 42 #define DD_DISK_DEVICE_NAME_U L"\\Device\\UNKNOWN" 43 44 #define IOCTL_DISK_BASE FILE_DEVICE_DISK 45 46 #define IOCTL_DISK_ARE_VOLUMES_READY \ 47 CTL_CODE(IOCTL_DISK_BASE, 0x0087, METHOD_BUFFERED, FILE_READ_ACCESS) 48 49 #define IOCTL_DISK_CHECK_VERIFY \ 50 CTL_CODE(IOCTL_DISK_BASE, 0x0200, METHOD_BUFFERED, FILE_READ_ACCESS) 51 52 #define IOCTL_DISK_CONTROLLER_NUMBER \ 53 CTL_CODE(IOCTL_DISK_BASE, 0x0011, METHOD_BUFFERED, FILE_ANY_ACCESS) 54 55 #define IOCTL_DISK_CREATE_DISK \ 56 CTL_CODE(IOCTL_DISK_BASE, 0x0016, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 57 58 #define IOCTL_DISK_DELETE_DRIVE_LAYOUT \ 59 CTL_CODE(IOCTL_DISK_BASE, 0x0040, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 60 61 #define IOCTL_DISK_FIND_NEW_DEVICES \ 62 CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS) 63 64 #define IOCTL_DISK_FORMAT_DRIVE \ 65 CTL_CODE(IOCTL_DISK_BASE, 0x00f3, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 66 67 #define IOCTL_DISK_FORMAT_TRACKS \ 68 CTL_CODE(IOCTL_DISK_BASE, 0x0006, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 69 70 #define IOCTL_DISK_FORMAT_TRACKS_EX \ 71 CTL_CODE(IOCTL_DISK_BASE, 0x000b, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 72 73 #define IOCTL_DISK_GET_CACHE_INFORMATION \ 74 CTL_CODE(IOCTL_DISK_BASE, 0x0035, METHOD_BUFFERED, FILE_READ_ACCESS) 75 76 #define IOCTL_DISK_GET_CACHE_SETTING \ 77 CTL_CODE(IOCTL_DISK_BASE, 0x0038, METHOD_BUFFERED, FILE_READ_ACCESS) 78 79 #define IOCTL_DISK_GET_CLUSTER_INFO \ 80 CTL_CODE(IOCTL_DISK_BASE, 0x0085, METHOD_BUFFERED, FILE_ANY_ACCESS) 81 82 #define IOCTL_DISK_GET_DISK_ATTRIBUTES \ 83 CTL_CODE(IOCTL_DISK_BASE, 0x003c, METHOD_BUFFERED, FILE_ANY_ACCESS) 84 85 #define IOCTL_DISK_GET_DRIVE_GEOMETRY \ 86 CTL_CODE(IOCTL_DISK_BASE, 0x0000, METHOD_BUFFERED, FILE_ANY_ACCESS) 87 88 #define IOCTL_DISK_GET_DRIVE_GEOMETRY_EX \ 89 CTL_CODE(IOCTL_DISK_BASE, 0x0028, METHOD_BUFFERED, FILE_ANY_ACCESS) 90 91 #define IOCTL_DISK_GET_DRIVE_LAYOUT \ 92 CTL_CODE(IOCTL_DISK_BASE, 0x0003, METHOD_BUFFERED, FILE_READ_ACCESS) 93 94 #define IOCTL_DISK_GET_DRIVE_LAYOUT_EX \ 95 CTL_CODE(IOCTL_DISK_BASE, 0x0014, METHOD_BUFFERED, FILE_ANY_ACCESS) 96 97 #define IOCTL_DISK_GET_MEDIA_TYPES \ 98 CTL_CODE(IOCTL_DISK_BASE, 0x0300, METHOD_BUFFERED, FILE_ANY_ACCESS) 99 100 #define IOCTL_DISK_GET_LENGTH_INFO \ 101 CTL_CODE(IOCTL_DISK_BASE, 0x0017, METHOD_BUFFERED, FILE_READ_ACCESS) 102 103 #define IOCTL_DISK_GET_PARTITION_ATTRIBUTES \ 104 CTL_CODE(IOCTL_DISK_BASE, 0x003a, METHOD_BUFFERED, FILE_ANY_ACCESS) 105 106 #define IOCTL_DISK_GET_PARTITION_INFO \ 107 CTL_CODE(IOCTL_DISK_BASE, 0x0001, METHOD_BUFFERED, FILE_READ_ACCESS) 108 109 #define IOCTL_DISK_GET_PARTITION_INFO_EX \ 110 CTL_CODE(IOCTL_DISK_BASE, 0x0012, METHOD_BUFFERED, FILE_ANY_ACCESS) 111 112 #define IOCTL_DISK_GET_PERFORMANCE_INFO \ 113 CTL_CODE(IOCTL_DISK_BASE, 0x0089, METHOD_BUFFERED, FILE_ANY_ACCESS) 114 115 #define IOCTL_DISK_GET_SAN_SETTINGS \ 116 CTL_CODE(IOCTL_DISK_BASE, 0x0080, METHOD_BUFFERED, FILE_READ_ACCESS) 117 118 #define IOCTL_DISK_GET_SNAPSHOT_INFO \ 119 CTL_CODE(IOCTL_DISK_BASE, 0x0082, METHOD_BUFFERED, FILE_READ_ACCESS) 120 121 #define IOCTL_DISK_GROW_PARTITION \ 122 CTL_CODE(IOCTL_DISK_BASE, 0x0034, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 123 124 #define IOCTL_DISK_HISTOGRAM_STRUCTURE \ 125 CTL_CODE(IOCTL_DISK_BASE, 0x000c, METHOD_BUFFERED, FILE_ANY_ACCESS) 126 127 #define IOCTL_DISK_HISTOGRAM_DATA \ 128 CTL_CODE(IOCTL_DISK_BASE, 0x000d, METHOD_BUFFERED, FILE_ANY_ACCESS) 129 130 #define IOCTL_DISK_HISTOGRAM_RESET \ 131 CTL_CODE(IOCTL_DISK_BASE, 0x000e, METHOD_BUFFERED, FILE_ANY_ACCESS) 132 133 #define IOCTL_DISK_INTERNAL_CLEAR_VERIFY \ 134 CTL_CODE(IOCTL_DISK_BASE, 0x0101, METHOD_NEITHER, FILE_ANY_ACCESS) 135 136 #define IOCTL_DISK_INTERNAL_SET_VERIFY \ 137 CTL_CODE(IOCTL_DISK_BASE, 0x0100, METHOD_NEITHER, FILE_ANY_ACCESS) 138 139 #define IOCTL_DISK_INTERNAL_SET_NOTIFY \ 140 CTL_CODE(IOCTL_DISK_BASE, 0x0102, METHOD_BUFFERED, FILE_ANY_ACCESS) 141 142 #define IOCTL_DISK_IS_CLUSTERED \ 143 CTL_CODE(IOCTL_DISK_BASE, 0x003e, METHOD_BUFFERED, FILE_ANY_ACCESS) 144 145 #define IOCTL_DISK_IS_WRITABLE \ 146 CTL_CODE(IOCTL_DISK_BASE, 0x0009, METHOD_BUFFERED, FILE_ANY_ACCESS) 147 148 #define IOCTL_DISK_LOGGING \ 149 CTL_CODE(IOCTL_DISK_BASE, 0x000a, METHOD_BUFFERED, FILE_ANY_ACCESS) 150 151 #define IOCTL_DISK_PERFORMANCE \ 152 CTL_CODE(IOCTL_DISK_BASE, 0x0008, METHOD_BUFFERED, FILE_ANY_ACCESS) 153 154 #define IOCTL_DISK_PERFORMANCE_OFF \ 155 CTL_CODE(IOCTL_DISK_BASE, 0x0018, METHOD_BUFFERED, FILE_ANY_ACCESS) 156 157 #define IOCTL_DISK_REASSIGN_BLOCKS \ 158 CTL_CODE(IOCTL_DISK_BASE, 0x0007, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 159 160 #define IOCTL_DISK_REQUEST_DATA \ 161 CTL_CODE(IOCTL_DISK_BASE, 0x0010, METHOD_BUFFERED, FILE_ANY_ACCESS) 162 163 #define IOCTL_DISK_REQUEST_STRUCTURE \ 164 CTL_CODE(IOCTL_DISK_BASE, 0x000f, METHOD_BUFFERED, FILE_ANY_ACCESS) 165 166 #define IOCTL_DISK_RESET_SNAPSHOT_INFO \ 167 CTL_CODE(IOCTL_DISK_BASE, 0x0084, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 168 169 #define IOCTL_DISK_MEDIA_REMOVAL \ 170 CTL_CODE(IOCTL_DISK_BASE, 0x0201, METHOD_BUFFERED, FILE_READ_ACCESS) 171 172 #define IOCTL_DISK_EJECT_MEDIA \ 173 CTL_CODE(IOCTL_DISK_BASE, 0x0202, METHOD_BUFFERED, FILE_READ_ACCESS) 174 175 #define IOCTL_DISK_LOAD_MEDIA \ 176 CTL_CODE(IOCTL_DISK_BASE, 0x0203, METHOD_BUFFERED, FILE_READ_ACCESS) 177 178 #define IOCTL_DISK_REASSIGN_BLOCKS_EX \ 179 CTL_CODE(IOCTL_DISK_BASE, 0x0029, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 180 181 #define IOCTL_DISK_RESERVE \ 182 CTL_CODE(IOCTL_DISK_BASE, 0x0204, METHOD_BUFFERED, FILE_READ_ACCESS) 183 184 #define IOCTL_DISK_RELEASE \ 185 CTL_CODE(IOCTL_DISK_BASE, 0x0205, METHOD_BUFFERED, FILE_READ_ACCESS) 186 187 #define IOCTL_DISK_FIND_NEW_DEVICES \ 188 CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS) 189 190 #define IOCTL_DISK_SENSE_DEVICE \ 191 CTL_CODE(IOCTL_DISK_BASE, 0x00f8, METHOD_BUFFERED, FILE_ANY_ACCESS) 192 193 #define IOCTL_DISK_SET_CACHE_INFORMATION \ 194 CTL_CODE(IOCTL_DISK_BASE, 0x0036, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 195 196 #define IOCTL_DISK_SET_CACHE_SETTING \ 197 CTL_CODE(IOCTL_DISK_BASE, 0x0039, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 198 199 #define IOCTL_DISK_SET_CLUSTER_INFO \ 200 CTL_CODE(IOCTL_DISK_BASE, 0x0086, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 201 202 #define IOCTL_DISK_SET_DISK_ATTRIBUTES \ 203 CTL_CODE(IOCTL_DISK_BASE, 0x003d, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 204 205 #define IOCTL_DISK_SET_DRIVE_LAYOUT \ 206 CTL_CODE(IOCTL_DISK_BASE, 0x0004, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 207 208 #define IOCTL_DISK_SET_DRIVE_LAYOUT_EX \ 209 CTL_CODE(IOCTL_DISK_BASE, 0x0015, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 210 211 #define IOCTL_DISK_SET_PARTITION_ATTRIBUTES \ 212 CTL_CODE(IOCTL_DISK_BASE, 0x003b, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 213 214 #define IOCTL_DISK_SET_PARTITION_INFO \ 215 CTL_CODE(IOCTL_DISK_BASE, 0x0002, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 216 217 #define IOCTL_DISK_SET_PARTITION_INFO_EX \ 218 CTL_CODE(IOCTL_DISK_BASE, 0x0013, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 219 220 #define IOCTL_DISK_SET_SAN_SETTINGS \ 221 CTL_CODE(IOCTL_DISK_BASE, 0x0081, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 222 223 #define IOCTL_DISK_SET_SNAPSHOT_INFO \ 224 CTL_CODE(IOCTL_DISK_BASE, 0x0083, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 225 226 // 227 // NTDDI_WIN2003 was an older define used in the early beta builds, which 228 // Microsoft forgot to fix in a few headers. 229 // NTDDI_WS03 is the correct term. 230 // 231 #if (NTDDI_VERSION < NTDDI_WS03) 232 #define IOCTL_DISK_GET_WRITE_CACHE_STATE \ 233 CTL_CODE(IOCTL_DISK_BASE, 0x0037, METHOD_BUFFERED, FILE_READ_ACCESS) 234 #else 235 #define OBSOLETE_DISK_GET_WRITE_CACHE_STATE \ 236 CTL_CODE(IOCTL_DISK_BASE, 0x0037, METHOD_BUFFERED, FILE_READ_ACCESS) 237 #endif 238 239 #define IOCTL_DISK_UPDATE_DRIVE_SIZE \ 240 CTL_CODE(IOCTL_DISK_BASE, 0x0032, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 241 242 #define IOCTL_DISK_UPDATE_PROPERTIES \ 243 CTL_CODE(IOCTL_DISK_BASE, 0x0050, METHOD_BUFFERED, FILE_ANY_ACCESS) 244 245 #define IOCTL_DISK_VERIFY \ 246 CTL_CODE(IOCTL_DISK_BASE, 0x0005, METHOD_BUFFERED, FILE_ANY_ACCESS) 247 248 #define IOCTL_DISK_VOLUMES_ARE_READY \ 249 CTL_CODE(IOCTL_DISK_BASE, 0x0088, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 250 251 #define IOCTL_DISK_COPY_DATA \ 252 CTL_CODE(IOCTL_DISK_BASE, 0x0019, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 253 254 #define IOCTL_DISK_SIMBAD \ 255 CTL_CODE(IOCTL_DISK_BASE, 0x0400, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 256 257 #define SMART_GET_VERSION \ 258 CTL_CODE(IOCTL_DISK_BASE, 0x0020, METHOD_BUFFERED, FILE_READ_ACCESS) 259 260 #define SMART_RCV_DRIVE_DATA \ 261 CTL_CODE(IOCTL_DISK_BASE, 0x0022, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 262 263 #define SMART_SEND_DRIVE_COMMAND \ 264 CTL_CODE(IOCTL_DISK_BASE, 0x0021, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) 265 266 #define PARTITION_ENTRY_UNUSED 0x00 267 #define PARTITION_FAT_12 0x01 268 #define PARTITION_XENIX_1 0x02 269 #define PARTITION_XENIX_2 0x03 270 #define PARTITION_FAT_16 0x04 271 #define PARTITION_EXTENDED 0x05 272 #define PARTITION_HUGE 0x06 273 #define PARTITION_IFS 0x07 274 #define PARTITION_OS2BOOTMGR 0x0A 275 #define PARTITION_FAT32 0x0B 276 #define PARTITION_FAT32_XINT13 0x0C 277 #define PARTITION_XINT13 0x0E 278 #define PARTITION_XINT13_EXTENDED 0x0F 279 #define PARTITION_MSFT_RECOVERY 0x27 280 #define PARTITION_MAIN_OS 0x28 281 #define PARTIITON_OS_DATA 0x29 282 #define PARTITION_PRE_INSTALLED 0x2a 283 #define PARTITION_BSP 0x2b 284 #define PARTITION_DPP 0x2c 285 #define PARTITION_WINDOWS_SYSTEM 0x2d 286 #define PARTITION_PREP 0x41 287 #define PARTITION_LDM 0x42 288 #define PARTITION_DM 0x54 289 #define PARTITION_EZDRIVE 0x55 290 #define PARTITION_UNIX 0x63 291 #define PARTITION_SPACES_DATA 0xD7 292 #define PARTITION_SPACES 0xE7 293 #define PARTITION_GPT 0xEE 294 #define PARTITION_SYSTEM 0xEF 295 296 #define VALID_NTFT 0xC0 297 #define PARTITION_NTFT 0x80 298 #ifdef __REACTOS__ 299 #define PARTITION_OLD_LINUX 0x43 300 #define PARTITION_LINUX 0x83 301 #define PARTITION_ISO9660 0x96 302 #define PARTITION_FREEBSD 0xA5 303 #define PARTITION_OPENBSD 0xA6 304 #define PARTITION_NETBSD 0xA9 305 #endif 306 307 #define IsFTPartition( PartitionType ) \ 308 ((((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT_12)) || \ 309 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_HUGE)) || \ 310 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_IFS)) || \ 311 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32)) || \ 312 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32_XINT13)) || \ 313 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_XINT13))) 314 315 316 #define IsContainerPartition(PartitionType) \ 317 (((PartitionType) == PARTITION_EXTENDED) || \ 318 ((PartitionType) == PARTITION_XINT13_EXTENDED)) 319 320 #ifdef __REACTOS__ 321 #define IsRecognizedPartition(PartitionType) ( \ 322 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT_12)) || \ 323 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_HUGE)) || \ 324 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_IFS)) || \ 325 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32)) || \ 326 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32_XINT13)) || \ 327 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_XINT13)) || \ 328 ((PartitionType) == PARTITION_FAT_12) || \ 329 ((PartitionType) == PARTITION_FAT_16) || \ 330 ((PartitionType) == PARTITION_HUGE) || \ 331 ((PartitionType) == PARTITION_IFS) || \ 332 ((PartitionType) == PARTITION_FAT32) || \ 333 ((PartitionType) == PARTITION_FAT32_XINT13) || \ 334 ((PartitionType) == PARTITION_XINT13) || \ 335 ((PartitionType) == PARTITION_LINUX) || \ 336 ((PartitionType) == PARTITION_OLD_LINUX) || \ 337 ((PartitionType) == PARTITION_ISO9660) || \ 338 ((PartitionType) == PARTITION_FREEBSD) || \ 339 ((PartitionType) == PARTITION_OPENBSD) || \ 340 ((PartitionType) == PARTITION_NETBSD)) 341 #else 342 #define IsRecognizedPartition(PartitionType) ( \ 343 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT_12)) || \ 344 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_HUGE)) || \ 345 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_IFS)) || \ 346 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32)) || \ 347 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32_XINT13)) || \ 348 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_XINT13)) || \ 349 ((PartitionType) == PARTITION_FAT_12) || \ 350 ((PartitionType) == PARTITION_FAT_16) || \ 351 ((PartitionType) == PARTITION_HUGE) || \ 352 ((PartitionType) == PARTITION_IFS) || \ 353 ((PartitionType) == PARTITION_FAT32) || \ 354 ((PartitionType) == PARTITION_FAT32_XINT13) || \ 355 ((PartitionType) == PARTITION_XINT13)) 356 #endif 357 358 #if (_WIN32_WINNT >= 0x0500) 359 /* Actually it should be > 0x0500, since this is not present in Windows 2000; 360 * however we keep >= 0x0500 for compatibility with MS PSDK. */ 361 362 #define GPT_ATTRIBUTE_PLATFORM_REQUIRED 0x00000001 363 #define GPT_BASIC_DATA_ATTRIBUTE_READ_ONLY 0x10000000 364 #define GPT_BASIC_DATA_ATTRIBUTE_SHADOW_COPY 0x20000000 365 #define GPT_BASIC_DATA_ATTRIBUTE_HIDDEN 0x40000000 366 #define GPT_BASIC_DATA_ATTRIBUTE_NO_DRIVE_LETTER 0x80000000 367 #endif 368 369 #define WMI_DISK_GEOMETRY_GUID \ 370 {0x25007f51, 0x57c2, 0x11d1, {0xa5, 0x28, 0x0, 0xa0, 0xc9, 0x6, 0x29, 0x10}} 371 372 typedef USHORT BAD_TRACK_NUMBER; 373 typedef USHORT *PBAD_TRACK_NUMBER; 374 375 typedef enum _MEDIA_TYPE { 376 Unknown, 377 F5_1Pt2_512, 378 F3_1Pt44_512, 379 F3_2Pt88_512, 380 F3_20Pt8_512, 381 F3_720_512, 382 F5_360_512, 383 F5_320_512, 384 F5_320_1024, 385 F5_180_512, 386 F5_160_512, 387 RemovableMedia, 388 FixedMedia, 389 F3_120M_512, 390 F3_640_512, 391 F5_640_512, 392 F5_720_512, 393 F3_1Pt2_512, 394 F3_1Pt23_1024, 395 F5_1Pt23_1024, 396 F3_128Mb_512, 397 F3_230Mb_512, 398 F8_256_128, 399 F3_200Mb_512, 400 F3_240M_512, 401 F3_32M_512 402 } MEDIA_TYPE, *PMEDIA_TYPE; 403 404 typedef struct _DISK_GEOMETRY { 405 LARGE_INTEGER Cylinders; 406 MEDIA_TYPE MediaType; 407 ULONG TracksPerCylinder; 408 ULONG SectorsPerTrack; 409 ULONG BytesPerSector; 410 } DISK_GEOMETRY, *PDISK_GEOMETRY; 411 412 typedef struct _PARTITION_INFORMATION { 413 LARGE_INTEGER StartingOffset; 414 LARGE_INTEGER PartitionLength; 415 ULONG HiddenSectors; 416 ULONG PartitionNumber; 417 UCHAR PartitionType; 418 BOOLEAN BootIndicator; 419 BOOLEAN RecognizedPartition; 420 BOOLEAN RewritePartition; 421 } PARTITION_INFORMATION, *PPARTITION_INFORMATION; 422 423 typedef struct _DRIVE_LAYOUT_INFORMATION { 424 ULONG PartitionCount; 425 ULONG Signature; 426 PARTITION_INFORMATION PartitionEntry[1]; 427 } DRIVE_LAYOUT_INFORMATION, *PDRIVE_LAYOUT_INFORMATION; 428 429 typedef struct _SET_PARTITION_INFORMATION { 430 UCHAR PartitionType; 431 } SET_PARTITION_INFORMATION, *PSET_PARTITION_INFORMATION; 432 433 #if (_WIN32_WINNT >= 0x0500) 434 /* Actually it should be > 0x0500, since this is not present in Windows 2000; 435 * however we keep >= 0x0500 for compatibility with MS PSDK. */ 436 437 typedef enum _PARTITION_STYLE { 438 PARTITION_STYLE_MBR, 439 PARTITION_STYLE_GPT, 440 PARTITION_STYLE_RAW, 441 #ifdef __REACTOS__ 442 /* ReactOS custom partition handlers */ 443 PARTITION_STYLE_BRFR = 128 /* Xbox-BRFR partitioning scheme */ 444 #endif 445 } PARTITION_STYLE; 446 447 typedef struct _CREATE_DISK_GPT 448 { 449 GUID DiskId; 450 ULONG MaxPartitionCount; 451 } CREATE_DISK_GPT, *PCREATE_DISK_GPT; 452 453 typedef struct _CREATE_DISK_MBR 454 { 455 ULONG Signature; 456 } CREATE_DISK_MBR, *PCREATE_DISK_MBR; 457 458 typedef struct _CREATE_DISK 459 { 460 PARTITION_STYLE PartitionStyle; 461 union { 462 CREATE_DISK_MBR Mbr; 463 CREATE_DISK_GPT Gpt; 464 }; 465 } CREATE_DISK, *PCREATE_DISK; 466 467 typedef enum _DETECTION_TYPE { 468 DetectNone, 469 DetectInt13, 470 DetectExInt13 471 } DETECTION_TYPE; 472 473 typedef struct _DISK_INT13_INFO { 474 USHORT DriveSelect; 475 ULONG MaxCylinders; 476 USHORT SectorsPerTrack; 477 USHORT MaxHeads; 478 USHORT NumberDrives; 479 } DISK_INT13_INFO, *PDISK_INT13_INFO; 480 481 typedef struct _DISK_EX_INT13_INFO { 482 USHORT ExBufferSize; 483 USHORT ExFlags; 484 ULONG ExCylinders; 485 ULONG ExHeads; 486 ULONG ExSectorsPerTrack; 487 ULONG64 ExSectorsPerDrive; 488 USHORT ExSectorSize; 489 USHORT ExReserved; 490 } DISK_EX_INT13_INFO, *PDISK_EX_INT13_INFO; 491 492 typedef struct _DISK_DETECTION_INFO { 493 ULONG SizeOfDetectInfo; 494 DETECTION_TYPE DetectionType; 495 _ANONYMOUS_UNION union { 496 _ANONYMOUS_STRUCT struct { 497 DISK_INT13_INFO Int13; 498 DISK_EX_INT13_INFO ExInt13; 499 } DUMMYSTRUCTNAME; 500 } DUMMYUNIONNAME; 501 } DISK_DETECTION_INFO, *PDISK_DETECTION_INFO; 502 503 typedef struct _DISK_PARTITION_INFO { 504 ULONG SizeOfPartitionInfo; 505 PARTITION_STYLE PartitionStyle; 506 _ANONYMOUS_UNION union { 507 struct { 508 ULONG Signature; 509 ULONG CheckSum; 510 } Mbr; 511 struct { 512 GUID DiskId; 513 } Gpt; 514 } DUMMYUNIONNAME; 515 } DISK_PARTITION_INFO, *PDISK_PARTITION_INFO; 516 517 typedef struct _DISK_GEOMETRY_EX { 518 DISK_GEOMETRY Geometry; 519 LARGE_INTEGER DiskSize; 520 UCHAR Data[1]; 521 } DISK_GEOMETRY_EX, *PDISK_GEOMETRY_EX; 522 523 #if (NTDDI_VERSION < NTDDI_WS03) 524 #define DiskGeometryGetPartition(Geometry) \ 525 ((PDISK_PARTITION_INFO)((Geometry) + 1)) 526 527 #define DiskGeometryGetDetect(Geometry)\ 528 ((PDISK_DETECTION_INFO)(((PBYTE)DiskGeometryGetPartition(Geometry) + \ 529 DiskGeometryGetPartition(Geometry)->SizeOfPartitionInfo))) 530 #else 531 #define DiskGeometryGetPartition(Geometry) \ 532 ((PDISK_PARTITION_INFO)((Geometry)->Data)) 533 534 #define DiskGeometryGetDetect(Geometry)\ 535 ((PDISK_DETECTION_INFO)(((ULONG_PTR)DiskGeometryGetPartition(Geometry) + \ 536 DiskGeometryGetPartition(Geometry)->SizeOfPartitionInfo))) 537 #endif 538 539 typedef struct _PARTITION_INFORMATION_GPT { 540 GUID PartitionType; 541 GUID PartitionId; 542 ULONG64 Attributes; 543 WCHAR Name [36]; 544 } PARTITION_INFORMATION_GPT, *PPARTITION_INFORMATION_GPT; 545 546 typedef struct _PARTITION_INFORMATION_MBR { 547 UCHAR PartitionType; 548 BOOLEAN BootIndicator; 549 BOOLEAN RecognizedPartition; 550 ULONG HiddenSectors; 551 } PARTITION_INFORMATION_MBR, *PPARTITION_INFORMATION_MBR; 552 553 typedef struct _PARTITION_INFORMATION_EX { 554 PARTITION_STYLE PartitionStyle; 555 LARGE_INTEGER StartingOffset; 556 LARGE_INTEGER PartitionLength; 557 ULONG PartitionNumber; 558 BOOLEAN RewritePartition; 559 #if (NTDDI_VERSION >= NTDDI_WIN10_RS3) 560 BOOLEAN IsServicePartition; 561 #endif 562 _ANONYMOUS_UNION union { 563 PARTITION_INFORMATION_MBR Mbr; 564 PARTITION_INFORMATION_GPT Gpt; 565 } DUMMYUNIONNAME; 566 } PARTITION_INFORMATION_EX, *PPARTITION_INFORMATION_EX; 567 568 typedef struct _DRIVE_LAYOUT_INFORMATION_GPT { 569 GUID DiskId; 570 LARGE_INTEGER StartingUsableOffset; 571 LARGE_INTEGER UsableLength; 572 ULONG MaxPartitionCount; 573 } DRIVE_LAYOUT_INFORMATION_GPT, *PDRIVE_LAYOUT_INFORMATION_GPT; 574 575 typedef struct _DRIVE_LAYOUT_INFORMATION_MBR { 576 ULONG Signature; 577 #if (NTDDI_VERSION >= NTDDI_WIN10_RS1) 578 ULONG CheckSum; 579 #endif 580 } DRIVE_LAYOUT_INFORMATION_MBR, *PDRIVE_LAYOUT_INFORMATION_MBR; 581 582 typedef struct _DRIVE_LAYOUT_INFORMATION_EX { 583 ULONG PartitionStyle; 584 ULONG PartitionCount; 585 __GNU_EXTENSION union { 586 DRIVE_LAYOUT_INFORMATION_MBR Mbr; 587 DRIVE_LAYOUT_INFORMATION_GPT Gpt; 588 }; 589 PARTITION_INFORMATION_EX PartitionEntry[1]; 590 } DRIVE_LAYOUT_INFORMATION_EX, *PDRIVE_LAYOUT_INFORMATION_EX; 591 592 typedef SET_PARTITION_INFORMATION SET_PARTITION_INFORMATION_MBR; 593 typedef PARTITION_INFORMATION_GPT SET_PARTITION_INFORMATION_GPT; 594 595 typedef struct _SET_PARTITION_INFORMATION_EX { 596 PARTITION_STYLE PartitionStyle; 597 _ANONYMOUS_UNION union { 598 SET_PARTITION_INFORMATION_MBR Mbr; 599 SET_PARTITION_INFORMATION_GPT Gpt; 600 } DUMMYUNIONNAME; 601 } SET_PARTITION_INFORMATION_EX, *PSET_PARTITION_INFORMATION_EX; 602 603 #endif // (_WIN32_WINNT >= 0x0500) 604 605 typedef struct _DISK_PERFORMANCE { 606 LARGE_INTEGER BytesRead; 607 LARGE_INTEGER BytesWritten; 608 LARGE_INTEGER ReadTime; 609 LARGE_INTEGER WriteTime; 610 LARGE_INTEGER IdleTime; 611 ULONG ReadCount; 612 ULONG WriteCount; 613 ULONG QueueDepth; 614 ULONG SplitCount; 615 LARGE_INTEGER QueryTime; 616 ULONG StorageDeviceNumber; 617 WCHAR StorageManagerName[8]; 618 } DISK_PERFORMANCE, *PDISK_PERFORMANCE; 619 620 typedef struct _FORMAT_EX_PARAMETERS { 621 MEDIA_TYPE MediaType; 622 ULONG StartCylinderNumber; 623 ULONG EndCylinderNumber; 624 ULONG StartHeadNumber; 625 ULONG EndHeadNumber; 626 USHORT FormatGapLength; 627 USHORT SectorsPerTrack; 628 USHORT SectorNumber[1]; 629 } FORMAT_EX_PARAMETERS, *PFORMAT_EX_PARAMETERS; 630 631 typedef struct _FORMAT_PARAMETERS { 632 MEDIA_TYPE MediaType; 633 ULONG StartCylinderNumber; 634 ULONG EndCylinderNumber; 635 ULONG StartHeadNumber; 636 ULONG EndHeadNumber; 637 } FORMAT_PARAMETERS, *PFORMAT_PARAMETERS; 638 639 typedef struct _GET_LENGTH_INFORMATION { 640 LARGE_INTEGER Length; 641 } GET_LENGTH_INFORMATION, *PGET_LENGTH_INFORMATION; 642 643 typedef struct _REASSIGN_BLOCKS { 644 USHORT Reserved; 645 USHORT Count; 646 ULONG BlockNumber[1]; 647 } REASSIGN_BLOCKS, *PREASSIGN_BLOCKS; 648 649 typedef struct _REASSIGN_BLOCKS_EX { 650 USHORT Reserved; 651 USHORT Count; 652 LARGE_INTEGER BlockNumber[1]; 653 } REASSIGN_BLOCKS_EX, *PREASSIGN_BLOCKS_EX; 654 655 typedef struct _VERIFY_INFORMATION { 656 LARGE_INTEGER StartingOffset; 657 ULONG Length; 658 } VERIFY_INFORMATION, *PVERIFY_INFORMATION; 659 660 /* GETVERSIONINPARAMS.fCapabilities constants */ 661 #define CAP_ATA_ID_CMD 1 662 #define CAP_ATAPI_ID_CMD 2 663 #define CAP_SMART_CMD 4 664 665 typedef struct _GETVERSIONINPARAMS { 666 UCHAR bVersion; 667 UCHAR bRevision; 668 UCHAR bReserved; 669 UCHAR bIDEDeviceMap; 670 ULONG fCapabilities; 671 ULONG dwReserved[4]; 672 } GETVERSIONINPARAMS, *PGETVERSIONINPARAMS, *LPGETVERSIONINPARAMS; 673 674 /* IDEREGS.bCommandReg constants */ 675 #define ATAPI_ID_CMD 0xA1 676 #define ID_CMD 0xEC 677 #define SMART_CMD 0xB0 678 679 #define SMART_CYL_LOW 0x4F 680 #define SMART_CYL_HI 0xC2 681 682 typedef struct _IDEREGS { 683 UCHAR bFeaturesReg; 684 UCHAR bSectorCountReg; 685 UCHAR bSectorNumberReg; 686 UCHAR bCylLowReg; 687 UCHAR bCylHighReg; 688 UCHAR bDriveHeadReg; 689 UCHAR bCommandReg; 690 UCHAR bReserved; 691 } IDEREGS, *PIDEREGS, *LPIDEREGS; 692 693 #include <pshpack1.h> 694 typedef struct _SENDCMDINPARAMS { 695 ULONG cBufferSize; 696 IDEREGS irDriveRegs; 697 UCHAR bDriveNumber; 698 UCHAR bReserved[3]; 699 ULONG dwReserved[4]; 700 UCHAR bBuffer[1]; 701 } SENDCMDINPARAMS, *PSENDCMDINPARAMS, *LPSENDCMDINPARAMS; 702 #include <poppack.h> 703 704 /* DRIVERSTATUS.bDriverError constants */ 705 #define SMART_NO_ERROR 0 706 #define SMART_IDE_ERROR 1 707 #define SMART_INVALID_FLAG 2 708 #define SMART_INVALID_COMMAND 3 709 #define SMART_INVALID_BUFFER 4 710 #define SMART_INVALID_DRIVE 5 711 #define SMART_INVALID_IOCTL 6 712 #define SMART_ERROR_NO_MEM 7 713 #define SMART_INVALID_REGISTER 8 714 #define SMART_NOT_SUPPORTED 9 715 #define SMART_NO_IDE_DEVICE 10 716 717 #define SMART_OFFLINE_ROUTINE_OFFLINE 0 718 #define SMART_SHORT_SELFTEST_OFFLINE 1 719 #define SMART_EXTENDED_SELFTEST_OFFLINE 2 720 #define SMART_ABORT_OFFLINE_SELFTEST 127 721 #define SMART_SHORT_SELFTEST_CAPTIVE 129 722 #define SMART_EXTENDED_SELFTEST_CAPTIVE 130 723 724 typedef struct _DRIVERSTATUS { 725 UCHAR bDriverError; 726 UCHAR bIDEError; 727 UCHAR bReserved[2]; 728 ULONG dwReserved[2]; 729 } DRIVERSTATUS, *PDRIVERSTATUS, *LPDRIVERSTATUS; 730 731 #define READ_ATTRIBUTE_BUFFER_SIZE 512 732 #define IDENTIFY_BUFFER_SIZE 512 733 #define READ_THRESHOLD_BUFFER_SIZE 512 734 #define SMART_LOG_SECTOR_SIZE 512 735 736 #include <pshpack1.h> 737 typedef struct _SENDCMDOUTPARAMS { 738 ULONG cBufferSize; 739 DRIVERSTATUS DriverStatus; 740 UCHAR bBuffer[1]; 741 } SENDCMDOUTPARAMS, *PSENDCMDOUTPARAMS, *LPSENDCMDOUTPARAMS; 742 #include <poppack.h> 743 744 #define READ_ATTRIBUTES 0xD0 745 #define READ_THRESHOLDS 0xD1 746 #define ENABLE_DISABLE_AUTOSAVE 0xD2 747 #define SAVE_ATTRIBUTE_VALUES 0xD3 748 #define EXECUTE_OFFLINE_DIAGS 0xD4 749 #define SMART_READ_LOG 0xD5 750 #define SMART_WRITE_LOG 0xd6 751 #define ENABLE_SMART 0xD8 752 #define DISABLE_SMART 0xD9 753 #define RETURN_SMART_STATUS 0xDA 754 #define ENABLE_DISABLE_AUTO_OFFLINE 0xDB 755 756 typedef struct _MAPPED_ADDRESS { 757 struct _MAPPED_ADDRESS *NextMappedAddress; 758 PVOID MappedAddress; 759 ULONG NumberOfBytes; 760 LARGE_INTEGER IoAddress; 761 ULONG BusNumber; 762 } MAPPED_ADDRESS, *PMAPPED_ADDRESS; 763 764 765 #if (_WIN32_WINNT >= 0x0500) 766 767 typedef enum { 768 EqualPriority, 769 KeepPrefetchedData, 770 KeepReadData 771 } DISK_CACHE_RETENTION_PRIORITY; 772 773 typedef enum _DISK_WRITE_CACHE_STATE { 774 DiskWriteCacheNormal, 775 DiskWriteCacheForceDisable, 776 DiskWriteCacheDisableNotSupported 777 } DISK_WRITE_CACHE_STATE, *PDISK_WRITE_CACHE_STATE; 778 779 780 typedef struct _DISK_CACHE_INFORMATION 781 { 782 BOOLEAN ParametersSavable; 783 BOOLEAN ReadCacheEnabled; 784 BOOLEAN WriteCacheEnabled; 785 DISK_CACHE_RETENTION_PRIORITY ReadRetentionPriority; 786 DISK_CACHE_RETENTION_PRIORITY WriteRetentionPriority; 787 USHORT DisablePrefetchTransferLength; 788 BOOLEAN PrefetchScalar; 789 union { 790 struct { 791 USHORT Minimum; 792 USHORT Maximum; 793 USHORT MaximumBlocks; 794 } ScalarPrefetch; 795 796 struct { 797 USHORT Minimum; 798 USHORT Maximum; 799 } BlockPrefetch; 800 }; 801 802 } DISK_CACHE_INFORMATION, *PDISK_CACHE_INFORMATION; 803 804 typedef struct _DISK_GROW_PARTITION { 805 ULONG PartitionNumber; 806 LARGE_INTEGER BytesToGrow; 807 } DISK_GROW_PARTITION, *PDISK_GROW_PARTITION; 808 #endif 809 810 // for IOCTL_DISK_CONTROLLER_NUMBER 811 812 typedef struct _DISK_CONTROLLER_NUMBER { 813 ULONG ControllerNumber; 814 ULONG DiskNumber; 815 } DISK_CONTROLLER_NUMBER, *PDISK_CONTROLLER_NUMBER; 816 817 // for IOCTL_DISK_COPY_DATA 818 819 typedef struct _DISK_COPY_DATA_PARAMETERS { 820 LARGE_INTEGER SourceOffset; 821 LARGE_INTEGER DestinationOffset; 822 LARGE_INTEGER CopyLength; 823 ULONGLONG Reserved; 824 } DISK_COPY_DATA_PARAMETERS, *PDISK_COPY_DATA_PARAMETERS; 825 826 // for IOCTL_DISK_GET_CACHE_SETTING and IOCTL_DISK_SET_CACHE_SETTING 827 828 typedef enum _DISK_CACHE_STATE { 829 DiskCacheNormal, 830 DiskCacheWriteThroughNotSupported, 831 DiskCacheModifyUnsuccessful 832 } DISK_CACHE_STATE, *PDISK_CACHE_STATE; 833 834 typedef struct _DISK_CACHE_SETTING { 835 ULONG Version; 836 DISK_CACHE_STATE State; 837 BOOLEAN IsPowerProtected; 838 } DISK_CACHE_SETTING, *PDISK_CACHE_SETTING; 839 840 #if (NTDDI_VERSION >= NTDDI_VISTA) 841 842 // for IOCTL_DISK_GET_PARTITION_ATTRIBUTES and IOCTL_DISK_SET_PARTITION_ATTRIBUTES 843 844 typedef struct _GET_PARTITION_ATTRIBUTES { 845 ULONG Version; 846 ULONG Reserved1; 847 ULONGLONG Attributes; 848 } GET_PARTITION_ATTRIBUTES, *PGET_PARTITION_ATTRIBUTES; 849 850 typedef struct _SET_PARTITION_ATTRIBUTES { 851 ULONG Version; 852 BOOLEAN Persist; 853 BOOLEAN Reserved1[3]; 854 ULONGLONG Attributes; 855 ULONGLONG AttributesMask; 856 } SET_PARTITION_ATTRIBUTES, *PSET_PARTITION_ATTRIBUTES; 857 858 // for IOCTL_DISK_GET_DISK_ATTRIBUTES and IOCTL_DISK_SET_DISK_ATTRIBUTES 859 860 #define DISK_ATTRIBUTE_OFFLINE 0x0000000000000001 861 #define DISK_ATTRIBUTE_READ_ONLY 0x0000000000000002 862 #define DISK_ATTRIBUTE_HIDDEN 0x0000000000000004 863 #define DISK_ATTRIBUTE_MAINTENANCE 0x0000000000000008 864 #define DISK_ATTRIBUTE_SPACES_BYPASS 0x0000000000000010 865 866 typedef struct _GET_DISK_ATTRIBUTES { 867 ULONG Version; 868 ULONG Reserved1; 869 ULONGLONG Attributes; 870 } GET_DISK_ATTRIBUTES, *PGET_DISK_ATTRIBUTES; 871 872 typedef struct _SET_DISK_ATTRIBUTES { 873 ULONG Version; 874 BOOLEAN Persist; 875 BOOLEAN RelinquishOwnership; 876 BOOLEAN Reserved1[2]; 877 ULONGLONG Attributes; 878 ULONGLONG AttributesMask; 879 GUID Owner; 880 } SET_DISK_ATTRIBUTES, *PSET_DISK_ATTRIBUTES; 881 882 883 // for IOCTL_DISK_GET_SAN_SETTINGS and IOCTL_DISK_SET_SAN_SETTINGS 884 885 typedef enum _DISK_SAN_POLICY { 886 DiskSanPolicyUnknown, 887 DiskSanPolicyOnline, 888 DiskSanPolicyOfflineShared, 889 DiskSanPolicyOffline, 890 DiskSanPolicyOfflineInternal, 891 DiskSanPolicyMax 892 } DISK_SAN_POLICY, *PDISK_SAN_POLICY; 893 894 typedef struct _DISK_SAN_SETTINGS { 895 ULONG Version; 896 DISK_SAN_POLICY SanPolicy; 897 } DISK_SAN_SETTINGS, *PDISK_SAN_SETTINGS; 898 899 // for IOCTL_DISK_GET_SNAPSHOT_INFO and IOCTL_DISK_SET_SNAPSHOT_INFO 900 typedef enum _DISK_SNAPSHOT_STATE { 901 DiskSnapshotNormalDisk, 902 DiskSnapshotSnapshotCheckRequired, 903 DiskSnapshotPreSnapshot, 904 DiskSnapshotSnapshotDisk 905 } DISK_SNAPSHOT_STATE, *PDISK_SNAPSHOT_STATE; 906 907 typedef struct _DISK_SNAPSHOT_INFO { 908 ULONG Version; 909 DISK_SNAPSHOT_STATE State; 910 GUID SnapshotSetId; 911 GUID SnapshotId; 912 GUID LunId; 913 LARGE_INTEGER CreationTimeStamp; 914 ULONG ImportCount; 915 ULONG Flags; 916 ULONG AdditionalDataSize; 917 UCHAR AdditionalData[ANYSIZE_ARRAY]; 918 } DISK_SNAPSHOT_INFO, *PDISK_SNAPSHOT_INFO; 919 #endif /* NTDDI_VERSION >= NTDDI_VISTA */ 920 921 #if (NTDDI_VERSION >= NTDDI_WIN8) 922 923 // for IOCTL_DISK_GET_CLUSTER_INFO and IOCTL_DISK_SET_CLUSTER_INFO 924 925 #define DISK_CLUSTER_FLAG_ENABLED 0x0000000000000001 926 #define DISK_CLUSTER_FLAG_CSV 0x0000000000000002 927 #define DISK_CLUSTER_FLAG_IN_MAINTENANCE 0x0000000000000004 928 #define DISK_CLUSTER_FLAG_PNP_ARRIVAL_COMPLETE 0x0000000000000008 929 930 typedef struct _DISK_CLUSTER_INFO { 931 ULONG Version; 932 ULONGLONG Flags; 933 ULONGLONG FlagsMask; 934 BOOLEAN Notify; 935 } DISK_CLUSTER_INFO, *PDISK_CLUSTER_INFO; 936 937 // for IOCTL_DISK_GET_PERFORMANCE_INFO 938 939 typedef enum _DISK_PERFORMANCE_TYPE { 940 DiskPerformanceTypeAllPriority, 941 DiskPerformanceTypeNonLowPriority, 942 DiskPerformanceTypeMax 943 } DISK_PERFORMANCE_TYPE, *PDISK_PERFORMANCE_TYPE; 944 945 typedef struct _DISK_PERFORMANCE_PARAMETERS { 946 ULONG Version; 947 DISK_PERFORMANCE_TYPE Type; 948 } DISK_PERFORMANCE_PARAMETERS, *PDISK_PERFORMANCE_PARAMETERS; 949 950 typedef struct _DISK_PERFORMANCE_INFO { 951 ULONG Version; 952 DISK_PERFORMANCE_TYPE Type; 953 LARGE_INTEGER QueryTime; 954 LARGE_INTEGER BytesRead; 955 LARGE_INTEGER BytesWritten; 956 LARGE_INTEGER ReadTime; 957 LARGE_INTEGER WriteTime; 958 LARGE_INTEGER FlushTime; 959 LARGE_INTEGER IdleTime; 960 ULONG ReadCount; 961 ULONG WriteCount; 962 ULONG FlushCount; 963 ULONG QueueDepth; 964 ULONG SplitCount; 965 } DISK_PERFORMANCE_INFO, *PDISK_PERFORMANCE_INFO; 966 967 #endif /* NTDDI_VERSION >= NTDDI_WIN8 */ 968 969 970 #ifdef __cplusplus 971 } 972 #endif 973 974 #endif /* _NTDDDISK_H_ */ 975