[1166] | 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_ */
|
---|