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