4 * Disk IOCTL interface.
6 * This file is part of the w32api package.
9 * Created by Casper S. Hornstrup <chorns@users.sourceforge.net>
11 * THIS SOFTWARE IS NOT COPYRIGHTED
13 * This source code is offered for use in the public domain. You may
14 * use, modify or distribute it freely.
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.
26 /* Helper macro to enable gcc's extension. */
27 #ifndef __GNU_EXTENSION
29 #define __GNU_EXTENSION __extension__
31 #define __GNU_EXTENSION
41 #define DD_DISK_DEVICE_NAME "\\Device\\UNKNOWN"
42 #define DD_DISK_DEVICE_NAME_U L"\\Device\\UNKNOWN"
44 #define IOCTL_DISK_BASE FILE_DEVICE_DISK
46 #define IOCTL_DISK_CHECK_VERIFY \
47 CTL_CODE(IOCTL_DISK_BASE, 0x0200, METHOD_BUFFERED, FILE_READ_ACCESS)
49 #define IOCTL_DISK_CONTROLLER_NUMBER \
50 CTL_CODE(IOCTL_DISK_BASE, 0x0011, METHOD_BUFFERED, FILE_ANY_ACCESS)
52 #define IOCTL_DISK_CREATE_DISK \
53 CTL_CODE(IOCTL_DISK_BASE, 0x0016, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
55 #define IOCTL_DISK_DELETE_DRIVE_LAYOUT \
56 CTL_CODE(IOCTL_DISK_BASE, 0x0040, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
58 #define IOCTL_DISK_FIND_NEW_DEVICES \
59 CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS)
61 #define IOCTL_DISK_FORMAT_TRACKS \
62 CTL_CODE(IOCTL_DISK_BASE, 0x0006, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
64 #define IOCTL_DISK_FORMAT_TRACKS_EX \
65 CTL_CODE(IOCTL_DISK_BASE, 0x000b, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
67 #define IOCTL_DISK_GET_CACHE_INFORMATION \
68 CTL_CODE(IOCTL_DISK_BASE, 0x0035, METHOD_BUFFERED, FILE_READ_ACCESS)
70 #define IOCTL_DISK_GET_DRIVE_GEOMETRY \
71 CTL_CODE(IOCTL_DISK_BASE, 0x0000, METHOD_BUFFERED, FILE_ANY_ACCESS)
73 #define IOCTL_DISK_GET_DRIVE_GEOMETRY_EX \
74 CTL_CODE(IOCTL_DISK_BASE, 0x0028, METHOD_BUFFERED, FILE_ANY_ACCESS)
76 #define IOCTL_DISK_GET_DRIVE_LAYOUT \
77 CTL_CODE(IOCTL_DISK_BASE, 0x0003, METHOD_BUFFERED, FILE_READ_ACCESS)
79 #define IOCTL_DISK_GET_DRIVE_LAYOUT_EX \
80 CTL_CODE(IOCTL_DISK_BASE, 0x0014, METHOD_BUFFERED, FILE_ANY_ACCESS)
82 #define IOCTL_DISK_GET_MEDIA_TYPES \
83 CTL_CODE(IOCTL_DISK_BASE, 0x0300, METHOD_BUFFERED, FILE_ANY_ACCESS)
85 #define IOCTL_DISK_GET_LENGTH_INFO \
86 CTL_CODE(IOCTL_DISK_BASE, 0x0017, METHOD_BUFFERED, FILE_READ_ACCESS)
88 #define IOCTL_DISK_GET_PARTITION_INFO \
89 CTL_CODE(IOCTL_DISK_BASE, 0x0001, METHOD_BUFFERED, FILE_READ_ACCESS)
91 #define IOCTL_DISK_GET_PARTITION_INFO_EX \
92 CTL_CODE(IOCTL_DISK_BASE, 0x0012, METHOD_BUFFERED, FILE_ANY_ACCESS)
94 #define IOCTL_DISK_GROW_PARTITION \
95 CTL_CODE(IOCTL_DISK_BASE, 0x0034, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
97 #define IOCTL_DISK_HISTOGRAM_STRUCTURE \
98 CTL_CODE(IOCTL_DISK_BASE, 0x000c, METHOD_BUFFERED, FILE_ANY_ACCESS)
100 #define IOCTL_DISK_HISTOGRAM_DATA \
101 CTL_CODE(IOCTL_DISK_BASE, 0x000d, METHOD_BUFFERED, FILE_ANY_ACCESS)
103 #define IOCTL_DISK_HISTOGRAM_RESET \
104 CTL_CODE(IOCTL_DISK_BASE, 0x000e, METHOD_BUFFERED, FILE_ANY_ACCESS)
106 #define IOCTL_DISK_INTERNAL_CLEAR_VERIFY \
107 CTL_CODE(IOCTL_DISK_BASE, 0x0101, METHOD_NEITHER, FILE_ANY_ACCESS)
109 #define IOCTL_DISK_INTERNAL_SET_VERIFY \
110 CTL_CODE(IOCTL_DISK_BASE, 0x0100, METHOD_NEITHER, FILE_ANY_ACCESS)
112 #define IOCTL_DISK_INTERNAL_SET_NOTIFY \
113 CTL_CODE(IOCTL_DISK_BASE, 0x0102, METHOD_BUFFERED, FILE_ANY_ACCESS)
115 #define IOCTL_DISK_IS_WRITABLE \
116 CTL_CODE(IOCTL_DISK_BASE, 0x0009, METHOD_BUFFERED, FILE_ANY_ACCESS)
118 #define IOCTL_DISK_LOGGING \
119 CTL_CODE(IOCTL_DISK_BASE, 0x000a, METHOD_BUFFERED, FILE_ANY_ACCESS)
121 #define IOCTL_DISK_PERFORMANCE \
122 CTL_CODE(IOCTL_DISK_BASE, 0x0008, METHOD_BUFFERED, FILE_ANY_ACCESS)
124 #define IOCTL_DISK_PERFORMANCE_OFF \
125 CTL_CODE(IOCTL_DISK_BASE, 0x0018, METHOD_BUFFERED, FILE_ANY_ACCESS)
127 #define IOCTL_DISK_REASSIGN_BLOCKS \
128 CTL_CODE(IOCTL_DISK_BASE, 0x0007, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
130 #define IOCTL_DISK_REQUEST_DATA \
131 CTL_CODE(IOCTL_DISK_BASE, 0x0010, METHOD_BUFFERED, FILE_ANY_ACCESS)
133 #define IOCTL_DISK_REQUEST_STRUCTURE \
134 CTL_CODE(IOCTL_DISK_BASE, 0x000f, METHOD_BUFFERED, FILE_ANY_ACCESS)
136 #define IOCTL_DISK_MEDIA_REMOVAL \
137 CTL_CODE(IOCTL_DISK_BASE, 0x0201, METHOD_BUFFERED, FILE_READ_ACCESS)
139 #define IOCTL_DISK_EJECT_MEDIA \
140 CTL_CODE(IOCTL_DISK_BASE, 0x0202, METHOD_BUFFERED, FILE_READ_ACCESS)
142 #define IOCTL_DISK_LOAD_MEDIA \
143 CTL_CODE(IOCTL_DISK_BASE, 0x0203, METHOD_BUFFERED, FILE_READ_ACCESS)
145 #define IOCTL_DISK_RESERVE \
146 CTL_CODE(IOCTL_DISK_BASE, 0x0204, METHOD_BUFFERED, FILE_READ_ACCESS)
148 #define IOCTL_DISK_RELEASE \
149 CTL_CODE(IOCTL_DISK_BASE, 0x0205, METHOD_BUFFERED, FILE_READ_ACCESS)
151 #define IOCTL_DISK_FIND_NEW_DEVICES \
152 CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS)
154 #define IOCTL_DISK_SET_CACHE_INFORMATION \
155 CTL_CODE(IOCTL_DISK_BASE, 0x0036, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
158 // NTDDI_WIN2003 was an older define used in the early beta builds, which
159 // Microsoft forgot to fix in a few headers.
160 // NTDDI_WS03 is the correct term.
162 #if (NTDDI_VERSION < NTDDI_WS03)
163 #define IOCTL_DISK_GET_WRITE_CACHE_STATE \
164 CTL_CODE(IOCTL_DISK_BASE, 0x0037, METHOD_BUFFERED, FILE_READ_ACCESS)
166 #define OBSOLETE_DISK_GET_WRITE_CACHE_STATE \
167 CTL_CODE(IOCTL_DISK_BASE, 0x0037, METHOD_BUFFERED, FILE_READ_ACCESS)
170 #define IOCTL_DISK_SET_DRIVE_LAYOUT \
171 CTL_CODE(IOCTL_DISK_BASE, 0x0004, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
173 #define IOCTL_DISK_SET_DRIVE_LAYOUT_EX \
174 CTL_CODE(IOCTL_DISK_BASE, 0x0015, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
176 #define IOCTL_DISK_SET_PARTITION_INFO \
177 CTL_CODE(IOCTL_DISK_BASE, 0x0002, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
179 #define IOCTL_DISK_SET_PARTITION_INFO_EX \
180 CTL_CODE(IOCTL_DISK_BASE, 0x0013, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
182 #define IOCTL_DISK_UPDATE_DRIVE_SIZE \
183 CTL_CODE(IOCTL_DISK_BASE, 0x0032, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
185 #define IOCTL_DISK_VERIFY \
186 CTL_CODE(IOCTL_DISK_BASE, 0x0005, METHOD_BUFFERED, FILE_ANY_ACCESS)
188 #define IOCTL_DISK_COPY_DATA \
189 CTL_CODE(IOCTL_DISK_BASE, 0x0019, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
191 #define IOCTL_DISK_SIMBAD \
192 CTL_CODE(IOCTL_DISK_BASE, 0x0400, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
194 #define SMART_GET_VERSION \
195 CTL_CODE(IOCTL_DISK_BASE, 0x0020, METHOD_BUFFERED, FILE_READ_ACCESS)
197 #define SMART_RCV_DRIVE_DATA \
198 CTL_CODE(IOCTL_DISK_BASE, 0x0022, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
200 #define SMART_SEND_DRIVE_COMMAND \
201 CTL_CODE(IOCTL_DISK_BASE, 0x0021, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
203 #if(_WIN32_WINNT >= 0x0500)
204 #define IOCTL_DISK_UPDATE_DRIVE_SIZE CTL_CODE(IOCTL_DISK_BASE, 0x0032, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
205 #define IOCTL_DISK_GROW_PARTITION CTL_CODE(IOCTL_DISK_BASE, 0x0034, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
206 #define IOCTL_DISK_GET_CACHE_INFORMATION CTL_CODE(IOCTL_DISK_BASE, 0x0035, METHOD_BUFFERED, FILE_READ_ACCESS)
207 #define IOCTL_DISK_SET_CACHE_INFORMATION CTL_CODE(IOCTL_DISK_BASE, 0x0036, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
208 #define IOCTL_DISK_DELETE_DRIVE_LAYOUT CTL_CODE(IOCTL_DISK_BASE, 0x0040, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
209 #define IOCTL_DISK_UPDATE_PROPERTIES CTL_CODE(IOCTL_DISK_BASE, 0x0050, METHOD_BUFFERED, FILE_ANY_ACCESS)
210 #define IOCTL_DISK_FORMAT_DRIVE CTL_CODE(IOCTL_DISK_BASE, 0x00f3, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
211 #define IOCTL_DISK_SENSE_DEVICE CTL_CODE(IOCTL_DISK_BASE, 0x00f8, METHOD_BUFFERED, FILE_ANY_ACCESS)
214 #define PARTITION_ENTRY_UNUSED 0x00
215 #define PARTITION_FAT_12 0x01
216 #define PARTITION_XENIX_1 0x02
217 #define PARTITION_XENIX_2 0x03
218 #define PARTITION_FAT_16 0x04
219 #define PARTITION_EXTENDED 0x05
220 #define PARTITION_HUGE 0x06
221 #define PARTITION_IFS 0x07
222 #define PARTITION_OS2BOOTMGR 0x0A
223 #define PARTITION_FAT32 0x0B
224 #define PARTITION_FAT32_XINT13 0x0C
225 #define PARTITION_XINT13 0x0E
226 #define PARTITION_XINT13_EXTENDED 0x0F
227 #define PARTITION_PREP 0x41
228 #define PARTITION_LDM 0x42
229 #define PARTITION_UNIX 0x63
230 #define VALID_NTFT 0xC0
231 #define PARTITION_NTFT 0x80
233 #define PARTITION_OLD_LINUX 0x43
234 #define PARTITION_LINUX 0x83
235 #define PARTITION_ISO9660 0x96
236 #define PARTITION_FREEBSD 0xA5
237 #define PARTITION_OPENBSD 0xA6
238 #define PARTITION_NETBSD 0xA9
241 #define IsFTPartition( PartitionType ) \
242 (((PartitionType) & PARTITION_NTFT) && \
243 IsRecognizedPartition(PartitionType))
245 #define IsContainerPartition(PartitionType) \
246 (((PartitionType) == PARTITION_EXTENDED) || \
247 ((PartitionType) == PARTITION_XINT13_EXTENDED))
250 #define IsRecognizedPartition(PartitionType) ( \
251 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT_12)) || \
252 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_HUGE)) || \
253 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_IFS)) || \
254 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32)) || \
255 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32_XINT13)) || \
256 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_XINT13)) || \
257 ((PartitionType) == PARTITION_FAT_12) || \
258 ((PartitionType) == PARTITION_FAT_16) || \
259 ((PartitionType) == PARTITION_HUGE) || \
260 ((PartitionType) == PARTITION_IFS) || \
261 ((PartitionType) == PARTITION_FAT32) || \
262 ((PartitionType) == PARTITION_FAT32_XINT13) || \
263 ((PartitionType) == PARTITION_XINT13) || \
264 ((PartitionType) == PARTITION_LINUX) || \
265 ((PartitionType) == PARTITION_OLD_LINUX) || \
266 ((PartitionType) == PARTITION_ISO9660) || \
267 ((PartitionType) == PARTITION_FREEBSD) || \
268 ((PartitionType) == PARTITION_OPENBSD) || \
269 ((PartitionType) == PARTITION_NETBSD))
271 #define IsRecognizedPartition(PartitionType) ( \
272 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT_12)) || \
273 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_HUGE)) || \
274 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_IFS)) || \
275 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32)) || \
276 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_FAT32_XINT13)) || \
277 (((PartitionType) & PARTITION_NTFT) && (((PartitionType) & ~0xC0) == PARTITION_XINT13)) || \
278 ((PartitionType) == PARTITION_FAT_12) || \
279 ((PartitionType) == PARTITION_FAT_16) || \
280 ((PartitionType) == PARTITION_HUGE) || \
281 ((PartitionType) == PARTITION_IFS) || \
282 ((PartitionType) == PARTITION_FAT32) || \
283 ((PartitionType) == PARTITION_FAT32_XINT13) || \
284 ((PartitionType) == PARTITION_XINT13))
287 #if(_WIN32_WINNT >= 0x0500)
288 #define GPT_ATTRIBUTE_PLATFORM_REQUIRED 0x00000001
289 #define GPT_BASIC_DATA_ATTRIBUTE_READ_ONLY 0x10000000
290 #define GPT_BASIC_DATA_ATTRIBUTE_SHADOW_COPY 0x20000000
291 #define GPT_BASIC_DATA_ATTRIBUTE_HIDDEN 0x40000000
292 #define GPT_BASIC_DATA_ATTRIBUTE_NO_DRIVE_LETTER 0x80000000
295 #define WMI_DISK_GEOMETRY_GUID \
296 {0x25007f51, 0x57c2, 0x11d1, {0xa5, 0x28, 0x0, 0xa0, 0xc9, 0x6, 0x29, 0x10}}
298 typedef USHORT BAD_TRACK_NUMBER
;
299 typedef USHORT
*PBAD_TRACK_NUMBER
;
301 typedef enum _MEDIA_TYPE
{
325 } MEDIA_TYPE
, *PMEDIA_TYPE
;
327 typedef enum _DETECTION_TYPE
{
333 typedef struct _DISK_CONTROLLER_NUMBER
{
334 ULONG ControllerNumber
;
336 } DISK_CONTROLLER_NUMBER
, *PDISK_CONTROLLER_NUMBER
;
338 typedef struct _DISK_INT13_INFO
{
341 USHORT SectorsPerTrack
;
344 } DISK_INT13_INFO
, *PDISK_INT13_INFO
;
346 typedef struct _DISK_EX_INT13_INFO
{
351 ULONG ExSectorsPerTrack
;
352 ULONG64 ExSectorsPerDrive
;
355 } DISK_EX_INT13_INFO
, *PDISK_EX_INT13_INFO
;
357 typedef struct _DISK_DETECTION_INFO
{
358 ULONG SizeOfDetectInfo
;
359 DETECTION_TYPE DetectionType
;
360 _ANONYMOUS_UNION
union {
361 _ANONYMOUS_STRUCT
struct {
362 DISK_INT13_INFO Int13
;
363 DISK_EX_INT13_INFO ExInt13
;
366 } DISK_DETECTION_INFO
, *PDISK_DETECTION_INFO
;
368 typedef struct _DISK_GEOMETRY
{
369 LARGE_INTEGER Cylinders
;
370 MEDIA_TYPE MediaType
;
371 ULONG TracksPerCylinder
;
372 ULONG SectorsPerTrack
;
373 ULONG BytesPerSector
;
374 } DISK_GEOMETRY
, *PDISK_GEOMETRY
;
376 typedef struct _DISK_GEOMETRY_EX
{
377 DISK_GEOMETRY Geometry
;
378 LARGE_INTEGER DiskSize
;
380 } DISK_GEOMETRY_EX
, *PDISK_GEOMETRY_EX
;
382 #define DiskGeometryGetPartition(Geometry) \
383 ((PDISK_PARTITION_INFO)((Geometry) + 1))
385 #define DiskGeometryGetDetect(Geometry)\
386 ((PDISK_DETECTION_INFO)(((PBYTE)DiskGeometryGetPartition(Geometry) + \
387 DiskGeometryGetPartition(Geometry)->SizeOfPartitionInfo)))
389 typedef struct _PARTITION_INFORMATION
{
390 LARGE_INTEGER StartingOffset
;
391 LARGE_INTEGER PartitionLength
;
393 ULONG PartitionNumber
;
395 BOOLEAN BootIndicator
;
396 BOOLEAN RecognizedPartition
;
397 BOOLEAN RewritePartition
;
398 } PARTITION_INFORMATION
, *PPARTITION_INFORMATION
;
400 typedef struct _PARTITION_INFORMATION_GPT
{
405 } PARTITION_INFORMATION_GPT
, *PPARTITION_INFORMATION_GPT
;
407 typedef enum _PARTITION_STYLE
{
413 typedef struct _DISK_PARTITION_INFO
{
414 ULONG SizeOfPartitionInfo
;
415 PARTITION_STYLE PartitionStyle
;
416 _ANONYMOUS_UNION
union {
425 } DISK_PARTITION_INFO
, *PDISK_PARTITION_INFO
;
427 typedef struct _DISK_PERFORMANCE
{
428 LARGE_INTEGER BytesRead
;
429 LARGE_INTEGER BytesWritten
;
430 LARGE_INTEGER ReadTime
;
431 LARGE_INTEGER WriteTime
;
432 LARGE_INTEGER IdleTime
;
437 LARGE_INTEGER QueryTime
;
438 ULONG StorageDeviceNumber
;
439 WCHAR StorageManagerName
[8];
440 } DISK_PERFORMANCE
, *PDISK_PERFORMANCE
;
442 typedef struct _PARTITION_INFORMATION_MBR
{
444 BOOLEAN BootIndicator
;
445 BOOLEAN RecognizedPartition
;
447 } PARTITION_INFORMATION_MBR
, *PPARTITION_INFORMATION_MBR
;
449 typedef struct _PARTITION_INFORMATION_EX
{
450 PARTITION_STYLE PartitionStyle
;
451 LARGE_INTEGER StartingOffset
;
452 LARGE_INTEGER PartitionLength
;
453 ULONG PartitionNumber
;
454 BOOLEAN RewritePartition
;
455 _ANONYMOUS_UNION
union {
456 PARTITION_INFORMATION_MBR Mbr
;
457 PARTITION_INFORMATION_GPT Gpt
;
459 } PARTITION_INFORMATION_EX
, *PPARTITION_INFORMATION_EX
;
461 typedef struct _DRIVE_LAYOUT_INFORMATION
{
462 ULONG PartitionCount
;
464 PARTITION_INFORMATION PartitionEntry
[1];
465 } DRIVE_LAYOUT_INFORMATION
, *PDRIVE_LAYOUT_INFORMATION
;
467 typedef struct _DRIVE_LAYOUT_INFORMATION_MBR
{
469 } DRIVE_LAYOUT_INFORMATION_MBR
, *PDRIVE_LAYOUT_INFORMATION_MBR
;
471 typedef struct _DRIVE_LAYOUT_INFORMATION_GPT
{
473 LARGE_INTEGER StartingUsableOffset
;
474 LARGE_INTEGER UsableLength
;
475 ULONG MaxPartitionCount
;
476 } DRIVE_LAYOUT_INFORMATION_GPT
, *PDRIVE_LAYOUT_INFORMATION_GPT
;
478 typedef struct _DRIVE_LAYOUT_INFORMATION_EX
{
479 ULONG PartitionStyle
;
480 ULONG PartitionCount
;
481 __GNU_EXTENSION
union {
482 DRIVE_LAYOUT_INFORMATION_MBR Mbr
;
483 DRIVE_LAYOUT_INFORMATION_GPT Gpt
;
485 PARTITION_INFORMATION_EX PartitionEntry
[1];
486 } DRIVE_LAYOUT_INFORMATION_EX
, *PDRIVE_LAYOUT_INFORMATION_EX
;
488 typedef struct _FORMAT_EX_PARAMETERS
{
489 MEDIA_TYPE MediaType
;
490 ULONG StartCylinderNumber
;
491 ULONG EndCylinderNumber
;
492 ULONG StartHeadNumber
;
494 USHORT FormatGapLength
;
495 USHORT SectorsPerTrack
;
496 USHORT SectorNumber
[1];
497 } FORMAT_EX_PARAMETERS
, *PFORMAT_EX_PARAMETERS
;
499 typedef struct _FORMAT_PARAMETERS
{
500 MEDIA_TYPE MediaType
;
501 ULONG StartCylinderNumber
;
502 ULONG EndCylinderNumber
;
503 ULONG StartHeadNumber
;
505 } FORMAT_PARAMETERS
, *PFORMAT_PARAMETERS
;
507 typedef struct _GET_LENGTH_INFORMATION
{
508 LARGE_INTEGER Length
;
509 } GET_LENGTH_INFORMATION
, *PGET_LENGTH_INFORMATION
;
511 typedef struct _REASSIGN_BLOCKS
{
514 ULONG BlockNumber
[1];
515 } REASSIGN_BLOCKS
, *PREASSIGN_BLOCKS
;
517 typedef struct _SET_PARTITION_INFORMATION
{
519 } SET_PARTITION_INFORMATION
, *PSET_PARTITION_INFORMATION
;
521 typedef SET_PARTITION_INFORMATION SET_PARTITION_INFORMATION_MBR
;
522 typedef PARTITION_INFORMATION_GPT SET_PARTITION_INFORMATION_GPT
;
524 typedef struct _SET_PARTITION_INFORMATION_EX
{
525 PARTITION_STYLE PartitionStyle
;
526 _ANONYMOUS_UNION
union {
527 SET_PARTITION_INFORMATION_MBR Mbr
;
528 SET_PARTITION_INFORMATION_GPT Gpt
;
530 } SET_PARTITION_INFORMATION_EX
, *PSET_PARTITION_INFORMATION_EX
;
532 typedef struct _VERIFY_INFORMATION
{
533 LARGE_INTEGER StartingOffset
;
535 } VERIFY_INFORMATION
, *PVERIFY_INFORMATION
;
537 /* GETVERSIONINPARAMS.fCapabilities constants */
538 #define CAP_ATA_ID_CMD 1
539 #define CAP_ATAPI_ID_CMD 2
540 #define CAP_SMART_CMD 4
542 typedef struct _GETVERSIONINPARAMS
{
549 } GETVERSIONINPARAMS
, *PGETVERSIONINPARAMS
, *LPGETVERSIONINPARAMS
;
551 /* IDEREGS.bCommandReg constants */
552 #define ATAPI_ID_CMD 0xA1
554 #define SMART_CMD 0xB0
556 #define SMART_CYL_LOW 0x4F
557 #define SMART_CYL_HI 0xC2
559 typedef struct _IDEREGS
{
561 UCHAR bSectorCountReg
;
562 UCHAR bSectorNumberReg
;
568 } IDEREGS
, *PIDEREGS
, *LPIDEREGS
;
570 #include <pshpack1.h>
571 typedef struct _SENDCMDINPARAMS
{
578 } SENDCMDINPARAMS
, *PSENDCMDINPARAMS
, *LPSENDCMDINPARAMS
;
581 /* DRIVERSTATUS.bDriverError constants */
582 #define SMART_NO_ERROR 0
583 #define SMART_IDE_ERROR 1
584 #define SMART_INVALID_FLAG 2
585 #define SMART_INVALID_COMMAND 3
586 #define SMART_INVALID_BUFFER 4
587 #define SMART_INVALID_DRIVE 5
588 #define SMART_INVALID_IOCTL 6
589 #define SMART_ERROR_NO_MEM 7
590 #define SMART_INVALID_REGISTER 8
591 #define SMART_NOT_SUPPORTED 9
592 #define SMART_NO_IDE_DEVICE 10
594 #define SMART_OFFLINE_ROUTINE_OFFLINE 0
595 #define SMART_SHORT_SELFTEST_OFFLINE 1
596 #define SMART_EXTENDED_SELFTEST_OFFLINE 2
597 #define SMART_ABORT_OFFLINE_SELFTEST 127
598 #define SMART_SHORT_SELFTEST_CAPTIVE 129
599 #define SMART_EXTENDED_SELFTEST_CAPTIVE 130
601 typedef struct _DRIVERSTATUS
{
606 } DRIVERSTATUS
, *PDRIVERSTATUS
, *LPDRIVERSTATUS
;
608 #define READ_ATTRIBUTE_BUFFER_SIZE 512
609 #define IDENTIFY_BUFFER_SIZE 512
610 #define READ_THRESHOLD_BUFFER_SIZE 512
611 #define SMART_LOG_SECTOR_SIZE 512
613 #include <pshpack1.h>
614 typedef struct _SENDCMDOUTPARAMS
{
616 DRIVERSTATUS DriverStatus
;
618 } SENDCMDOUTPARAMS
, *PSENDCMDOUTPARAMS
, *LPSENDCMDOUTPARAMS
;
621 #define READ_ATTRIBUTES 0xD0
622 #define READ_THRESHOLDS 0xD1
623 #define ENABLE_DISABLE_AUTOSAVE 0xD2
624 #define SAVE_ATTRIBUTE_VALUES 0xD3
625 #define EXECUTE_OFFLINE_DIAGS 0xD4
626 #define SMART_READ_LOG 0xD5
627 #define SMART_WRITE_LOG 0xd6
628 #define ENABLE_SMART 0xD8
629 #define DISABLE_SMART 0xD9
630 #define RETURN_SMART_STATUS 0xDA
631 #define ENABLE_DISABLE_AUTO_OFFLINE 0xDB
633 typedef struct _MAPPED_ADDRESS
{
634 struct _MAPPED_ADDRESS
*NextMappedAddress
;
637 LARGE_INTEGER IoAddress
;
639 } MAPPED_ADDRESS
, *PMAPPED_ADDRESS
;
643 #if(_WIN32_WINNT >= 0x0500)
645 typedef struct _CREATE_DISK_GPT
648 ULONG MaxPartitionCount
;
649 } CREATE_DISK_GPT
, *PCREATE_DISK_GPT
;
651 typedef struct _CREATE_DISK_MBR
654 } CREATE_DISK_MBR
, *PCREATE_DISK_MBR
;
657 typedef struct _CREATE_DISK
659 PARTITION_STYLE PartitionStyle
;
664 } CREATE_DISK
, *PCREATE_DISK
;
671 } DISK_CACHE_RETENTION_PRIORITY
;
673 typedef enum _DISK_WRITE_CACHE_STATE
{
674 DiskWriteCacheNormal
,
675 DiskWriteCacheForceDisable
,
676 DiskWriteCacheDisableNotSupported
677 } DISK_WRITE_CACHE_STATE
, *PDISK_WRITE_CACHE_STATE
;
680 typedef struct _DISK_CACHE_INFORMATION
682 BOOLEAN ParametersSavable
;
683 BOOLEAN ReadCacheEnabled
;
684 BOOLEAN WriteCacheEnabled
;
685 DISK_CACHE_RETENTION_PRIORITY ReadRetentionPriority
;
686 DISK_CACHE_RETENTION_PRIORITY WriteRetentionPriority
;
687 USHORT DisablePrefetchTransferLength
;
688 BOOLEAN PrefetchScalar
;
693 USHORT MaximumBlocks
;
702 } DISK_CACHE_INFORMATION
, *PDISK_CACHE_INFORMATION
;
704 typedef struct _DISK_GROW_PARTITION
{
705 ULONG PartitionNumber
;
706 LARGE_INTEGER BytesToGrow
;
707 } DISK_GROW_PARTITION
, *PDISK_GROW_PARTITION
;
715 #endif /* _NTDDDISK_H_ */