[VIDEOPRT]
[reactos.git] / reactos / include / psdk / winioctl.h
1 #ifndef _WINIOCTL_
2 #define _WINIOCTL_
3
4 #ifdef __cplusplus
5 extern "C" {
6 #endif
7
8 #ifdef _MSC_VER
9 #pragma warning(push)
10 #pragma warning(disable:4201)
11 #pragma warning(disable:4820)
12 #endif
13
14 #define HIST_NO_OF_BUCKETS 24
15 #define HISTOGRAM_BUCKET_SIZE sizeof(HISTOGRAM_BUCKET)
16 #define DISK_HISTOGRAM_SIZE sizeof(DISK_HISTOGRAM)
17
18 #ifndef _NTDDSTOR_H_
19 #define IOCTL_STORAGE_BASE FILE_DEVICE_MASS_STORAGE
20 #define IOCTL_STORAGE_CHECK_VERIFY CTL_CODE(IOCTL_STORAGE_BASE, 0x0200, METHOD_BUFFERED, FILE_READ_ACCESS)
21 #define IOCTL_STORAGE_CHECK_VERIFY2 CTL_CODE(IOCTL_STORAGE_BASE, 0x0200, METHOD_BUFFERED, FILE_ANY_ACCESS)
22 #define IOCTL_STORAGE_MEDIA_REMOVAL CTL_CODE(IOCTL_STORAGE_BASE, 0x0201, METHOD_BUFFERED, FILE_READ_ACCESS)
23 #define IOCTL_STORAGE_EJECT_MEDIA CTL_CODE(IOCTL_STORAGE_BASE, 0x0202, METHOD_BUFFERED, FILE_READ_ACCESS)
24 #define IOCTL_STORAGE_LOAD_MEDIA CTL_CODE(IOCTL_STORAGE_BASE, 0x0203, METHOD_BUFFERED, FILE_READ_ACCESS)
25 #define IOCTL_STORAGE_LOAD_MEDIA2 CTL_CODE(IOCTL_STORAGE_BASE, 0x0203, METHOD_BUFFERED, FILE_ANY_ACCESS)
26 #define IOCTL_STORAGE_RESERVE CTL_CODE(IOCTL_STORAGE_BASE, 0x0204, METHOD_BUFFERED, FILE_READ_ACCESS)
27 #define IOCTL_STORAGE_RELEASE CTL_CODE(IOCTL_STORAGE_BASE, 0x0205, METHOD_BUFFERED, FILE_READ_ACCESS)
28 #define IOCTL_STORAGE_FIND_NEW_DEVICES CTL_CODE(IOCTL_STORAGE_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS)
29 #define IOCTL_STORAGE_EJECTION_CONTROL CTL_CODE(IOCTL_STORAGE_BASE, 0x0250, METHOD_BUFFERED, FILE_ANY_ACCESS)
30 #define IOCTL_STORAGE_MCN_CONTROL CTL_CODE(IOCTL_STORAGE_BASE, 0x0251, METHOD_BUFFERED, FILE_ANY_ACCESS)
31 #define IOCTL_STORAGE_GET_MEDIA_TYPES CTL_CODE(IOCTL_STORAGE_BASE, 0x0300, METHOD_BUFFERED, FILE_ANY_ACCESS)
32 #define IOCTL_STORAGE_GET_MEDIA_TYPES_EX CTL_CODE(IOCTL_STORAGE_BASE, 0x0301, METHOD_BUFFERED, FILE_ANY_ACCESS)
33 #define IOCTL_STORAGE_RESET_BUS CTL_CODE(IOCTL_STORAGE_BASE, 0x0400, METHOD_BUFFERED, FILE_READ_ACCESS)
34 #define IOCTL_STORAGE_RESET_DEVICE CTL_CODE(IOCTL_STORAGE_BASE, 0x0401, METHOD_BUFFERED, FILE_READ_ACCESS)
35 #define IOCTL_STORAGE_GET_DEVICE_NUMBER CTL_CODE(IOCTL_STORAGE_BASE, 0x0420, METHOD_BUFFERED, FILE_ANY_ACCESS)
36 #define IOCTL_STORAGE_PREDICT_FAILURE CTL_CODE(IOCTL_STORAGE_BASE, 0x0440, METHOD_BUFFERED, FILE_ANY_ACCESS)
37 #endif
38
39 #define IOCTL_DISK_BASE FILE_DEVICE_DISK
40 #define IOCTL_DISK_GET_DRIVE_GEOMETRY CTL_CODE(IOCTL_DISK_BASE,0,METHOD_BUFFERED, FILE_ANY_ACCESS)
41 #define IOCTL_DISK_GET_PARTITION_INFO CTL_CODE(IOCTL_DISK_BASE,1,METHOD_BUFFERED,FILE_READ_ACCESS)
42 #define IOCTL_DISK_SET_PARTITION_INFO CTL_CODE(IOCTL_DISK_BASE,2,METHOD_BUFFERED,FILE_READ_ACCESS|FILE_WRITE_ACCESS)
43 #define IOCTL_DISK_GET_DRIVE_LAYOUT CTL_CODE(IOCTL_DISK_BASE,3,METHOD_BUFFERED,FILE_READ_ACCESS)
44 #define IOCTL_DISK_SET_DRIVE_LAYOUT CTL_CODE(IOCTL_DISK_BASE,4,METHOD_BUFFERED,FILE_READ_ACCESS|FILE_WRITE_ACCESS)
45 #define IOCTL_DISK_VERIFY CTL_CODE(IOCTL_DISK_BASE,5,METHOD_BUFFERED,FILE_ANY_ACCESS)
46 #define IOCTL_DISK_FORMAT_TRACKS CTL_CODE(IOCTL_DISK_BASE,6,METHOD_BUFFERED,FILE_READ_ACCESS|FILE_WRITE_ACCESS)
47 #define IOCTL_DISK_REASSIGN_BLOCKS CTL_CODE(IOCTL_DISK_BASE,7,METHOD_BUFFERED,FILE_READ_ACCESS|FILE_WRITE_ACCESS)
48 #define IOCTL_DISK_PERFORMANCE CTL_CODE(IOCTL_DISK_BASE,8,METHOD_BUFFERED,FILE_ANY_ACCESS)
49 #define IOCTL_DISK_IS_WRITABLE CTL_CODE(IOCTL_DISK_BASE,9,METHOD_BUFFERED,FILE_ANY_ACCESS)
50 #define IOCTL_DISK_LOGGING CTL_CODE(IOCTL_DISK_BASE,10,METHOD_BUFFERED,FILE_ANY_ACCESS)
51 #define IOCTL_DISK_FORMAT_TRACKS_EX CTL_CODE(IOCTL_DISK_BASE,11,METHOD_BUFFERED,FILE_READ_ACCESS|FILE_WRITE_ACCESS)
52 #define IOCTL_DISK_HISTOGRAM_STRUCTURE CTL_CODE(IOCTL_DISK_BASE,12,METHOD_BUFFERED,FILE_ANY_ACCESS)
53 #define IOCTL_DISK_HISTOGRAM_DATA CTL_CODE(IOCTL_DISK_BASE,13,METHOD_BUFFERED,FILE_ANY_ACCESS)
54 #define IOCTL_DISK_HISTOGRAM_RESET CTL_CODE(IOCTL_DISK_BASE,14,METHOD_BUFFERED,FILE_ANY_ACCESS)
55 #define IOCTL_DISK_REQUEST_STRUCTURE CTL_CODE(IOCTL_DISK_BASE,15,METHOD_BUFFERED,FILE_ANY_ACCESS)
56 #define IOCTL_DISK_REQUEST_DATA CTL_CODE(IOCTL_DISK_BASE,16,METHOD_BUFFERED,FILE_ANY_ACCESS)
57 #define IOCTL_DISK_GET_PARTITION_INFO_EX CTL_CODE(IOCTL_DISK_BASE,0x12,METHOD_BUFFERED,FILE_ANY_ACCESS)
58 #define IOCTL_DISK_SET_PARTITION_INFO_EX CTL_CODE(IOCTL_DISK_BASE,0x13,METHOD_BUFFERED,FILE_READ_ACCESS | FILE_WRITE_ACCESS)
59 #define IOCTL_DISK_GET_DRIVE_LAYOUT_EX CTL_CODE(IOCTL_DISK_BASE,0x14,METHOD_BUFFERED,FILE_ANY_ACCESS)
60 #define IOCTL_DISK_SET_DRIVE_LAYOUT_EX CTL_CODE(IOCTL_DISK_BASE,0x15,METHOD_BUFFERED,FILE_READ_ACCESS | FILE_WRITE_ACCESS)
61 #define IOCTL_DISK_CREATE_DISK CTL_CODE(IOCTL_DISK_BASE,0x16,METHOD_BUFFERED,FILE_READ_ACCESS | FILE_WRITE_ACCESS)
62 #define IOCTL_DISK_GET_LENGTH_INFO CTL_CODE(IOCTL_DISK_BASE,0x17,METHOD_BUFFERED,FILE_READ_ACCESS)
63 #define IOCTL_DISK_PERFORMANCE_OFF CTL_CODE(IOCTL_DISK_BASE,0x18,METHOD_BUFFERED,FILE_ANY_ACCESS)
64 #define IOCTL_DISK_GET_DRIVE_GEOMETRY_EX CTL_CODE(IOCTL_DISK_BASE,0x28,METHOD_BUFFERED,FILE_ANY_ACCESS)
65 #define IOCTL_DISK_GROW_PARTITION CTL_CODE(IOCTL_DISK_BASE,0x34,METHOD_BUFFERED,FILE_READ_ACCESS | FILE_WRITE_ACCESS)
66 #define IOCTL_DISK_GET_CACHE_INFORMATION CTL_CODE(IOCTL_DISK_BASE,0x35,METHOD_BUFFERED,FILE_READ_ACCESS)
67 #define IOCTL_DISK_SET_CACHE_INFORMATION CTL_CODE(IOCTL_DISK_BASE,0x36,METHOD_BUFFERED,FILE_READ_ACCESS | FILE_WRITE_ACCESS)
68 #define IOCTL_DISK_DELETE_DRIVE_LAYOUT CTL_CODE(IOCTL_DISK_BASE,0x40,METHOD_BUFFERED,FILE_READ_ACCESS | FILE_WRITE_ACCESS)
69 #define IOCTL_DISK_UPDATE_PROPERTIES CTL_CODE(IOCTL_DISK_BASE,0x50,METHOD_BUFFERED,FILE_ANY_ACCESS)
70 #define IOCTL_DISK_CHECK_VERIFY CTL_CODE(IOCTL_DISK_BASE,0x200,METHOD_BUFFERED,FILE_READ_ACCESS)
71 #define IOCTL_DISK_MEDIA_REMOVAL CTL_CODE(IOCTL_DISK_BASE,0x201,METHOD_BUFFERED,FILE_READ_ACCESS)
72 #define IOCTL_DISK_EJECT_MEDIA CTL_CODE(IOCTL_DISK_BASE,0x202,METHOD_BUFFERED,FILE_READ_ACCESS)
73 #define IOCTL_DISK_LOAD_MEDIA CTL_CODE(IOCTL_DISK_BASE,0x203,METHOD_BUFFERED,FILE_READ_ACCESS)
74 #define IOCTL_DISK_RESERVE CTL_CODE(IOCTL_DISK_BASE,0x204,METHOD_BUFFERED,FILE_READ_ACCESS)
75 #define IOCTL_DISK_RELEASE CTL_CODE(IOCTL_DISK_BASE,0x205,METHOD_BUFFERED,FILE_READ_ACCESS)
76 #define IOCTL_DISK_FIND_NEW_DEVICES CTL_CODE(IOCTL_DISK_BASE,0x206,METHOD_BUFFERED,FILE_READ_ACCESS)
77 #define IOCTL_DISK_REMOVE_DEVICE CTL_CODE(IOCTL_DISK_BASE,0x207,METHOD_BUFFERED,FILE_READ_ACCESS)
78 #define IOCTL_DISK_GET_MEDIA_TYPES CTL_CODE(IOCTL_DISK_BASE,0x300,METHOD_BUFFERED,FILE_ANY_ACCESS)
79 #define IOCTL_DISK_UPDATE_DRIVE_SIZE CTL_CODE(IOCTL_DISK_BASE, 0x0032, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
80 #define IOCTL_SERIAL_LSRMST_INSERT CTL_CODE(FILE_DEVICE_SERIAL_PORT,31,METHOD_BUFFERED,FILE_ANY_ACCESS)
81 #define IOCTL_VOLUME_BASE ((DWORD)'V')
82 #define IOCTL_VOLUME_GET_VOLUME_DISK_EXTENTS CTL_CODE(IOCTL_VOLUME_BASE, 0, METHOD_BUFFERED, FILE_ANY_ACCESS)
83 #define FSCTL_LOCK_VOLUME CTL_CODE(FILE_DEVICE_FILE_SYSTEM,6,METHOD_BUFFERED,FILE_ANY_ACCESS)
84 #define FSCTL_UNLOCK_VOLUME CTL_CODE(FILE_DEVICE_FILE_SYSTEM,7,METHOD_BUFFERED,FILE_ANY_ACCESS)
85 #define FSCTL_PIPE_IMPERSONATE CTL_CODE(FILE_DEVICE_NAMED_PIPE, 7, METHOD_BUFFERED, FILE_ANY_ACCESS)
86 #define FSCTL_DISMOUNT_VOLUME CTL_CODE(FILE_DEVICE_FILE_SYSTEM,8,METHOD_BUFFERED,FILE_ANY_ACCESS)
87 #define FSCTL_MOUNT_DBLS_VOLUME CTL_CODE(FILE_DEVICE_FILE_SYSTEM,13,METHOD_BUFFERED,FILE_ANY_ACCESS)
88 #define FSCTL_GET_COMPRESSION CTL_CODE(FILE_DEVICE_FILE_SYSTEM,15,METHOD_BUFFERED,FILE_ANY_ACCESS)
89 #define FSCTL_SET_COMPRESSION CTL_CODE(FILE_DEVICE_FILE_SYSTEM,16,METHOD_BUFFERED,FILE_READ_DATA|FILE_WRITE_DATA)
90 #define FSCTL_READ_COMPRESSION CTL_CODE(FILE_DEVICE_FILE_SYSTEM,17,METHOD_NEITHER,FILE_READ_DATA)
91 #define FSCTL_WRITE_COMPRESSION CTL_CODE(FILE_DEVICE_FILE_SYSTEM,18,METHOD_NEITHER,FILE_WRITE_DATA)
92 #define FSCTL_GET_NTFS_VOLUME_DATA CTL_CODE(FILE_DEVICE_FILE_SYSTEM,25,METHOD_BUFFERED,FILE_ANY_ACCESS)
93 #define FSCTL_GET_VOLUME_BITMAP CTL_CODE(FILE_DEVICE_FILE_SYSTEM,27,METHOD_NEITHER,FILE_ANY_ACCESS)
94 #define FSCTL_GET_RETRIEVAL_POINTERS CTL_CODE(FILE_DEVICE_FILE_SYSTEM,28,METHOD_NEITHER,FILE_ANY_ACCESS)
95 #define FSCTL_MOVE_FILE CTL_CODE(FILE_DEVICE_FILE_SYSTEM,29,METHOD_BUFFERED,FILE_ANY_ACCESS)
96 #define FSCTL_GET_REPARSE_POINT CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 42, METHOD_BUFFERED, FILE_ANY_ACCESS)
97 #define FSCTL_SET_REPARSE_POINT CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 41, METHOD_BUFFERED, FILE_ANY_ACCESS)
98 #define FSCTL_DELETE_REPARSE_POINT CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 43, METHOD_BUFFERED, FILE_ANY_ACCESS)
99 #define FSCTL_SET_SPARSE CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 49, METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
100
101 #ifndef _DEVIOCTL_
102 #define _DEVIOCTL_
103
104 #define DEVICE_TYPE DWORD
105 #define FILE_DEVICE_BEEP 1
106 #define FILE_DEVICE_CD_ROM 2
107 #define FILE_DEVICE_CD_ROM_FILE_SYSTEM 3
108 #define FILE_DEVICE_CONTROLLER 4
109 #define FILE_DEVICE_DATALINK 5
110 #define FILE_DEVICE_DFS 6
111 #define FILE_DEVICE_DISK 7
112 #define FILE_DEVICE_DISK_FILE_SYSTEM 8
113 #define FILE_DEVICE_FILE_SYSTEM 9
114 #define FILE_DEVICE_INPORT_PORT 10
115 #define FILE_DEVICE_KEYBOARD 11
116 #define FILE_DEVICE_MAILSLOT 12
117 #define FILE_DEVICE_MIDI_IN 13
118 #define FILE_DEVICE_MIDI_OUT 14
119 #define FILE_DEVICE_MOUSE 15
120 #define FILE_DEVICE_MULTI_UNC_PROVIDER 16
121 #define FILE_DEVICE_NAMED_PIPE 17
122 #define FILE_DEVICE_NETWORK 18
123 #define FILE_DEVICE_NETWORK_BROWSER 19
124 #define FILE_DEVICE_NETWORK_FILE_SYSTEM 20
125 #define FILE_DEVICE_NULL 21
126 #define FILE_DEVICE_PARALLEL_PORT 22
127 #define FILE_DEVICE_PHYSICAL_NETCARD 23
128 #define FILE_DEVICE_PRINTER 24
129 #define FILE_DEVICE_SCANNER 25
130 #define FILE_DEVICE_SERIAL_MOUSE_PORT 26
131 #define FILE_DEVICE_SERIAL_PORT 27
132 #define FILE_DEVICE_SCREEN 28
133 #define FILE_DEVICE_SOUND 29
134 #define FILE_DEVICE_STREAMS 30
135 #define FILE_DEVICE_TAPE 31
136 #define FILE_DEVICE_TAPE_FILE_SYSTEM 32
137 #define FILE_DEVICE_TRANSPORT 33
138 #define FILE_DEVICE_UNKNOWN 34
139 #define FILE_DEVICE_VIDEO 35
140 #define FILE_DEVICE_VIRTUAL_DISK 36
141 #define FILE_DEVICE_WAVE_IN 37
142 #define FILE_DEVICE_WAVE_OUT 38
143 #define FILE_DEVICE_8042_PORT 39
144 #define FILE_DEVICE_NETWORK_REDIRECTOR 40
145 #define FILE_DEVICE_BATTERY 41
146 #define FILE_DEVICE_BUS_EXTENDER 42
147 #define FILE_DEVICE_MODEM 43
148 #define FILE_DEVICE_VDM 44
149 #define FILE_DEVICE_MASS_STORAGE 45
150 #define FILE_DEVICE_SMB 46
151 #define FILE_DEVICE_KS 47
152 #define FILE_DEVICE_CHANGER 48
153 #define FILE_DEVICE_SMARTCARD 49
154 #define FILE_DEVICE_ACPI 50
155 #define FILE_DEVICE_DVD 51
156 #define FILE_DEVICE_FULLSCREEN_VIDEO 52
157 #define FILE_DEVICE_DFS_FILE_SYSTEM 53
158 #define FILE_DEVICE_DFS_VOLUME 54
159 #define FILE_DEVICE_SERENUM 55
160 #define FILE_DEVICE_TERMSRV 56
161 #define FILE_DEVICE_KSEC 57
162
163 /* Also in ddk/winddk.h */
164 #define FILE_ANY_ACCESS 0x00000000
165 #define FILE_SPECIAL_ACCESS FILE_ANY_ACCESS
166 #define FILE_READ_ACCESS 0x00000001
167 #define FILE_WRITE_ACCESS 0x00000002
168
169 #define METHOD_BUFFERED 0
170 #define METHOD_IN_DIRECT 1
171 #define METHOD_OUT_DIRECT 2
172 #define METHOD_NEITHER 3
173
174 #define CTL_CODE(t,f,m,a) (((t)<<16)|((a)<<14)|((f)<<2)|(m))
175 #define DEVICE_TYPE_FROM_CTL_CODE(c) (((DWORD)((c)&0xffff0000))>>16)
176
177 #endif /* _DEVIOCTL_ */
178
179 #define PARTITION_ENTRY_UNUSED 0
180 #define PARTITION_FAT_12 1
181 #define PARTITION_XENIX_1 2
182 #define PARTITION_XENIX_2 3
183 #define PARTITION_FAT_16 4
184 #define PARTITION_EXTENDED 5
185 #define PARTITION_HUGE 6
186 #define PARTITION_IFS 7
187 #define PARTITION_FAT32 0x0B
188 #define PARTITION_FAT32_XINT13 0x0C
189 #define PARTITION_XINT13 0x0E
190 #define PARTITION_XINT13_EXTENDED 0x0F
191 #define PARTITION_PREP 0x41
192 #define PARTITION_LDM 0x42
193 #define PARTITION_UNIX 0x63
194 #define PARTITION_NTFT 128
195 #define VALID_NTFT 0xC0
196 #define SERIAL_LSRMST_ESCAPE 0
197 #define SERIAL_LSRMST_LSR_DATA 1
198 #define SERIAL_LSRMST_LSR_NODATA 2
199 #define SERIAL_LSRMST_MST 3
200 /* Device GUIDs */
201 #ifdef DEFINE_GUID
202
203 DEFINE_GUID(GUID_DEVINTERFACE_COMPORT, 0x86E0D1E0L, 0x8089,
204 0x11D0, 0x9C, 0xE4, 0x08, 0x00, 0x3E, 0x30, 0x1F, 0x73);
205 DEFINE_GUID(GUID_DEVINTERFACE_SERENUM_BUS_ENUMERATOR, 0x4D36E978L, 0xE325,
206 0x11CE, 0xBF, 0xC1, 0x08, 0x00, 0x2B, 0xE1, 0x03, 0x18);
207
208 /* obsolete GUID names */
209 #define GUID_CLASS_COMPORT GUID_DEVINTERFACE_COMPORT
210 #define GUID_SERENUM_BUS_ENUMERATOR GUID_DEVINTERFACE_SERENUM_BUS_ENUMERATOR
211
212 #endif /* DEFINE_GUID */
213
214 #define DISK_LOGGING_START 0
215 #define DISK_LOGGING_STOP 1
216 #define DISK_LOGGING_DUMP 2
217 #define DISK_BINNING 3
218 typedef WORD BAD_TRACK_NUMBER,*PBAD_TRACK_NUMBER;
219 typedef enum _BIN_TYPES {RequestSize,RequestLocation} BIN_TYPES;
220 typedef struct _BIN_RANGE {
221 LARGE_INTEGER StartValue;
222 LARGE_INTEGER Length;
223 } BIN_RANGE,*PBIN_RANGE;
224 typedef struct _BIN_COUNT {
225 BIN_RANGE BinRange;
226 DWORD BinCount;
227 } BIN_COUNT,*PBIN_COUNT;
228 typedef struct _BIN_RESULTS {
229 DWORD NumberOfBins;
230 BIN_COUNT BinCounts[1];
231 } BIN_RESULTS,*PBIN_RESULTS;
232 typedef enum _PARTITION_STYLE {
233 PARTITION_STYLE_MBR,
234 PARTITION_STYLE_GPT,
235 PARTITION_STYLE_RAW
236 } PARTITION_STYLE;
237 typedef struct {
238 GUID DiskId;
239 DWORD MaxPartitionCount;
240 } CREATE_DISK_GPT,*PCREATE_DISK_GPT;
241 typedef struct {
242 DWORD Signature;
243 } CREATE_DISK_MBR,*PCREATE_DISK_MBR;
244 typedef struct {
245 PARTITION_STYLE PartitionStyle;
246 _ANONYMOUS_UNION union {
247 CREATE_DISK_MBR Mbr;
248 CREATE_DISK_GPT Gpt;
249 };
250 } CREATE_DISK,*PCREATE_DISK;
251 typedef enum {
252 EqualPriority,
253 KeepPrefetchedData,
254 KeepReadData
255 } DISK_CACHE_RETENTION_PRIORITY;
256 typedef struct _DISK_CACHE_INFORMATION {
257 BOOLEAN ParametersSavable;
258 BOOLEAN ReadCacheEnabled;
259 BOOLEAN WriteCacheEnabled;
260 DISK_CACHE_RETENTION_PRIORITY ReadRetentionPriority;
261 DISK_CACHE_RETENTION_PRIORITY WriteRetentionPriority;
262 WORD DisablePrefetchTransferLength;
263 BOOLEAN PrefetchScalar;
264 _ANONYMOUS_UNION union {
265 struct {
266 WORD Minimum;
267 WORD Maximum;
268 WORD MaximumBlocks;
269 } ScalarPrefetch;
270 struct {
271 WORD Minimum;
272 WORD Maximum;
273 } BlockPrefetch;
274 };
275 } DISK_CACHE_INFORMATION,*PDISK_CACHE_INFORMATION;
276 typedef enum _DETECTION_TYPE {
277 DetectNone,
278 DetectInt13,
279 DetectExInt13
280 } DETECTION_TYPE;
281 typedef struct _DISK_INT13_INFO {
282 WORD DriveSelect;
283 DWORD MaxCylinders;
284 WORD SectorsPerTrack;
285 WORD MaxHeads;
286 WORD NumberDrives;
287 } DISK_INT13_INFO,*PDISK_INT13_INFO;
288 typedef struct _DISK_EX_INT13_INFO {
289 WORD ExBufferSize;
290 WORD ExFlags;
291 DWORD ExCylinders;
292 DWORD ExHeads;
293 DWORD ExSectorsPerTrack;
294 DWORD64 ExSectorsPerDrive;
295 WORD ExSectorSize;
296 WORD ExReserved;
297 } DISK_EX_INT13_INFO,*PDISK_EX_INT13_INFO;
298 typedef struct _DISK_DETECTION_INFO {
299 DWORD SizeOfDetectInfo;
300 DETECTION_TYPE DetectionType;
301 _ANONYMOUS_UNION union {
302 _ANONYMOUS_STRUCT struct {
303 DISK_INT13_INFO Int13;
304 DISK_EX_INT13_INFO ExInt13;
305 };
306 };
307 } DISK_DETECTION_INFO,*PDISK_DETECTION_INFO;
308 typedef enum _MEDIA_TYPE {
309 Unknown,
310 F5_1Pt2_512,
311 F3_1Pt44_512,
312 F3_2Pt88_512,
313 F3_20Pt8_512,
314 F3_720_512,
315 F5_360_512,
316 F5_320_512,
317 F5_320_1024,
318 F5_180_512,
319 F5_160_512,
320 RemovableMedia,
321 FixedMedia,
322 F3_120M_512,
323 F3_640_512,
324 F5_640_512,
325 F5_720_512,
326 F3_1Pt2_512,
327 F3_1Pt23_1024,
328 F5_1Pt23_1024,
329 F3_128Mb_512,
330 F3_230Mb_512,
331 F8_256_128,
332 F3_200Mb_512,
333 F3_240M_512,
334 F3_32M_512
335 } MEDIA_TYPE,*PMEDIA_TYPE;
336 typedef struct _DISK_GEOMETRY {
337 LARGE_INTEGER Cylinders;
338 MEDIA_TYPE MediaType;
339 DWORD TracksPerCylinder;
340 DWORD SectorsPerTrack;
341 DWORD BytesPerSector;
342 } DISK_GEOMETRY,*PDISK_GEOMETRY;
343 typedef struct _DISK_GEOMETRY_EX {
344 DISK_GEOMETRY Geometry;
345 LARGE_INTEGER DiskSize;
346 BYTE Data[1];
347 } DISK_GEOMETRY_EX,*PDISK_GEOMETRY_EX;
348 typedef struct _DISK_GROW_PARTITION {
349 DWORD PartitionNumber;
350 LARGE_INTEGER BytesToGrow;
351 } DISK_GROW_PARTITION, *PDISK_GROW_PARTITION;
352 typedef struct _DISK_PARTITION_INFO {
353 DWORD SizeOfPartitionInfo;
354 PARTITION_STYLE PartitionStyle;
355 _ANONYMOUS_UNION union {
356 struct {
357 DWORD Signature;
358 } Mbr;
359 struct {
360 GUID DiskId;
361 } Gpt;
362 };
363 } DISK_PARTITION_INFO,*PDISK_PARTITION_INFO;
364 typedef struct _DISK_PERFORMANCE {
365 LARGE_INTEGER BytesRead;
366 LARGE_INTEGER BytesWritten;
367 LARGE_INTEGER ReadTime;
368 LARGE_INTEGER WriteTime;
369 DWORD ReadCount;
370 DWORD WriteCount;
371 DWORD QueueDepth;
372 } DISK_PERFORMANCE, *PDISK_PERFORMANCE;
373 typedef struct _DISK_RECORD {
374 LARGE_INTEGER ByteOffset;
375 LARGE_INTEGER StartTime;
376 LARGE_INTEGER EndTime;
377 PVOID VirtualAddress;
378 DWORD NumberOfBytes;
379 BYTE DeviceNumber;
380 BOOLEAN ReadRequest;
381 } DISK_RECORD,*PDISK_RECORD;
382 typedef struct _DISK_LOGGING {
383 BYTE Function;
384 PVOID BufferAddress;
385 DWORD BufferSize;
386 } DISK_LOGGING,*PDISK_LOGGING;
387 typedef struct DiskQuotaUserInformation {
388 LONGLONG QuotaUsed;
389 LONGLONG QuotaThreshold;
390 LONGLONG QuotaLimit;
391 } DISKQUOTA_USER_INFORMATION,*PDISKQUOTA_USER_INFORMATION;
392 typedef struct _FORMAT_PARAMETERS {
393 MEDIA_TYPE MediaType;
394 DWORD StartCylinderNumber;
395 DWORD EndCylinderNumber;
396 DWORD StartHeadNumber;
397 DWORD EndHeadNumber;
398 } FORMAT_PARAMETERS,*PFORMAT_PARAMETERS;
399 typedef struct _FORMAT_EX_PARAMETERS {
400 MEDIA_TYPE MediaType;
401 DWORD StartCylinderNumber;
402 DWORD EndCylinderNumber;
403 DWORD StartHeadNumber;
404 DWORD EndHeadNumber;
405 WORD FormatGapLength;
406 WORD SectorsPerTrack;
407 WORD SectorNumber[1];
408 } FORMAT_EX_PARAMETERS,*PFORMAT_EX_PARAMETERS;
409 typedef struct {
410 LARGE_INTEGER Length;
411 } GET_LENGTH_INFORMATION;
412 typedef struct _HISTOGRAM_BUCKET {
413 DWORD Reads;
414 DWORD Writes;
415 } HISTOGRAM_BUCKET,*PHISTOGRAM_BUCKET;
416 typedef struct _DISK_HISTOGRAM {
417 LARGE_INTEGER DiskSize;
418 LARGE_INTEGER Start;
419 LARGE_INTEGER End;
420 LARGE_INTEGER Average;
421 LARGE_INTEGER AverageRead;
422 LARGE_INTEGER AverageWrite;
423 DWORD Granularity;
424 DWORD Size;
425 DWORD ReadCount;
426 DWORD WriteCount;
427 PHISTOGRAM_BUCKET Histogram;
428 } DISK_HISTOGRAM,*PDISK_HISTOGRAM;
429 typedef struct _DISK_EXTENT {
430 DWORD DiskNumber;
431 LARGE_INTEGER StartingOffset;
432 LARGE_INTEGER ExtentLength;
433 } DISK_EXTENT,*PDISK_EXTENT;
434 typedef struct _VOLUME_DISK_EXTENTS {
435 DWORD NumberOfDiskExtents;
436 DISK_EXTENT Extents[1];
437 } VOLUME_DISK_EXTENTS,*PVOLUME_DISK_EXTENTS;
438 typedef struct _PARTITION_INFORMATION {
439 LARGE_INTEGER StartingOffset;
440 LARGE_INTEGER PartitionLength;
441 DWORD HiddenSectors;
442 DWORD PartitionNumber;
443 BYTE PartitionType;
444 BOOLEAN BootIndicator;
445 BOOLEAN RecognizedPartition;
446 BOOLEAN RewritePartition;
447 } PARTITION_INFORMATION,*PPARTITION_INFORMATION;
448 typedef struct _DRIVE_LAYOUT_INFORMATION {
449 DWORD PartitionCount;
450 DWORD Signature;
451 PARTITION_INFORMATION PartitionEntry[1];
452 } DRIVE_LAYOUT_INFORMATION, *PDRIVE_LAYOUT_INFORMATION;
453 typedef struct _DRIVE_LAYOUT_INFORMATION_GPT {
454 GUID DiskId;
455 LARGE_INTEGER StartingUsableOffset;
456 LARGE_INTEGER UsableLength;
457 ULONG MaxPartitionCount;
458 } DRIVE_LAYOUT_INFORMATION_GPT,*PDRIVE_LAYOUT_INFORMATION_GPT;
459 typedef struct _DRIVE_LAYOUT_INFORMATION_MBR {
460 ULONG Signature;
461 } DRIVE_LAYOUT_INFORMATION_MBR, *PDRIVE_LAYOUT_INFORMATION_MBR;
462 typedef struct _PARTITION_INFORMATION_MBR {
463 BYTE PartitionType;
464 BOOLEAN BootIndicator;
465 BOOLEAN RecognizedPartition;
466 DWORD HiddenSectors;
467 } PARTITION_INFORMATION_MBR;
468 typedef struct _PARTITION_INFORMATION_GPT {
469 GUID PartitionType;
470 GUID PartitionId;
471 DWORD64 Attributes;
472 WCHAR Name[36];
473 } PARTITION_INFORMATION_GPT;
474 typedef struct _PARTITION_INFORMATION_EX {
475 PARTITION_STYLE PartitionStyle;
476 LARGE_INTEGER StartingOffset;
477 LARGE_INTEGER PartitionLength;
478 DWORD PartitionNumber;
479 BOOLEAN RewritePartition;
480 _ANONYMOUS_UNION union {
481 PARTITION_INFORMATION_MBR Mbr;
482 PARTITION_INFORMATION_GPT Gpt;
483 };
484 } PARTITION_INFORMATION_EX;
485 typedef struct _DRIVE_LAYOUT_INFORMATION_EX {
486 DWORD PartitionStyle;
487 DWORD PartitionCount;
488 _ANONYMOUS_UNION union {
489 DRIVE_LAYOUT_INFORMATION_MBR Mbr;
490 DRIVE_LAYOUT_INFORMATION_GPT Gpt;
491 };
492 PARTITION_INFORMATION_EX PartitionEntry[1];
493 } DRIVE_LAYOUT_INFORMATION_EX,*PDRIVE_LAYOUT_INFORMATION_EX;
494 typedef struct {
495 HANDLE FileHandle;
496 LARGE_INTEGER StartingVcn;
497 LARGE_INTEGER StartingLcn;
498 DWORD ClusterCount;
499 } MOVE_FILE_DATA,*PMOVE_FILE_DATA;
500 typedef struct _PERF_BIN {
501 DWORD NumberOfBins;
502 DWORD TypeOfBin;
503 BIN_RANGE BinsRanges[1];
504 } PERF_BIN,*PPERF_BIN;
505
506 #ifndef _NTDDSTOR_H_
507 typedef struct _PREVENT_MEDIA_REMOVAL {
508 BOOLEAN PreventMediaRemoval;
509 } PREVENT_MEDIA_REMOVAL,*PPREVENT_MEDIA_REMOVAL;
510 #endif
511
512 typedef struct RETRIEVAL_POINTERS_BUFFER {
513 DWORD ExtentCount;
514 LARGE_INTEGER StartingVcn;
515 struct {
516 LARGE_INTEGER NextVcn;
517 LARGE_INTEGER Lcn;
518 } Extents[1];
519 } RETRIEVAL_POINTERS_BUFFER,*PRETRIEVAL_POINTERS_BUFFER;
520 typedef struct _REASSIGN_BLOCKS {
521 WORD Reserved;
522 WORD Count;
523 DWORD BlockNumber[1];
524 } REASSIGN_BLOCKS,*PREASSIGN_BLOCKS;
525 typedef struct _SET_PARTITION_INFORMATION {
526 BYTE PartitionType;
527 } SET_PARTITION_INFORMATION,*PSET_PARTITION_INFORMATION;
528 typedef struct {
529 LARGE_INTEGER StartingLcn;
530 } STARTING_LCN_INPUT_BUFFER,*PSTARTING_LCN_INPUT_BUFFER;
531 typedef struct {
532 LARGE_INTEGER StartingVcn;
533 } STARTING_VCN_INPUT_BUFFER,*PSTARTING_VCN_INPUT_BUFFER;
534 typedef struct _VERIFY_INFORMATION {
535 LARGE_INTEGER StartingOffset;
536 DWORD Length;
537 } VERIFY_INFORMATION,*PVERIFY_INFORMATION;
538 typedef struct {
539 LARGE_INTEGER StartingLcn;
540 LARGE_INTEGER BitmapSize;
541 BYTE Buffer[1];
542 } VOLUME_BITMAP_BUFFER,*PVOLUME_BITMAP_BUFFER;
543 typedef struct {
544 LARGE_INTEGER VolumeSerialNumber;
545 LARGE_INTEGER NumberSectors;
546 LARGE_INTEGER TotalClusters;
547 LARGE_INTEGER FreeClusters;
548 LARGE_INTEGER TotalReserved;
549 DWORD BytesPerSector;
550 DWORD BytesPerCluster;
551 DWORD BytesPerFileRecordSegment;
552 DWORD ClustersPerFileRecordSegment;
553 LARGE_INTEGER MftValidDataLength;
554 LARGE_INTEGER MftStartLcn;
555 LARGE_INTEGER Mft2StartLcn;
556 LARGE_INTEGER MftZoneStart;
557 LARGE_INTEGER MftZoneEnd;
558 } NTFS_VOLUME_DATA_BUFFER, *PNTFS_VOLUME_DATA_BUFFER;
559
560 #define IsRecognizedPartition(t)\
561 (((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_FAT_12))||\
562 ((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_FAT_16))||\
563 ((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_IFS))||\
564 ((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_HUGE))||\
565 ((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_FAT32))||\
566 ((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_FAT32_XINT13))||\
567 ((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_XINT13))||\
568 ((t&~PARTITION_NTFT)==PARTITION_FAT_12)||\
569 ((t&~PARTITION_NTFT)==PARTITION_FAT_16)||\
570 ((t&~PARTITION_NTFT)==PARTITION_IFS)||\
571 ((t&~PARTITION_NTFT)==PARTITION_HUGE)||\
572 ((t&~PARTITION_NTFT)==PARTITION_FAT32)||\
573 ((t&~PARTITION_NTFT)==PARTITION_FAT32_XINT13)||\
574 ((t&~PARTITION_NTFT)==PARTITION_XINT13))
575 #define IsContainerPartition(t)\
576 (((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_EXTENDED))||\
577 ((t&PARTITION_NTFT)&&((t&~VALID_NTFT)==PARTITION_XINT13_EXTENDED))||\
578 ((t&~PARTITION_NTFT)==PARTITION_EXTENDED)||\
579 ((t&~PARTITION_NTFT)==PARTITION_XINT13_EXTENDED))
580
581 #ifdef _MSC_VER
582 #pragma warning(pop)
583 #endif
584
585 #ifdef __cplusplus
586 }
587 #endif
588 #endif /* _WINIOCTL_ */