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.
32 #define DD_DISK_DEVICE_NAME "\\Device\\UNKNOWN"
33 #define DD_DISK_DEVICE_NAME_U L"\\Device\\UNKNOWN"
35 #define IOCTL_DISK_BASE FILE_DEVICE_DISK
37 #define IOCTL_DISK_CHECK_VERIFY \
38 CTL_CODE(IOCTL_DISK_BASE, 0x0200, METHOD_BUFFERED, FILE_READ_ACCESS)
40 #define IOCTL_DISK_CONTROLLER_NUMBER \
41 CTL_CODE(IOCTL_DISK_BASE, 0x0011, METHOD_BUFFERED, FILE_ANY_ACCESS)
43 #define IOCTL_DISK_CREATE_DISK \
44 CTL_CODE(IOCTL_DISK_BASE, 0x0016, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
46 #define IOCTL_DISK_DELETE_DRIVE_LAYOUT \
47 CTL_CODE(IOCTL_DISK_BASE, 0x0040, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
49 #define IOCTL_DISK_FIND_NEW_DEVICES \
50 CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS)
52 #define IOCTL_DISK_FORMAT_TRACKS \
53 CTL_CODE(IOCTL_DISK_BASE, 0x0006, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
55 #define IOCTL_DISK_FORMAT_TRACKS_EX \
56 CTL_CODE(IOCTL_DISK_BASE, 0x000b, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
58 #define IOCTL_DISK_GET_CACHE_INFORMATION \
59 CTL_CODE(IOCTL_DISK_BASE, 0x0035, METHOD_BUFFERED, FILE_READ_ACCESS)
61 #define IOCTL_DISK_GET_DRIVE_GEOMETRY \
62 CTL_CODE(IOCTL_DISK_BASE, 0x0000, METHOD_BUFFERED, FILE_ANY_ACCESS)
64 #define IOCTL_DISK_GET_DRIVE_GEOMETRY_EX \
65 CTL_CODE(IOCTL_DISK_BASE, 0x0028, METHOD_BUFFERED, FILE_ANY_ACCESS)
67 #define IOCTL_DISK_GET_DRIVE_LAYOUT \
68 CTL_CODE(IOCTL_DISK_BASE, 0x0003, METHOD_BUFFERED, FILE_READ_ACCESS)
70 #define IOCTL_DISK_GET_DRIVE_LAYOUT_EX \
71 CTL_CODE(IOCTL_DISK_BASE, 0x0014, METHOD_BUFFERED, FILE_ANY_ACCESS)
73 #define IOCTL_DISK_GET_MEDIA_TYPES \
74 CTL_CODE(IOCTL_DISK_BASE, 0x0300, METHOD_BUFFERED, FILE_ANY_ACCESS)
76 #define IOCTL_DISK_GET_LENGTH_INFO \
77 CTL_CODE(IOCTL_DISK_BASE, 0x0017, METHOD_BUFFERED, FILE_READ_ACCESS)
79 #define IOCTL_DISK_GET_PARTITION_INFO \
80 CTL_CODE(IOCTL_DISK_BASE, 0x0001, METHOD_BUFFERED, FILE_READ_ACCESS)
82 #define IOCTL_DISK_GET_PARTITION_INFO_EX \
83 CTL_CODE(IOCTL_DISK_BASE, 0x0012, METHOD_BUFFERED, FILE_ANY_ACCESS)
85 #define IOCTL_DISK_GROW_PARTITION \
86 CTL_CODE(IOCTL_DISK_BASE, 0x0034, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
88 #define IOCTL_DISK_HISTOGRAM_STRUCTURE \
89 CTL_CODE(IOCTL_DISK_BASE, 0x000c, METHOD_BUFFERED, FILE_ANY_ACCESS)
91 #define IOCTL_DISK_HISTOGRAM_DATA \
92 CTL_CODE(IOCTL_DISK_BASE, 0x000d, METHOD_BUFFERED, FILE_ANY_ACCESS)
94 #define IOCTL_DISK_HISTOGRAM_RESET \
95 CTL_CODE(IOCTL_DISK_BASE, 0x000e, METHOD_BUFFERED, FILE_ANY_ACCESS)
97 #define IOCTL_DISK_INTERNAL_CLEAR_VERIFY \
98 CTL_CODE(IOCTL_DISK_BASE, 0x0101, METHOD_NEITHER, FILE_ANY_ACCESS)
100 #define IOCTL_DISK_INTERNAL_SET_VERIFY \
101 CTL_CODE(IOCTL_DISK_BASE, 0x0100, METHOD_NEITHER, FILE_ANY_ACCESS)
103 #define IOCTL_DISK_IS_WRITABLE \
104 CTL_CODE(IOCTL_DISK_BASE, 0x0009, METHOD_BUFFERED, FILE_ANY_ACCESS)
106 #define IOCTL_DISK_LOGGING \
107 CTL_CODE(IOCTL_DISK_BASE, 0x000a, METHOD_BUFFERED, FILE_ANY_ACCESS)
109 #define IOCTL_DISK_PERFORMANCE \
110 CTL_CODE(IOCTL_DISK_BASE, 0x0008, METHOD_BUFFERED, FILE_ANY_ACCESS)
112 #define IOCTL_DISK_PERFORMANCE_OFF \
113 CTL_CODE(IOCTL_DISK_BASE, 0x0018, METHOD_BUFFERED, FILE_ANY_ACCESS)
115 #define IOCTL_DISK_REASSIGN_BLOCKS \
116 CTL_CODE(IOCTL_DISK_BASE, 0x0007, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
118 #define IOCTL_DISK_REQUEST_DATA \
119 CTL_CODE(IOCTL_DISK_BASE, 0x0010, METHOD_BUFFERED, FILE_ANY_ACCESS)
121 #define IOCTL_DISK_REQUEST_STRUCTURE \
122 CTL_CODE(IOCTL_DISK_BASE, 0x000f, METHOD_BUFFERED, FILE_ANY_ACCESS)
124 #define IOCTL_DISK_MEDIA_REMOVAL \
125 CTL_CODE(IOCTL_DISK_BASE, 0x0201, METHOD_BUFFERED, FILE_READ_ACCESS)
127 #define IOCTL_DISK_EJECT_MEDIA \
128 CTL_CODE(IOCTL_DISK_BASE, 0x0202, METHOD_BUFFERED, FILE_READ_ACCESS)
130 #define IOCTL_DISK_LOAD_MEDIA \
131 CTL_CODE(IOCTL_DISK_BASE, 0x0203, METHOD_BUFFERED, FILE_READ_ACCESS)
133 #define IOCTL_DISK_RESERVE \
134 CTL_CODE(IOCTL_DISK_BASE, 0x0204, METHOD_BUFFERED, FILE_READ_ACCESS)
136 #define IOCTL_DISK_RELEASE \
137 CTL_CODE(IOCTL_DISK_BASE, 0x0205, METHOD_BUFFERED, FILE_READ_ACCESS)
139 #define IOCTL_DISK_FIND_NEW_DEVICES \
140 CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS)
142 #define IOCTL_DISK_SET_CACHE_INFORMATION \
143 CTL_CODE(IOCTL_DISK_BASE, 0x0036, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
145 #define IOCTL_DISK_SET_DRIVE_LAYOUT \
146 CTL_CODE(IOCTL_DISK_BASE, 0x0004, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
148 #define IOCTL_DISK_SET_DRIVE_LAYOUT_EX \
149 CTL_CODE(IOCTL_DISK_BASE, 0x0015, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
151 #define IOCTL_DISK_SET_PARTITION_INFO \
152 CTL_CODE(IOCTL_DISK_BASE, 0x0002, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
154 #define IOCTL_DISK_SET_PARTITION_INFO_EX \
155 CTL_CODE(IOCTL_DISK_BASE, 0x0013, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
157 #define IOCTL_DISK_UPDATE_DRIVE_SIZE \
158 CTL_CODE(IOCTL_DISK_BASE, 0x0032, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
160 #define IOCTL_DISK_VERIFY \
161 CTL_CODE(IOCTL_DISK_BASE, 0x0005, METHOD_BUFFERED, FILE_ANY_ACCESS)
163 #define SMART_GET_VERSION \
164 CTL_CODE(IOCTL_DISK_BASE, 0x0020, METHOD_BUFFERED, FILE_READ_ACCESS)
166 #define SMART_RCV_DRIVE_DATA \
167 CTL_CODE(IOCTL_DISK_BASE, 0x0022, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
169 #define SMART_SEND_DRIVE_COMMAND \
170 CTL_CODE(IOCTL_DISK_BASE, 0x0021, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
172 #define IOCTL_DISK_UPDATE_PROPERTIES \
173 CTL_CODE(IOCTL_DISK_BASE, 0x50, METHOD_BUFFERED, FILE_ANY_ACCESS)
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
194 #define IsFTPartition( PartitionType ) \
195 (((PartitionType) & PARTITION_NTFT) && \
196 IsRecognizedPartition(PartitionType))
198 #define IsContainerPartition(PartitionType) \
199 (((PartitionType) == PARTITION_EXTENDED) || \
200 ((PartitionType) == PARTITION_XINT13_EXTENDED))
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))
217 #define WMI_DISK_GEOMETRY_GUID \
218 {0x25007f51, 0x57c2, 0x11d1, {0xa5, 0x28, 0x0, 0xa0, 0xc9, 0x6, 0x29, 0x10}}
220 typedef USHORT BAD_TRACK_NUMBER
;
221 typedef USHORT
*PBAD_TRACK_NUMBER
;
223 typedef enum _MEDIA_TYPE
{
247 } MEDIA_TYPE
, *PMEDIA_TYPE
;
249 typedef enum _DETECTION_TYPE
{
255 typedef struct _DISK_CONTROLLER_NUMBER
{
256 ULONG ControllerNumber
;
258 } DISK_CONTROLLER_NUMBER
, *PDISK_CONTROLLER_NUMBER
;
260 typedef struct _DISK_INT13_INFO
{
263 USHORT SectorsPerTrack
;
266 } DISK_INT13_INFO
, *PDISK_INT13_INFO
;
268 typedef struct _DISK_EX_INT13_INFO
{
273 ULONG ExSectorsPerTrack
;
274 ULONG64 ExSectorsPerDrive
;
277 } DISK_EX_INT13_INFO
, *PDISK_EX_INT13_INFO
;
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
;
288 } DISK_DETECTION_INFO
, *PDISK_DETECTION_INFO
;
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
;
298 typedef struct _DISK_GEOMETRY_EX
{
299 DISK_GEOMETRY Geometry
;
300 LARGE_INTEGER DiskSize
;
302 } DISK_GEOMETRY_EX
, *PDISK_GEOMETRY_EX
;
304 #define DiskGeometryGetPartition(Geometry) \
305 ((PDISK_PARTITION_INFO)((Geometry) + 1))
307 #define DiskGeometryGetDetect(Geometry)\
308 ((PDISK_DETECTION_INFO)(((PBYTE)DiskGeometryGetPartition(Geometry) + \
309 DiskGeometryGetPartition(Geometry)->SizeOfPartitionInfo)))
311 typedef struct _PARTITION_INFORMATION
{
312 LARGE_INTEGER StartingOffset
;
313 LARGE_INTEGER PartitionLength
;
315 ULONG PartitionNumber
;
317 BOOLEAN BootIndicator
;
318 BOOLEAN RecognizedPartition
;
319 BOOLEAN RewritePartition
;
320 } PARTITION_INFORMATION
, *PPARTITION_INFORMATION
;
322 typedef struct _PARTITION_INFORMATION_GPT
{
327 } PARTITION_INFORMATION_GPT
, *PPARTITION_INFORMATION_GPT
;
329 typedef struct _DISK_PARTITION_INFO
{
330 ULONG SizeOfPartitionInfo
;
331 PARTITION_STYLE PartitionStyle
;
332 _ANONYMOUS_UNION
union {
341 } DISK_PARTITION_INFO
, *PDISK_PARTITION_INFO
;
343 typedef struct _DISK_PERFORMANCE
{
344 LARGE_INTEGER BytesRead
;
345 LARGE_INTEGER BytesWritten
;
346 LARGE_INTEGER ReadTime
;
347 LARGE_INTEGER WriteTime
;
348 LARGE_INTEGER IdleTime
;
353 LARGE_INTEGER QueryTime
;
354 ULONG StorageDeviceNumber
;
355 WCHAR StorageManagerName
[8];
356 } DISK_PERFORMANCE
, *PDISK_PERFORMANCE
;
358 typedef struct _PARTITION_INFORMATION_MBR
{
360 BOOLEAN BootIndicator
;
361 BOOLEAN RecognizedPartition
;
363 } PARTITION_INFORMATION_MBR
, *PPARTITION_INFORMATION_MBR
;
365 typedef struct _PARTITION_INFORMATION_EX
{
366 PARTITION_STYLE PartitionStyle
;
367 LARGE_INTEGER StartingOffset
;
368 LARGE_INTEGER PartitionLength
;
369 ULONG PartitionNumber
;
370 BOOLEAN RewritePartition
;
371 _ANONYMOUS_UNION
union {
372 PARTITION_INFORMATION_MBR Mbr
;
373 PARTITION_INFORMATION_GPT Gpt
;
375 } PARTITION_INFORMATION_EX
, *PPARTITION_INFORMATION_EX
;
377 typedef struct _DRIVE_LAYOUT_INFORMATION
{
378 ULONG PartitionCount
;
380 PARTITION_INFORMATION PartitionEntry
[1];
381 } DRIVE_LAYOUT_INFORMATION
, *PDRIVE_LAYOUT_INFORMATION
;
383 typedef struct _DRIVE_LAYOUT_INFORMATION_MBR
{
385 } DRIVE_LAYOUT_INFORMATION_MBR
, *PDRIVE_LAYOUT_INFORMATION_MBR
;
387 typedef struct _DRIVE_LAYOUT_INFORMATION_GPT
{
389 LARGE_INTEGER StartingUsableOffset
;
390 LARGE_INTEGER UsableLength
;
391 ULONG MaxPartitionCount
;
392 } DRIVE_LAYOUT_INFORMATION_GPT
, *PDRIVE_LAYOUT_INFORMATION_GPT
;
394 typedef struct _DRIVE_LAYOUT_INFORMATION_EX
{
395 ULONG PartitionStyle
;
396 ULONG PartitionCount
;
398 DRIVE_LAYOUT_INFORMATION_MBR Mbr
;
399 DRIVE_LAYOUT_INFORMATION_GPT Gpt
;
401 PARTITION_INFORMATION_EX PartitionEntry
[1];
402 } DRIVE_LAYOUT_INFORMATION_EX
, *PDRIVE_LAYOUT_INFORMATION_EX
;
404 typedef struct _FORMAT_EX_PARAMETERS
{
405 MEDIA_TYPE MediaType
;
406 ULONG StartCylinderNumber
;
407 ULONG EndCylinderNumber
;
408 ULONG StartHeadNumber
;
410 USHORT FormatGapLength
;
411 USHORT SectorsPerTrack
;
412 USHORT SectorNumber
[1];
413 } FORMAT_EX_PARAMETERS
, *PFORMAT_EX_PARAMETERS
;
415 typedef struct _FORMAT_PARAMETERS
{
416 MEDIA_TYPE MediaType
;
417 ULONG StartCylinderNumber
;
418 ULONG EndCylinderNumber
;
419 ULONG StartHeadNumber
;
421 } FORMAT_PARAMETERS
, *PFORMAT_PARAMETERS
;
423 typedef struct _GET_LENGTH_INFORMATION
{
424 LARGE_INTEGER Length
;
425 } GET_LENGTH_INFORMATION
, *PGET_LENGTH_INFORMATION
;
427 typedef struct _REASSIGN_BLOCKS
{
430 ULONG BlockNumber
[1];
431 } REASSIGN_BLOCKS
, *PREASSIGN_BLOCKS
;
433 typedef struct _SET_PARTITION_INFORMATION
{
435 } SET_PARTITION_INFORMATION
, *PSET_PARTITION_INFORMATION
;
437 typedef SET_PARTITION_INFORMATION SET_PARTITION_INFORMATION_MBR
;
438 typedef PARTITION_INFORMATION_GPT SET_PARTITION_INFORMATION_GPT
;
440 typedef struct _SET_PARTITION_INFORMATION_EX
{
441 PARTITION_STYLE PartitionStyle
;
442 _ANONYMOUS_UNION
union {
443 SET_PARTITION_INFORMATION_MBR Mbr
;
444 SET_PARTITION_INFORMATION_GPT Gpt
;
446 } SET_PARTITION_INFORMATION_EX
, *PSET_PARTITION_INFORMATION_EX
;
448 typedef struct _VERIFY_INFORMATION
{
449 LARGE_INTEGER StartingOffset
;
451 } VERIFY_INFORMATION
, *PVERIFY_INFORMATION
;
457 } DISK_CACHE_RETENTION_PRIORITY
;
459 typedef struct _DISK_CACHE_INFORMATION
{
460 BOOLEAN ParametersSavable
;
461 BOOLEAN ReadCacheEnabled
;
462 BOOLEAN WriteCacheEnabled
;
463 DISK_CACHE_RETENTION_PRIORITY ReadRetentionPriority
;
464 DISK_CACHE_RETENTION_PRIORITY WriteRetentionPriority
;
465 USHORT DisablePrefetchTransferLength
;
466 BOOLEAN PrefetchScalar
;
467 _ANONYMOUS_UNION
union {
471 USHORT MaximumBlocks
;
478 } DISK_CACHE_INFORMATION
, *PDISK_CACHE_INFORMATION
;
480 typedef struct _DISK_GROW_PARTITION
{
481 ULONG PartitionNumber
;
482 LARGE_INTEGER BytesToGrow
;
483 } DISK_GROW_PARTITION
, *PDISK_GROW_PARTITION
;
485 /* GETVERSIONINPARAMS.fCapabilities constants */
486 #define CAP_ATA_ID_CMD 1
487 #define CAP_ATAPI_ID_CMD 2
488 #define CAP_SMART_CMD 4
490 typedef struct _GETVERSIONINPARAMS
{
497 } GETVERSIONINPARAMS
, *PGETVERSIONINPARAMS
, *LPGETVERSIONINPARAMS
;
499 /* IDEREGS.bCommandReg constants */
500 #define ATAPI_ID_CMD 0xA1
502 #define SMART_CMD 0xB0
504 #define SMART_CYL_LOW 0x4F
505 #define SMART_CYL_HI 0xC2
507 typedef struct _IDEREGS
{
509 UCHAR bSectorCountReg
;
510 UCHAR bSectorNumberReg
;
516 } IDEREGS
, *PIDEREGS
, *LPIDEREGS
;
518 #include <pshpack1.h>
519 typedef struct _SENDCMDINPARAMS
{
526 } SENDCMDINPARAMS
, *PSENDCMDINPARAMS
, *LPSENDCMDINPARAMS
;
529 /* DRIVERSTATUS.bDriverError constants */
530 #define SMART_NO_ERROR 0
531 #define SMART_IDE_ERROR 1
532 #define SMART_INVALID_FLAG 2
533 #define SMART_INVALID_COMMAND 3
534 #define SMART_INVALID_BUFFER 4
535 #define SMART_INVALID_DRIVE 5
536 #define SMART_INVALID_IOCTL 6
537 #define SMART_ERROR_NO_MEM 7
538 #define SMART_INVALID_REGISTER 8
539 #define SMART_NOT_SUPPORTED 9
540 #define SMART_NO_IDE_DEVICE 10
542 #define SMART_OFFLINE_ROUTINE_OFFLINE 0
543 #define SMART_SHORT_SELFTEST_OFFLINE 1
544 #define SMART_EXTENDED_SELFTEST_OFFLINE 2
545 #define SMART_ABORT_OFFLINE_SELFTEST 127
546 #define SMART_SHORT_SELFTEST_CAPTIVE 129
547 #define SMART_EXTENDED_SELFTEST_CAPTIVE 130
549 typedef struct _DRIVERSTATUS
{
554 } DRIVERSTATUS
, *PDRIVERSTATUS
, *LPDRIVERSTATUS
;
556 #define READ_ATTRIBUTE_BUFFER_SIZE 512
557 #define IDENTIFY_BUFFER_SIZE 512
558 #define READ_THRESHOLD_BUFFER_SIZE 512
559 #define SMART_LOG_SECTOR_SIZE 512
561 #include <pshpack1.h>
562 typedef struct _SENDCMDOUTPARAMS
{
564 DRIVERSTATUS DriverStatus
;
566 } SENDCMDOUTPARAMS
, *PSENDCMDOUTPARAMS
, *LPSENDCMDOUTPARAMS
;
569 #define READ_ATTRIBUTES 0xD0
570 #define READ_THRESHOLDS 0xD1
571 #define ENABLE_DISABLE_AUTOSAVE 0xD2
572 #define SAVE_ATTRIBUTE_VALUES 0xD3
573 #define EXECUTE_OFFLINE_DIAGS 0xD4
574 #define SMART_READ_LOG 0xD5
575 #define SMART_WRITE_LOG 0xd6
576 #define ENABLE_SMART 0xD8
577 #define DISABLE_SMART 0xD9
578 #define RETURN_SMART_STATUS 0xDA
579 #define ENABLE_DISABLE_AUTO_OFFLINE 0xDB
581 typedef struct _MAPPED_ADDRESS
{
582 struct _MAPPED_ADDRESS
*NextMappedAddress
;
585 LARGE_INTEGER IoAddress
;
587 } MAPPED_ADDRESS
, *PMAPPED_ADDRESS
;
594 #endif /* __NTDDDISK_H */