1 |
|
---|
2 | #pragma once
|
---|
3 |
|
---|
4 | #define _CLASS_
|
---|
5 |
|
---|
6 | #include <ntdddisk.h>
|
---|
7 | #include <ntddcdrm.h>
|
---|
8 | #include <ntddtape.h>
|
---|
9 | #include <ntddscsi.h>
|
---|
10 | #include <ntddstor.h>
|
---|
11 |
|
---|
12 | #include <stdio.h>
|
---|
13 |
|
---|
14 | #include <scsi.h>
|
---|
15 |
|
---|
16 | #define max(a,b) (((a) > (b)) ? (a) : (b))
|
---|
17 | #define min(a,b) (((a) < (b)) ? (a) : (b))
|
---|
18 |
|
---|
19 | #define SRB_CLASS_FLAGS_LOW_PRIORITY 0x10000000
|
---|
20 | #define SRB_CLASS_FLAGS_PERSISTANT 0x20000000
|
---|
21 | #define SRB_CLASS_FLAGS_PAGING 0x40000000
|
---|
22 | #define SRB_CLASS_FLAGS_FREE_MDL 0x80000000
|
---|
23 |
|
---|
24 | #define ASSERT_FDO(x) \
|
---|
25 | ASSERT(((PCOMMON_DEVICE_EXTENSION) (x)->DeviceExtension)->IsFdo)
|
---|
26 |
|
---|
27 | #define ASSERT_PDO(x) \
|
---|
28 | ASSERT(!(((PCOMMON_DEVICE_EXTENSION) (x)->DeviceExtension)->IsFdo))
|
---|
29 |
|
---|
30 | #define IS_CLEANUP_REQUEST(majorFunction) \
|
---|
31 | ((majorFunction == IRP_MJ_CLOSE) || \
|
---|
32 | (majorFunction == IRP_MJ_CLEANUP) || \
|
---|
33 | (majorFunction == IRP_MJ_SHUTDOWN))
|
---|
34 |
|
---|
35 | #define DO_MCD(fdoExtension) \
|
---|
36 | (((fdoExtension)->MediaChangeDetectionInfo != NULL) && \
|
---|
37 | ((fdoExtension)->MediaChangeDetectionInfo->MediaChangeDetectionDisableCount == 0))
|
---|
38 |
|
---|
39 | #define IS_SCSIOP_READ(opCode) \
|
---|
40 | ((opCode == SCSIOP_READ6) || \
|
---|
41 | (opCode == SCSIOP_READ) || \
|
---|
42 | (opCode == SCSIOP_READ12) || \
|
---|
43 | (opCode == SCSIOP_READ16))
|
---|
44 |
|
---|
45 | #define IS_SCSIOP_WRITE(opCode) \
|
---|
46 | ((opCode == SCSIOP_WRITE6) || \
|
---|
47 | (opCode == SCSIOP_WRITE) || \
|
---|
48 | (opCode == SCSIOP_WRITE12) || \
|
---|
49 | (opCode == SCSIOP_WRITE16))
|
---|
50 |
|
---|
51 | #define IS_SCSIOP_READWRITE(opCode) (IS_SCSIOP_READ(opCode) || IS_SCSIOP_WRITE(opCode))
|
---|
52 |
|
---|
53 | #define ADJUST_FUA_FLAG(fdoExt) { \
|
---|
54 | if (TEST_FLAG(fdoExt->DeviceFlags, DEV_WRITE_CACHE) && \
|
---|
55 | !TEST_FLAG(fdoExt->DeviceFlags, DEV_POWER_PROTECTED) && \
|
---|
56 | !TEST_FLAG(fdoExt->ScanForSpecialFlags, CLASS_SPECIAL_FUA_NOT_SUPPORTED) ) { \
|
---|
57 | fdoExt->CdbForceUnitAccess = TRUE; \
|
---|
58 | } else { \
|
---|
59 | fdoExt->CdbForceUnitAccess = FALSE; \
|
---|
60 | } \
|
---|
61 | }
|
---|
62 |
|
---|
63 | #define FREE_POOL(_PoolPtr) \
|
---|
64 | if (_PoolPtr != NULL) { \
|
---|
65 | ExFreePool(_PoolPtr); \
|
---|
66 | _PoolPtr = NULL; \
|
---|
67 | }
|
---|
68 |
|
---|
69 | #ifdef POOL_TAGGING
|
---|
70 | #undef ExAllocatePool
|
---|
71 | #undef ExAllocatePoolWithQuota
|
---|
72 | #define ExAllocatePool(a,b) ExAllocatePoolWithTag(a,b,'nUcS')
|
---|
73 | //#define ExAllocatePool(a,b) #assert(0)
|
---|
74 | #define ExAllocatePoolWithQuota(a,b) ExAllocatePoolWithQuotaTag(a,b,'nUcS')
|
---|
75 | #endif
|
---|
76 |
|
---|
77 | #define CLASS_TAG_AUTORUN_DISABLE 'ALcS'
|
---|
78 | #define CLASS_TAG_FILE_OBJECT_EXTENSION 'FLcS'
|
---|
79 | #define CLASS_TAG_MEDIA_CHANGE_DETECTION 'MLcS'
|
---|
80 | #define CLASS_TAG_MOUNT 'mLcS'
|
---|
81 | #define CLASS_TAG_RELEASE_QUEUE 'qLcS'
|
---|
82 | #define CLASS_TAG_POWER 'WLcS'
|
---|
83 | #define CLASS_TAG_WMI 'wLcS'
|
---|
84 | #define CLASS_TAG_FAILURE_PREDICT 'fLcS'
|
---|
85 | #define CLASS_TAG_DEVICE_CONTROL 'OIcS'
|
---|
86 | #define CLASS_TAG_MODE_DATA 'oLcS'
|
---|
87 | #define CLASS_TAG_MULTIPATH 'mPcS'
|
---|
88 |
|
---|
89 | #define MAXIMUM_RETRIES 4
|
---|
90 |
|
---|
91 | #define CLASS_DRIVER_EXTENSION_KEY ((PVOID) ClassInitialize)
|
---|
92 |
|
---|
93 | #define NO_REMOVE 0
|
---|
94 | #define REMOVE_PENDING 1
|
---|
95 | #define REMOVE_COMPLETE 2
|
---|
96 |
|
---|
97 | #define ClassAcquireRemoveLock(devobj, tag) \
|
---|
98 | ClassAcquireRemoveLockEx(devobj, tag, __FILE__, __LINE__)
|
---|
99 |
|
---|
100 | #ifdef TRY
|
---|
101 | #undef TRY
|
---|
102 | #endif
|
---|
103 | #ifdef LEAVE
|
---|
104 | #undef LEAVE
|
---|
105 | #endif
|
---|
106 |
|
---|
107 | #ifdef FINALLY
|
---|
108 | #undef FINALLY
|
---|
109 | #endif
|
---|
110 |
|
---|
111 | #define TRY
|
---|
112 | #define LEAVE goto __tryLabel;
|
---|
113 | #define FINALLY __tryLabel:
|
---|
114 |
|
---|
115 | #if defined DebugPrint
|
---|
116 | #undef DebugPrint
|
---|
117 | #endif
|
---|
118 |
|
---|
119 | #if DBG
|
---|
120 | #define DebugPrint(x) ClassDebugPrint x
|
---|
121 | #else
|
---|
122 | #define DebugPrint(x)
|
---|
123 | #endif
|
---|
124 |
|
---|
125 | #define DEBUG_BUFFER_LENGTH 256
|
---|
126 |
|
---|
127 | #define START_UNIT_TIMEOUT (60 * 4)
|
---|
128 |
|
---|
129 | #define MEDIA_CHANGE_DEFAULT_TIME 1
|
---|
130 | #define MEDIA_CHANGE_TIMEOUT_TIME 300
|
---|
131 |
|
---|
132 | #define MAXIMUM_RETRY_FOR_SINGLE_IO_IN_100NS_UNITS 0x3b9aca00
|
---|
133 |
|
---|
134 | #ifdef ALLOCATE_SRB_FROM_POOL
|
---|
135 |
|
---|
136 | #define ClasspAllocateSrb(ext) \
|
---|
137 | ExAllocatePoolWithTag(NonPagedPool, \
|
---|
138 | sizeof(SCSI_REQUEST_BLOCK), \
|
---|
139 | 'sBRS')
|
---|
140 |
|
---|
141 | #define ClasspFreeSrb(ext, srb) ExFreePool((srb));
|
---|
142 |
|
---|
143 | #else /* ALLOCATE_SRB_FROM_POOL */
|
---|
144 |
|
---|
145 | #define ClasspAllocateSrb(ext) \
|
---|
146 | ExAllocateFromNPagedLookasideList( \
|
---|
147 | &((ext)->CommonExtension.SrbLookasideList))
|
---|
148 |
|
---|
149 | #define ClasspFreeSrb(ext, srb) \
|
---|
150 | ExFreeToNPagedLookasideList( \
|
---|
151 | &((ext)->CommonExtension.SrbLookasideList), \
|
---|
152 | (srb))
|
---|
153 |
|
---|
154 | #endif /* ALLOCATE_SRB_FROM_POOL */
|
---|
155 |
|
---|
156 | #define SET_FLAG(Flags, Bit) ((Flags) |= (Bit))
|
---|
157 | #define CLEAR_FLAG(Flags, Bit) ((Flags) &= ~(Bit))
|
---|
158 | #define TEST_FLAG(Flags, Bit) (((Flags) & (Bit)) != 0)
|
---|
159 |
|
---|
160 | #define CLASS_WORKING_SET_MAXIMUM 2048
|
---|
161 |
|
---|
162 | #define CLASS_INTERPRET_SENSE_INFO2_MAXIMUM_HISTORY_COUNT 30000
|
---|
163 |
|
---|
164 | #define CLASS_SPECIAL_DISABLE_SPIN_DOWN 0x00000001
|
---|
165 | #define CLASS_SPECIAL_DISABLE_SPIN_UP 0x00000002
|
---|
166 | #define CLASS_SPECIAL_NO_QUEUE_LOCK 0x00000008
|
---|
167 | #define CLASS_SPECIAL_DISABLE_WRITE_CACHE 0x00000010
|
---|
168 | #define CLASS_SPECIAL_CAUSE_NOT_REPORTABLE_HACK 0x00000020
|
---|
169 | #if ((NTDDI_VERSION == NTDDI_WIN2KSP3) || (OSVER(NTDDI_VERSION) == NTDDI_WINXP))
|
---|
170 | #define CLASS_SPECIAL_DISABLE_WRITE_CACHE_NOT_SUPPORTED 0x00000040
|
---|
171 | #endif
|
---|
172 | #define CLASS_SPECIAL_MODIFY_CACHE_UNSUCCESSFUL 0x00000040
|
---|
173 | #define CLASS_SPECIAL_FUA_NOT_SUPPORTED 0x00000080
|
---|
174 | #define CLASS_SPECIAL_VALID_MASK 0x000000FB
|
---|
175 | #define CLASS_SPECIAL_RESERVED (~CLASS_SPECIAL_VALID_MASK)
|
---|
176 |
|
---|
177 | #define DEV_WRITE_CACHE 0x00000001
|
---|
178 | #define DEV_USE_SCSI1 0x00000002
|
---|
179 | #define DEV_SAFE_START_UNIT 0x00000004
|
---|
180 | #define DEV_NO_12BYTE_CDB 0x00000008
|
---|
181 | #define DEV_POWER_PROTECTED 0x00000010
|
---|
182 | #define DEV_USE_16BYTE_CDB 0x00000020
|
---|
183 |
|
---|
184 | #define GUID_CLASSPNP_QUERY_REGINFOEX {0x00e34b11, 0x2444, 0x4745, {0xa5, 0x3d, 0x62, 0x01, 0x00, 0xcd, 0x82, 0xf7}}
|
---|
185 | #define GUID_CLASSPNP_SENSEINFO2 {0x509a8c5f, 0x71d7, 0x48f6, {0x82, 0x1e, 0x17, 0x3c, 0x49, 0xbf, 0x2f, 0x18}}
|
---|
186 | #define GUID_CLASSPNP_WORKING_SET {0x105701b0, 0x9e9b, 0x47cb, {0x97, 0x80, 0x81, 0x19, 0x8a, 0xf7, 0xb5, 0x24}}
|
---|
187 |
|
---|
188 | #define DEFAULT_FAILURE_PREDICTION_PERIOD 60 * 60 * 1
|
---|
189 |
|
---|
190 | static inline ULONG CountOfSetBitsUChar(UCHAR _X)
|
---|
191 | { ULONG i = 0; while (_X) { _X &= _X - 1; i++; } return i; }
|
---|
192 | static inline ULONG CountOfSetBitsULong(ULONG _X)
|
---|
193 | { ULONG i = 0; while (_X) { _X &= _X - 1; i++; } return i; }
|
---|
194 | static inline ULONG CountOfSetBitsULong32(ULONG32 _X)
|
---|
195 | { ULONG i = 0; while (_X) { _X &= _X - 1; i++; } return i; }
|
---|
196 | static inline ULONG CountOfSetBitsULong64(ULONG64 _X)
|
---|
197 | { ULONG i = 0; while (_X) { _X &= _X - 1; i++; } return i; }
|
---|
198 | static inline ULONG CountOfSetBitsUlongPtr(ULONG_PTR _X)
|
---|
199 | { ULONG i = 0; while (_X) { _X &= _X - 1; i++; } return i; }
|
---|
200 |
|
---|
201 | typedef enum _MEDIA_CHANGE_DETECTION_STATE {
|
---|
202 | MediaUnknown,
|
---|
203 | MediaPresent,
|
---|
204 | MediaNotPresent,
|
---|
205 | MediaUnavailable
|
---|
206 | } MEDIA_CHANGE_DETECTION_STATE, *PMEDIA_CHANGE_DETECTION_STATE;
|
---|
207 |
|
---|
208 | typedef enum _CLASS_DEBUG_LEVEL {
|
---|
209 | ClassDebugError = 0,
|
---|
210 | ClassDebugWarning = 1,
|
---|
211 | ClassDebugTrace = 2,
|
---|
212 | ClassDebugInfo = 3,
|
---|
213 | ClassDebugMediaLocks = 8,
|
---|
214 | ClassDebugMCN = 9,
|
---|
215 | ClassDebugDelayedRetry = 10,
|
---|
216 | ClassDebugSenseInfo = 11,
|
---|
217 | ClassDebugRemoveLock = 12,
|
---|
218 | ClassDebugExternal4 = 13,
|
---|
219 | ClassDebugExternal3 = 14,
|
---|
220 | ClassDebugExternal2 = 15,
|
---|
221 | ClassDebugExternal1 = 16
|
---|
222 | } CLASS_DEBUG_LEVEL, *PCLASS_DEBUG_LEVEL;
|
---|
223 |
|
---|
224 | typedef enum {
|
---|
225 | EventGeneration,
|
---|
226 | DataBlockCollection
|
---|
227 | } CLASSENABLEDISABLEFUNCTION;
|
---|
228 |
|
---|
229 | typedef enum {
|
---|
230 | FailurePredictionNone = 0,
|
---|
231 | FailurePredictionIoctl,
|
---|
232 | FailurePredictionSmart,
|
---|
233 | FailurePredictionSense
|
---|
234 | } FAILURE_PREDICTION_METHOD, *PFAILURE_PREDICTION_METHOD;
|
---|
235 |
|
---|
236 | typedef enum {
|
---|
237 | PowerDownDeviceInitial,
|
---|
238 | PowerDownDeviceLocked,
|
---|
239 | PowerDownDeviceStopped,
|
---|
240 | PowerDownDeviceOff,
|
---|
241 | PowerDownDeviceUnlocked
|
---|
242 | } CLASS_POWER_DOWN_STATE;
|
---|
243 |
|
---|
244 | typedef enum {
|
---|
245 | PowerDownDeviceInitial2,
|
---|
246 | PowerDownDeviceLocked2,
|
---|
247 | PowerDownDeviceFlushed2,
|
---|
248 | PowerDownDeviceStopped2,
|
---|
249 | PowerDownDeviceOff2,
|
---|
250 | PowerDownDeviceUnlocked2
|
---|
251 | } CLASS_POWER_DOWN_STATE2;
|
---|
252 |
|
---|
253 | typedef enum {
|
---|
254 | PowerUpDeviceInitial,
|
---|
255 | PowerUpDeviceLocked,
|
---|
256 | PowerUpDeviceOn,
|
---|
257 | PowerUpDeviceStarted,
|
---|
258 | PowerUpDeviceUnlocked
|
---|
259 | } CLASS_POWER_UP_STATE;
|
---|
260 |
|
---|
261 | struct _CLASS_INIT_DATA;
|
---|
262 | typedef struct _CLASS_INIT_DATA CLASS_INIT_DATA, *PCLASS_INIT_DATA;
|
---|
263 |
|
---|
264 | struct _CLASS_PRIVATE_FDO_DATA;
|
---|
265 | typedef struct _CLASS_PRIVATE_FDO_DATA CLASS_PRIVATE_FDO_DATA, *PCLASS_PRIVATE_FDO_DATA;
|
---|
266 |
|
---|
267 | struct _CLASS_PRIVATE_PDO_DATA;
|
---|
268 | typedef struct _CLASS_PRIVATE_PDO_DATA CLASS_PRIVATE_PDO_DATA, *PCLASS_PRIVATE_PDO_DATA;
|
---|
269 |
|
---|
270 | struct _CLASS_PRIVATE_COMMON_DATA;
|
---|
271 | typedef struct _CLASS_PRIVATE_COMMON_DATA CLASS_PRIVATE_COMMON_DATA, *PCLASS_PRIVATE_COMMON_DATA;
|
---|
272 |
|
---|
273 | struct _MEDIA_CHANGE_DETECTION_INFO;
|
---|
274 | typedef struct _MEDIA_CHANGE_DETECTION_INFO MEDIA_CHANGE_DETECTION_INFO, *PMEDIA_CHANGE_DETECTION_INFO;
|
---|
275 |
|
---|
276 | typedef struct _DICTIONARY {
|
---|
277 | ULONGLONG Signature;
|
---|
278 | struct _DICTIONARY_HEADER* List;
|
---|
279 | KSPIN_LOCK SpinLock;
|
---|
280 | } DICTIONARY, *PDICTIONARY;
|
---|
281 |
|
---|
282 | typedef struct _CLASSPNP_SCAN_FOR_SPECIAL_INFO {
|
---|
283 | PCHAR VendorId;
|
---|
284 | PCHAR ProductId;
|
---|
285 | PCHAR ProductRevision;
|
---|
286 | ULONG_PTR Data;
|
---|
287 | } CLASSPNP_SCAN_FOR_SPECIAL_INFO, *PCLASSPNP_SCAN_FOR_SPECIAL_INFO;
|
---|
288 |
|
---|
289 | typedef VOID
|
---|
290 | (NTAPI *PCLASS_ERROR)(
|
---|
291 | PDEVICE_OBJECT DeviceObject,
|
---|
292 | PSCSI_REQUEST_BLOCK Srb,
|
---|
293 | NTSTATUS *Status,
|
---|
294 | BOOLEAN *Retry);
|
---|
295 |
|
---|
296 | typedef NTSTATUS
|
---|
297 | (NTAPI *PCLASS_ADD_DEVICE)(
|
---|
298 | PDRIVER_OBJECT DriverObject,
|
---|
299 | PDEVICE_OBJECT Pdo);
|
---|
300 |
|
---|
301 | typedef NTSTATUS
|
---|
302 | (NTAPI *PCLASS_POWER_DEVICE)(
|
---|
303 | PDEVICE_OBJECT DeviceObject,
|
---|
304 | PIRP Irp);
|
---|
305 |
|
---|
306 | typedef NTSTATUS
|
---|
307 | (NTAPI *PCLASS_START_DEVICE)(
|
---|
308 | PDEVICE_OBJECT DeviceObject);
|
---|
309 |
|
---|
310 | typedef NTSTATUS
|
---|
311 | (NTAPI *PCLASS_STOP_DEVICE)(
|
---|
312 | PDEVICE_OBJECT DeviceObject,
|
---|
313 | UCHAR Type);
|
---|
314 |
|
---|
315 | typedef NTSTATUS
|
---|
316 | (NTAPI *PCLASS_INIT_DEVICE)(
|
---|
317 | PDEVICE_OBJECT DeviceObject);
|
---|
318 |
|
---|
319 | typedef NTSTATUS
|
---|
320 | (NTAPI *PCLASS_ENUM_DEVICE)(
|
---|
321 | PDEVICE_OBJECT DeviceObject);
|
---|
322 |
|
---|
323 | typedef NTSTATUS
|
---|
324 | (NTAPI *PCLASS_READ_WRITE)(
|
---|
325 | PDEVICE_OBJECT DeviceObject,
|
---|
326 | PIRP Irp);
|
---|
327 |
|
---|
328 | typedef NTSTATUS
|
---|
329 | (NTAPI *PCLASS_DEVICE_CONTROL)(
|
---|
330 | PDEVICE_OBJECT DeviceObject,
|
---|
331 | PIRP Irp);
|
---|
332 |
|
---|
333 | typedef NTSTATUS
|
---|
334 | (NTAPI *PCLASS_SHUTDOWN_FLUSH)(
|
---|
335 | PDEVICE_OBJECT DeviceObject,
|
---|
336 | PIRP Irp);
|
---|
337 |
|
---|
338 | typedef NTSTATUS
|
---|
339 | (NTAPI *PCLASS_CREATE_CLOSE)(
|
---|
340 | PDEVICE_OBJECT DeviceObject,
|
---|
341 | PIRP Irp);
|
---|
342 |
|
---|
343 | typedef NTSTATUS
|
---|
344 | (NTAPI *PCLASS_QUERY_ID)(
|
---|
345 | PDEVICE_OBJECT DeviceObject,
|
---|
346 | BUS_QUERY_ID_TYPE IdType,
|
---|
347 | PUNICODE_STRING IdString);
|
---|
348 |
|
---|
349 | typedef NTSTATUS
|
---|
350 | (NTAPI *PCLASS_REMOVE_DEVICE)(
|
---|
351 | PDEVICE_OBJECT DeviceObject,
|
---|
352 | UCHAR Type);
|
---|
353 |
|
---|
354 | typedef VOID
|
---|
355 | (NTAPI *PCLASS_UNLOAD)(
|
---|
356 | PDRIVER_OBJECT DriverObject);
|
---|
357 |
|
---|
358 | typedef NTSTATUS
|
---|
359 | (NTAPI *PCLASS_QUERY_PNP_CAPABILITIES)(
|
---|
360 | PDEVICE_OBJECT PhysicalDeviceObject,
|
---|
361 | PDEVICE_CAPABILITIES Capabilities);
|
---|
362 |
|
---|
363 | typedef VOID
|
---|
364 | (NTAPI *PCLASS_TICK)(
|
---|
365 | PDEVICE_OBJECT DeviceObject);
|
---|
366 |
|
---|
367 | typedef NTSTATUS
|
---|
368 | (NTAPI *PCLASS_QUERY_WMI_REGINFO_EX)(
|
---|
369 | PDEVICE_OBJECT DeviceObject,
|
---|
370 | ULONG *RegFlags,
|
---|
371 | PUNICODE_STRING Name,
|
---|
372 | PUNICODE_STRING MofResouceName);
|
---|
373 |
|
---|
374 | typedef NTSTATUS
|
---|
375 | (NTAPI *PCLASS_QUERY_WMI_REGINFO)(
|
---|
376 | PDEVICE_OBJECT DeviceObject,
|
---|
377 | ULONG *RegFlags,
|
---|
378 | PUNICODE_STRING Name);
|
---|
379 |
|
---|
380 | typedef NTSTATUS
|
---|
381 | (NTAPI *PCLASS_QUERY_WMI_DATABLOCK)(
|
---|
382 | PDEVICE_OBJECT DeviceObject,
|
---|
383 | PIRP Irp,
|
---|
384 | ULONG GuidIndex,
|
---|
385 | ULONG BufferAvail,
|
---|
386 | PUCHAR Buffer);
|
---|
387 |
|
---|
388 | typedef NTSTATUS
|
---|
389 | (NTAPI *PCLASS_SET_WMI_DATABLOCK)(
|
---|
390 | PDEVICE_OBJECT DeviceObject,
|
---|
391 | PIRP Irp,
|
---|
392 | ULONG GuidIndex,
|
---|
393 | ULONG BufferSize,
|
---|
394 | PUCHAR Buffer);
|
---|
395 |
|
---|
396 | typedef NTSTATUS
|
---|
397 | (NTAPI *PCLASS_SET_WMI_DATAITEM)(
|
---|
398 | PDEVICE_OBJECT DeviceObject,
|
---|
399 | PIRP Irp,
|
---|
400 | ULONG GuidIndex,
|
---|
401 | ULONG DataItemId,
|
---|
402 | ULONG BufferSize,
|
---|
403 | PUCHAR Buffer);
|
---|
404 |
|
---|
405 | typedef NTSTATUS
|
---|
406 | (NTAPI *PCLASS_EXECUTE_WMI_METHOD)(
|
---|
407 | PDEVICE_OBJECT DeviceObject,
|
---|
408 | PIRP Irp,
|
---|
409 | ULONG GuidIndex,
|
---|
410 | ULONG MethodId,
|
---|
411 | ULONG InBufferSize,
|
---|
412 | ULONG OutBufferSize,
|
---|
413 | PUCHAR Buffer);
|
---|
414 |
|
---|
415 | typedef NTSTATUS
|
---|
416 | (NTAPI *PCLASS_WMI_FUNCTION_CONTROL)(
|
---|
417 | PDEVICE_OBJECT DeviceObject,
|
---|
418 | PIRP Irp,
|
---|
419 | ULONG GuidIndex,
|
---|
420 | CLASSENABLEDISABLEFUNCTION Function,
|
---|
421 | BOOLEAN Enable);
|
---|
422 |
|
---|
423 | typedef struct _SRB_HISTORY_ITEM {
|
---|
424 | LARGE_INTEGER TickCountSent;
|
---|
425 | LARGE_INTEGER TickCountCompleted;
|
---|
426 | ULONG MillisecondsDelayOnRetry;
|
---|
427 | SENSE_DATA NormalizedSenseData;
|
---|
428 | UCHAR SrbStatus;
|
---|
429 | UCHAR ClassDriverUse;
|
---|
430 | } SRB_HISTORY_ITEM, *PSRB_HISTORY_ITEM;
|
---|
431 |
|
---|
432 | typedef struct _SRB_HISTORY {
|
---|
433 | ULONG_PTR ClassDriverUse[4];
|
---|
434 | ULONG TotalHistoryCount;
|
---|
435 | ULONG UsedHistoryCount;
|
---|
436 | SRB_HISTORY_ITEM History[1];
|
---|
437 | } SRB_HISTORY, *PSRB_HISTORY;
|
---|
438 |
|
---|
439 | typedef BOOLEAN
|
---|
440 | (NTAPI *PCLASS_INTERPRET_SENSE_INFO)(
|
---|
441 | PDEVICE_OBJECT Fdo,
|
---|
442 | PIRP OriginalRequest,
|
---|
443 | PSCSI_REQUEST_BLOCK Srb,
|
---|
444 | UCHAR MajorFunctionCode,
|
---|
445 | ULONG IoDeviceCode,
|
---|
446 | ULONG PreviousRetryCount,
|
---|
447 | SRB_HISTORY *RequestHistory,
|
---|
448 | NTSTATUS *Status,
|
---|
449 | LONGLONG *RetryIn100nsUnits);
|
---|
450 |
|
---|
451 | typedef VOID
|
---|
452 | (NTAPI *PCLASS_COMPRESS_RETRY_HISTORY_DATA)(
|
---|
453 | PDEVICE_OBJECT DeviceObject,
|
---|
454 | PSRB_HISTORY RequestHistory);
|
---|
455 |
|
---|
456 | typedef struct {
|
---|
457 | GUID Guid;
|
---|
458 | ULONG InstanceCount;
|
---|
459 | ULONG Flags;
|
---|
460 | } GUIDREGINFO, *PGUIDREGINFO;
|
---|
461 |
|
---|
462 | typedef struct _CLASS_WMI_INFO {
|
---|
463 | ULONG GuidCount;
|
---|
464 | PGUIDREGINFO GuidRegInfo;
|
---|
465 | PCLASS_QUERY_WMI_REGINFO ClassQueryWmiRegInfo;
|
---|
466 | PCLASS_QUERY_WMI_DATABLOCK ClassQueryWmiDataBlock;
|
---|
467 | PCLASS_SET_WMI_DATABLOCK ClassSetWmiDataBlock;
|
---|
468 | PCLASS_SET_WMI_DATAITEM ClassSetWmiDataItem;
|
---|
469 | PCLASS_EXECUTE_WMI_METHOD ClassExecuteWmiMethod;
|
---|
470 | PCLASS_WMI_FUNCTION_CONTROL ClassWmiFunctionControl;
|
---|
471 | } CLASS_WMI_INFO, *PCLASS_WMI_INFO;
|
---|
472 |
|
---|
473 | typedef struct _CLASS_DEV_INFO {
|
---|
474 | ULONG DeviceExtensionSize;
|
---|
475 | DEVICE_TYPE DeviceType;
|
---|
476 | UCHAR StackSize;
|
---|
477 | ULONG DeviceCharacteristics;
|
---|
478 | PCLASS_ERROR ClassError;
|
---|
479 | PCLASS_READ_WRITE ClassReadWriteVerification;
|
---|
480 | PCLASS_DEVICE_CONTROL ClassDeviceControl;
|
---|
481 | PCLASS_SHUTDOWN_FLUSH ClassShutdownFlush;
|
---|
482 | PCLASS_CREATE_CLOSE ClassCreateClose;
|
---|
483 | PCLASS_INIT_DEVICE ClassInitDevice;
|
---|
484 | PCLASS_START_DEVICE ClassStartDevice;
|
---|
485 | PCLASS_POWER_DEVICE ClassPowerDevice;
|
---|
486 | PCLASS_STOP_DEVICE ClassStopDevice;
|
---|
487 | PCLASS_REMOVE_DEVICE ClassRemoveDevice;
|
---|
488 | PCLASS_QUERY_PNP_CAPABILITIES ClassQueryPnpCapabilities;
|
---|
489 | CLASS_WMI_INFO ClassWmiInfo;
|
---|
490 | } CLASS_DEV_INFO, *PCLASS_DEV_INFO;
|
---|
491 |
|
---|
492 | struct _CLASS_INIT_DATA {
|
---|
493 | ULONG InitializationDataSize;
|
---|
494 | CLASS_DEV_INFO FdoData;
|
---|
495 | CLASS_DEV_INFO PdoData;
|
---|
496 | PCLASS_ADD_DEVICE ClassAddDevice;
|
---|
497 | PCLASS_ENUM_DEVICE ClassEnumerateDevice;
|
---|
498 | PCLASS_QUERY_ID ClassQueryId;
|
---|
499 | PDRIVER_STARTIO ClassStartIo;
|
---|
500 | PCLASS_UNLOAD ClassUnload;
|
---|
501 | PCLASS_TICK ClassTick;
|
---|
502 | };
|
---|
503 |
|
---|
504 | typedef struct _FILE_OBJECT_EXTENSION {
|
---|
505 | PFILE_OBJECT FileObject;
|
---|
506 | PDEVICE_OBJECT DeviceObject;
|
---|
507 | ULONG LockCount;
|
---|
508 | ULONG McnDisableCount;
|
---|
509 | } FILE_OBJECT_EXTENSION, *PFILE_OBJECT_EXTENSION;
|
---|
510 |
|
---|
511 | typedef struct _CLASS_WORKING_SET {
|
---|
512 | ULONG Size;
|
---|
513 | ULONG XferPacketsWorkingSetMaximum;
|
---|
514 | ULONG XferPacketsWorkingSetMinimum;
|
---|
515 | } CLASS_WORKING_SET, *PCLASS_WORKING_SET;
|
---|
516 |
|
---|
517 | typedef struct _CLASS_INTERPRET_SENSE_INFO2 {
|
---|
518 | ULONG Size;
|
---|
519 | ULONG HistoryCount;
|
---|
520 | PCLASS_COMPRESS_RETRY_HISTORY_DATA Compress;
|
---|
521 | PCLASS_INTERPRET_SENSE_INFO Interpret;
|
---|
522 | } CLASS_INTERPRET_SENSE_INFO2, *PCLASS_INTERPRET_SENSE_INFO2;
|
---|
523 |
|
---|
524 | C_ASSERT((MAXULONG - sizeof(SRB_HISTORY)) / 30000 >= sizeof(SRB_HISTORY_ITEM));
|
---|
525 |
|
---|
526 | typedef struct _CLASS_DRIVER_EXTENSION {
|
---|
527 | UNICODE_STRING RegistryPath;
|
---|
528 | CLASS_INIT_DATA InitData;
|
---|
529 | ULONG DeviceCount;
|
---|
530 | #if (NTDDI_VERSION >= NTDDI_WINXP)
|
---|
531 | PCLASS_QUERY_WMI_REGINFO_EX ClassFdoQueryWmiRegInfoEx;
|
---|
532 | PCLASS_QUERY_WMI_REGINFO_EX ClassPdoQueryWmiRegInfoEx;
|
---|
533 | #endif
|
---|
534 | #if (NTDDI_VERSION >= NTDDI_VISTA)
|
---|
535 | REGHANDLE EtwHandle;
|
---|
536 | PDRIVER_DISPATCH DeviceMajorFunctionTable[IRP_MJ_MAXIMUM_FUNCTION + 1];
|
---|
537 | PDRIVER_DISPATCH MpDeviceMajorFunctionTable[IRP_MJ_MAXIMUM_FUNCTION + 1];
|
---|
538 | PCLASS_INTERPRET_SENSE_INFO2 InterpretSenseInfo;
|
---|
539 | PCLASS_WORKING_SET WorkingSet;
|
---|
540 | #endif
|
---|
541 | } CLASS_DRIVER_EXTENSION, *PCLASS_DRIVER_EXTENSION;
|
---|
542 |
|
---|
543 | typedef struct _COMMON_DEVICE_EXTENSION {
|
---|
544 | ULONG Version;
|
---|
545 | PDEVICE_OBJECT DeviceObject;
|
---|
546 | PDEVICE_OBJECT LowerDeviceObject;
|
---|
547 | struct _FUNCTIONAL_DEVICE_EXTENSION *PartitionZeroExtension;
|
---|
548 | PCLASS_DRIVER_EXTENSION DriverExtension;
|
---|
549 | LONG RemoveLock;
|
---|
550 | KEVENT RemoveEvent;
|
---|
551 | KSPIN_LOCK RemoveTrackingSpinlock;
|
---|
552 | PVOID RemoveTrackingList;
|
---|
553 | LONG RemoveTrackingUntrackedCount;
|
---|
554 | PVOID DriverData;
|
---|
555 | _ANONYMOUS_STRUCT struct {
|
---|
556 | BOOLEAN IsFdo:1;
|
---|
557 | BOOLEAN IsInitialized:1;
|
---|
558 | BOOLEAN IsSrbLookasideListInitialized:1;
|
---|
559 | } DUMMYSTRUCTNAME;
|
---|
560 | UCHAR PreviousState;
|
---|
561 | UCHAR CurrentState;
|
---|
562 | ULONG IsRemoved;
|
---|
563 | UNICODE_STRING DeviceName;
|
---|
564 | struct _PHYSICAL_DEVICE_EXTENSION *ChildList;
|
---|
565 | ULONG PartitionNumber;
|
---|
566 | LARGE_INTEGER PartitionLength;
|
---|
567 | LARGE_INTEGER StartingOffset;
|
---|
568 | PCLASS_DEV_INFO DevInfo;
|
---|
569 | ULONG PagingPathCount;
|
---|
570 | ULONG DumpPathCount;
|
---|
571 | ULONG HibernationPathCount;
|
---|
572 | KEVENT PathCountEvent;
|
---|
573 | #ifndef ALLOCATE_SRB_FROM_POOL
|
---|
574 | NPAGED_LOOKASIDE_LIST SrbLookasideList;
|
---|
575 | #endif
|
---|
576 | UNICODE_STRING MountedDeviceInterfaceName;
|
---|
577 | ULONG GuidCount;
|
---|
578 | PGUIDREGINFO GuidRegInfo;
|
---|
579 | DICTIONARY FileObjectDictionary;
|
---|
580 | #if (NTDDI_VERSION >= NTDDI_WINXP)
|
---|
581 | PCLASS_PRIVATE_COMMON_DATA PrivateCommonData;
|
---|
582 | #else
|
---|
583 | ULONG_PTR Reserved1;
|
---|
584 | #endif
|
---|
585 | #if (NTDDI_VERSION >= NTDDI_VISTA)
|
---|
586 | PDRIVER_DISPATCH *DispatchTable;
|
---|
587 | #else
|
---|
588 | ULONG_PTR Reserved2;
|
---|
589 | #endif
|
---|
590 | ULONG_PTR Reserved3;
|
---|
591 | ULONG_PTR Reserved4;
|
---|
592 | } COMMON_DEVICE_EXTENSION, *PCOMMON_DEVICE_EXTENSION;
|
---|
593 |
|
---|
594 | typedef struct _PHYSICAL_DEVICE_EXTENSION {
|
---|
595 | _ANONYMOUS_UNION union {
|
---|
596 | _ANONYMOUS_STRUCT struct {
|
---|
597 | ULONG Version;
|
---|
598 | PDEVICE_OBJECT DeviceObject;
|
---|
599 | } DUMMYSTRUCTNAME;
|
---|
600 | COMMON_DEVICE_EXTENSION CommonExtension;
|
---|
601 | } DUMMYUNIONNAME;
|
---|
602 | BOOLEAN IsMissing;
|
---|
603 | BOOLEAN IsEnumerated;
|
---|
604 | #if (NTDDI_VERSION >= NTDDI_WINXP)
|
---|
605 | PCLASS_PRIVATE_PDO_DATA PrivatePdoData;
|
---|
606 | #else
|
---|
607 | ULONG_PTR Reserved1;
|
---|
608 | #endif
|
---|
609 | ULONG_PTR Reserved2;
|
---|
610 | ULONG_PTR Reserved3;
|
---|
611 | ULONG_PTR Reserved4;
|
---|
612 | } PHYSICAL_DEVICE_EXTENSION, *PPHYSICAL_DEVICE_EXTENSION;
|
---|
613 |
|
---|
614 | typedef struct _CLASS_POWER_OPTIONS {
|
---|
615 | ULONG PowerDown:1;
|
---|
616 | ULONG LockQueue:1;
|
---|
617 | ULONG HandleSpinDown:1;
|
---|
618 | ULONG HandleSpinUp:1;
|
---|
619 | ULONG Reserved:27;
|
---|
620 | } CLASS_POWER_OPTIONS, *PCLASS_POWER_OPTIONS;
|
---|
621 |
|
---|
622 | typedef struct _CLASS_POWER_CONTEXT {
|
---|
623 | union {
|
---|
624 | CLASS_POWER_DOWN_STATE PowerDown;
|
---|
625 | CLASS_POWER_DOWN_STATE2 PowerDown2;
|
---|
626 | CLASS_POWER_UP_STATE PowerUp;
|
---|
627 | } PowerChangeState;
|
---|
628 | CLASS_POWER_OPTIONS Options;
|
---|
629 | BOOLEAN InUse;
|
---|
630 | BOOLEAN QueueLocked;
|
---|
631 | NTSTATUS FinalStatus;
|
---|
632 | ULONG RetryCount;
|
---|
633 | ULONG RetryInterval;
|
---|
634 | PIO_COMPLETION_ROUTINE CompletionRoutine;
|
---|
635 | PDEVICE_OBJECT DeviceObject;
|
---|
636 | PIRP Irp;
|
---|
637 | SCSI_REQUEST_BLOCK Srb;
|
---|
638 | } CLASS_POWER_CONTEXT, *PCLASS_POWER_CONTEXT;
|
---|
639 |
|
---|
640 | typedef struct _COMPLETION_CONTEXT {
|
---|
641 | PDEVICE_OBJECT DeviceObject;
|
---|
642 | SCSI_REQUEST_BLOCK Srb;
|
---|
643 | } COMPLETION_CONTEXT, *PCOMPLETION_CONTEXT;
|
---|
644 |
|
---|
645 | SCSIPORTAPI
|
---|
646 | ULONG
|
---|
647 | NTAPI
|
---|
648 | ClassInitialize(
|
---|
649 | PVOID Argument1,
|
---|
650 | PVOID Argument2,
|
---|
651 | PCLASS_INIT_DATA InitializationData);
|
---|
652 |
|
---|
653 | typedef struct _CLASS_QUERY_WMI_REGINFO_EX_LIST {
|
---|
654 | ULONG Size;
|
---|
655 | PCLASS_QUERY_WMI_REGINFO_EX ClassFdoQueryWmiRegInfoEx;
|
---|
656 | PCLASS_QUERY_WMI_REGINFO_EX ClassPdoQueryWmiRegInfoEx;
|
---|
657 | } CLASS_QUERY_WMI_REGINFO_EX_LIST, *PCLASS_QUERY_WMI_REGINFO_EX_LIST;
|
---|
658 |
|
---|
659 | typedef struct _FUNCTIONAL_DEVICE_EXTENSION {
|
---|
660 | _ANONYMOUS_UNION union {
|
---|
661 | _ANONYMOUS_STRUCT struct {
|
---|
662 | ULONG Version;
|
---|
663 | PDEVICE_OBJECT DeviceObject;
|
---|
664 | } DUMMYSTRUCTNAME;
|
---|
665 | COMMON_DEVICE_EXTENSION CommonExtension;
|
---|
666 | } DUMMYUNIONNAME;
|
---|
667 | PDEVICE_OBJECT LowerPdo;
|
---|
668 | PSTORAGE_DEVICE_DESCRIPTOR DeviceDescriptor;
|
---|
669 | PSTORAGE_ADAPTER_DESCRIPTOR AdapterDescriptor;
|
---|
670 | DEVICE_POWER_STATE DevicePowerState;
|
---|
671 | ULONG DMByteSkew;
|
---|
672 | ULONG DMSkew;
|
---|
673 | BOOLEAN DMActive;
|
---|
674 | DISK_GEOMETRY DiskGeometry;
|
---|
675 | PSENSE_DATA SenseData;
|
---|
676 | ULONG TimeOutValue;
|
---|
677 | ULONG DeviceNumber;
|
---|
678 | ULONG SrbFlags;
|
---|
679 | ULONG ErrorCount;
|
---|
680 | LONG LockCount;
|
---|
681 | LONG ProtectedLockCount;
|
---|
682 | LONG InternalLockCount;
|
---|
683 | KEVENT EjectSynchronizationEvent;
|
---|
684 | USHORT DeviceFlags;
|
---|
685 | UCHAR SectorShift;
|
---|
686 | #if (NTDDI_VERSION >= NTDDI_VISTA)
|
---|
687 | UCHAR CdbForceUnitAccess;
|
---|
688 | #else
|
---|
689 | UCHAR ReservedByte;
|
---|
690 | #endif
|
---|
691 | PMEDIA_CHANGE_DETECTION_INFO MediaChangeDetectionInfo;
|
---|
692 | PKEVENT Unused1;
|
---|
693 | HANDLE Unused2;
|
---|
694 | FILE_OBJECT_EXTENSION KernelModeMcnContext;
|
---|
695 | ULONG MediaChangeCount;
|
---|
696 | HANDLE DeviceDirectory;
|
---|
697 | KSPIN_LOCK ReleaseQueueSpinLock;
|
---|
698 | PIRP ReleaseQueueIrp;
|
---|
699 | SCSI_REQUEST_BLOCK ReleaseQueueSrb;
|
---|
700 | BOOLEAN ReleaseQueueNeeded;
|
---|
701 | BOOLEAN ReleaseQueueInProgress;
|
---|
702 | BOOLEAN ReleaseQueueIrpFromPool;
|
---|
703 | BOOLEAN FailurePredicted;
|
---|
704 | ULONG FailureReason;
|
---|
705 | struct _FAILURE_PREDICTION_INFO* FailurePredictionInfo;
|
---|
706 | BOOLEAN PowerDownInProgress;
|
---|
707 | ULONG EnumerationInterlock;
|
---|
708 | KEVENT ChildLock;
|
---|
709 | PKTHREAD ChildLockOwner;
|
---|
710 | ULONG ChildLockAcquisitionCount;
|
---|
711 | ULONG ScanForSpecialFlags;
|
---|
712 | KDPC PowerRetryDpc;
|
---|
713 | KTIMER PowerRetryTimer;
|
---|
714 | CLASS_POWER_CONTEXT PowerContext;
|
---|
715 |
|
---|
716 | #if (NTDDI_VERSION <= NTDDI_WIN2K)
|
---|
717 |
|
---|
718 | #if (SPVER(NTDDI_VERSION) < 2))
|
---|
719 | ULONG_PTR Reserved1;
|
---|
720 | ULONG_PTR Reserved2;
|
---|
721 | ULONG_PTR Reserved3;
|
---|
722 | ULONG_PTR Reserved4;
|
---|
723 | #else
|
---|
724 | ULONG CompletionSuccessCount;
|
---|
725 | ULONG SavedSrbFlags;
|
---|
726 | ULONG SavedErrorCount;
|
---|
727 | ULONG_PTR Reserved1;
|
---|
728 | #endif
|
---|
729 |
|
---|
730 | #else /* (NTDDI_VERSION <= NTDDI_WIN2K) */
|
---|
731 |
|
---|
732 | PCLASS_PRIVATE_FDO_DATA PrivateFdoData;
|
---|
733 | ULONG_PTR Reserved2;
|
---|
734 | ULONG_PTR Reserved3;
|
---|
735 | ULONG_PTR Reserved4;
|
---|
736 |
|
---|
737 | #endif /* (NTDDI_VERSION <= NTDDI_WIN2K) */
|
---|
738 |
|
---|
739 | } FUNCTIONAL_DEVICE_EXTENSION, *PFUNCTIONAL_DEVICE_EXTENSION;
|
---|
740 |
|
---|
741 | SCSIPORTAPI
|
---|
742 | ULONG
|
---|
743 | NTAPI
|
---|
744 | ClassInitializeEx(
|
---|
745 | PDRIVER_OBJECT DriverObject,
|
---|
746 | LPGUID Guid,
|
---|
747 | PVOID Data);
|
---|
748 |
|
---|
749 | SCSIPORTAPI
|
---|
750 | NTSTATUS
|
---|
751 | NTAPI
|
---|
752 | ClassCreateDeviceObject(
|
---|
753 | PDRIVER_OBJECT DriverObject,
|
---|
754 | PCCHAR ObjectNameBuffer,
|
---|
755 | PDEVICE_OBJECT LowerDeviceObject,
|
---|
756 | BOOLEAN IsFdo,
|
---|
757 | PDEVICE_OBJECT *DeviceObject);
|
---|
758 |
|
---|
759 | SCSIPORTAPI
|
---|
760 | NTSTATUS
|
---|
761 | NTAPI
|
---|
762 | ClassReadDriveCapacity(
|
---|
763 | PDEVICE_OBJECT DeviceObject);
|
---|
764 |
|
---|
765 | SCSIPORTAPI
|
---|
766 | VOID
|
---|
767 | NTAPI
|
---|
768 | ClassReleaseQueue(
|
---|
769 | PDEVICE_OBJECT DeviceObject);
|
---|
770 |
|
---|
771 | SCSIPORTAPI
|
---|
772 | VOID
|
---|
773 | NTAPI
|
---|
774 | ClassSplitRequest(
|
---|
775 | PDEVICE_OBJECT DeviceObject,
|
---|
776 | PIRP Irp,
|
---|
777 | ULONG MaximumBytes);
|
---|
778 |
|
---|
779 | SCSIPORTAPI
|
---|
780 | NTSTATUS
|
---|
781 | NTAPI
|
---|
782 | ClassDeviceControl(
|
---|
783 | PDEVICE_OBJECT DeviceObject,
|
---|
784 | PIRP Irp);
|
---|
785 |
|
---|
786 | SCSIPORTAPI
|
---|
787 | NTSTATUS
|
---|
788 | NTAPI
|
---|
789 | ClassIoComplete(
|
---|
790 | PDEVICE_OBJECT DeviceObject,
|
---|
791 | PIRP Irp,
|
---|
792 | PVOID Context);
|
---|
793 |
|
---|
794 | SCSIPORTAPI
|
---|
795 | NTSTATUS
|
---|
796 | NTAPI
|
---|
797 | ClassIoCompleteAssociated(
|
---|
798 | PDEVICE_OBJECT DeviceObject,
|
---|
799 | PIRP Irp,
|
---|
800 | PVOID Context);
|
---|
801 |
|
---|
802 | SCSIPORTAPI
|
---|
803 | BOOLEAN
|
---|
804 | NTAPI
|
---|
805 | ClassInterpretSenseInfo(
|
---|
806 | PDEVICE_OBJECT DeviceObject,
|
---|
807 | PSCSI_REQUEST_BLOCK Srb,
|
---|
808 | UCHAR MajorFunctionCode,
|
---|
809 | ULONG IoDeviceCode,
|
---|
810 | ULONG RetryCount,
|
---|
811 | NTSTATUS *Status,
|
---|
812 | ULONG *RetryInterval);
|
---|
813 |
|
---|
814 | VOID
|
---|
815 | NTAPI
|
---|
816 | ClassSendDeviceIoControlSynchronous(
|
---|
817 | ULONG IoControlCode,
|
---|
818 | PDEVICE_OBJECT TargetDeviceObject,
|
---|
819 | PVOID Buffer,
|
---|
820 | ULONG InputBufferLength,
|
---|
821 | ULONG OutputBufferLength,
|
---|
822 | BOOLEAN InternalDeviceIoControl,
|
---|
823 | PIO_STATUS_BLOCK IoStatus);
|
---|
824 |
|
---|
825 | SCSIPORTAPI
|
---|
826 | NTSTATUS
|
---|
827 | NTAPI
|
---|
828 | ClassSendIrpSynchronous(
|
---|
829 | PDEVICE_OBJECT TargetDeviceObject,
|
---|
830 | PIRP Irp);
|
---|
831 |
|
---|
832 | SCSIPORTAPI
|
---|
833 | NTSTATUS
|
---|
834 | NTAPI
|
---|
835 | ClassForwardIrpSynchronous(
|
---|
836 | PCOMMON_DEVICE_EXTENSION CommonExtension,
|
---|
837 | PIRP Irp);
|
---|
838 |
|
---|
839 | SCSIPORTAPI
|
---|
840 | NTSTATUS
|
---|
841 | NTAPI
|
---|
842 | ClassSendSrbSynchronous(
|
---|
843 | PDEVICE_OBJECT DeviceObject,
|
---|
844 | PSCSI_REQUEST_BLOCK Srb,
|
---|
845 | PVOID BufferAddress,
|
---|
846 | ULONG BufferLength,
|
---|
847 | BOOLEAN WriteToDevice);
|
---|
848 |
|
---|
849 | SCSIPORTAPI
|
---|
850 | NTSTATUS
|
---|
851 | NTAPI
|
---|
852 | ClassSendSrbAsynchronous(
|
---|
853 | PDEVICE_OBJECT DeviceObject,
|
---|
854 | PSCSI_REQUEST_BLOCK Srb,
|
---|
855 | PIRP Irp,
|
---|
856 | PVOID BufferAddress,
|
---|
857 | ULONG BufferLength,
|
---|
858 | BOOLEAN WriteToDevice);
|
---|
859 |
|
---|
860 | SCSIPORTAPI
|
---|
861 | NTSTATUS
|
---|
862 | NTAPI
|
---|
863 | ClassBuildRequest(
|
---|
864 | PDEVICE_OBJECT DeviceObject,
|
---|
865 | PIRP Irp);
|
---|
866 |
|
---|
867 | SCSIPORTAPI
|
---|
868 | ULONG
|
---|
869 | NTAPI
|
---|
870 | ClassModeSense(
|
---|
871 | PDEVICE_OBJECT DeviceObject,
|
---|
872 | PCHAR ModeSenseBuffer,
|
---|
873 | ULONG Length,
|
---|
874 | UCHAR PageMode);
|
---|
875 |
|
---|
876 | SCSIPORTAPI
|
---|
877 | PVOID
|
---|
878 | NTAPI
|
---|
879 | ClassFindModePage(
|
---|
880 | PCHAR ModeSenseBuffer,
|
---|
881 | ULONG Length,
|
---|
882 | UCHAR PageMode,
|
---|
883 | BOOLEAN Use6Byte);
|
---|
884 |
|
---|
885 | SCSIPORTAPI
|
---|
886 | NTSTATUS
|
---|
887 | NTAPI
|
---|
888 | ClassClaimDevice(
|
---|
889 | PDEVICE_OBJECT LowerDeviceObject,
|
---|
890 | BOOLEAN Release);
|
---|
891 |
|
---|
892 | SCSIPORTAPI
|
---|
893 | NTSTATUS
|
---|
894 | NTAPI
|
---|
895 | ClassInternalIoControl (
|
---|
896 | PDEVICE_OBJECT DeviceObject,
|
---|
897 | PIRP Irp);
|
---|
898 |
|
---|
899 | SCSIPORTAPI
|
---|
900 | VOID
|
---|
901 | NTAPI
|
---|
902 | ClassInitializeSrbLookasideList(
|
---|
903 | PCOMMON_DEVICE_EXTENSION CommonExtension,
|
---|
904 | ULONG NumberElements);
|
---|
905 |
|
---|
906 | SCSIPORTAPI
|
---|
907 | VOID
|
---|
908 | NTAPI
|
---|
909 | ClassDeleteSrbLookasideList(
|
---|
910 | PCOMMON_DEVICE_EXTENSION CommonExtension);
|
---|
911 |
|
---|
912 | SCSIPORTAPI
|
---|
913 | ULONG
|
---|
914 | NTAPI
|
---|
915 | ClassQueryTimeOutRegistryValue(
|
---|
916 | PDEVICE_OBJECT DeviceObject);
|
---|
917 |
|
---|
918 | SCSIPORTAPI
|
---|
919 | NTSTATUS
|
---|
920 | NTAPI
|
---|
921 | ClassGetDescriptor(
|
---|
922 | PDEVICE_OBJECT DeviceObject,
|
---|
923 | PSTORAGE_PROPERTY_ID PropertyId,
|
---|
924 | PSTORAGE_DESCRIPTOR_HEADER *Descriptor);
|
---|
925 |
|
---|
926 | SCSIPORTAPI
|
---|
927 | VOID
|
---|
928 | NTAPI
|
---|
929 | ClassInvalidateBusRelations(
|
---|
930 | PDEVICE_OBJECT Fdo);
|
---|
931 |
|
---|
932 | SCSIPORTAPI
|
---|
933 | VOID
|
---|
934 | NTAPI
|
---|
935 | ClassMarkChildrenMissing(
|
---|
936 | PFUNCTIONAL_DEVICE_EXTENSION Fdo);
|
---|
937 |
|
---|
938 | SCSIPORTAPI
|
---|
939 | BOOLEAN
|
---|
940 | NTAPI
|
---|
941 | ClassMarkChildMissing(
|
---|
942 | PPHYSICAL_DEVICE_EXTENSION PdoExtension,
|
---|
943 | BOOLEAN AcquireChildLock);
|
---|
944 |
|
---|
945 | SCSIPORTAPI
|
---|
946 | VOID
|
---|
947 | ClassDebugPrint(
|
---|
948 | CLASS_DEBUG_LEVEL DebugPrintLevel,
|
---|
949 | PCCHAR DebugMessage,
|
---|
950 | ...);
|
---|
951 |
|
---|
952 | SCSIPORTAPI
|
---|
953 | PCLASS_DRIVER_EXTENSION
|
---|
954 | NTAPI
|
---|
955 | ClassGetDriverExtension(
|
---|
956 | PDRIVER_OBJECT DriverObject);
|
---|
957 |
|
---|
958 | SCSIPORTAPI
|
---|
959 | VOID
|
---|
960 | NTAPI
|
---|
961 | ClassCompleteRequest(
|
---|
962 | PDEVICE_OBJECT DeviceObject,
|
---|
963 | PIRP Irp,
|
---|
964 | CCHAR PriorityBoost);
|
---|
965 |
|
---|
966 | SCSIPORTAPI
|
---|
967 | VOID
|
---|
968 | NTAPI
|
---|
969 | ClassReleaseRemoveLock(
|
---|
970 | PDEVICE_OBJECT DeviceObject,
|
---|
971 | PIRP Tag);
|
---|
972 |
|
---|
973 | SCSIPORTAPI
|
---|
974 | ULONG
|
---|
975 | NTAPI
|
---|
976 | ClassAcquireRemoveLockEx(
|
---|
977 | PDEVICE_OBJECT DeviceObject,
|
---|
978 | PVOID Tag,
|
---|
979 | PCSTR File,
|
---|
980 | ULONG Line);
|
---|
981 |
|
---|
982 | SCSIPORTAPI
|
---|
983 | VOID
|
---|
984 | NTAPI
|
---|
985 | ClassUpdateInformationInRegistry(
|
---|
986 | PDEVICE_OBJECT Fdo,
|
---|
987 | PCHAR DeviceName,
|
---|
988 | ULONG DeviceNumber,
|
---|
989 | PINQUIRYDATA InquiryData,
|
---|
990 | ULONG InquiryDataLength);
|
---|
991 |
|
---|
992 | SCSIPORTAPI
|
---|
993 | NTSTATUS
|
---|
994 | NTAPI
|
---|
995 | ClassWmiCompleteRequest(
|
---|
996 | PDEVICE_OBJECT DeviceObject,
|
---|
997 | PIRP Irp,
|
---|
998 | NTSTATUS Status,
|
---|
999 | ULONG BufferUsed,
|
---|
1000 | CCHAR PriorityBoost);
|
---|
1001 |
|
---|
1002 | SCSIPORTAPI
|
---|
1003 | NTSTATUS
|
---|
1004 | NTAPI
|
---|
1005 | ClassWmiFireEvent(
|
---|
1006 | PDEVICE_OBJECT DeviceObject,
|
---|
1007 | LPGUID Guid,
|
---|
1008 | ULONG InstanceIndex,
|
---|
1009 | ULONG EventDataSize,
|
---|
1010 | PVOID EventData);
|
---|
1011 |
|
---|
1012 | SCSIPORTAPI
|
---|
1013 | VOID
|
---|
1014 | NTAPI
|
---|
1015 | ClassResetMediaChangeTimer(
|
---|
1016 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension);
|
---|
1017 |
|
---|
1018 | SCSIPORTAPI
|
---|
1019 | VOID
|
---|
1020 | NTAPI
|
---|
1021 | ClassInitializeMediaChangeDetection(
|
---|
1022 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1023 | PUCHAR EventPrefix);
|
---|
1024 |
|
---|
1025 | SCSIPORTAPI
|
---|
1026 | NTSTATUS
|
---|
1027 | NTAPI
|
---|
1028 | ClassInitializeTestUnitPolling(
|
---|
1029 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1030 | BOOLEAN AllowDriveToSleep);
|
---|
1031 |
|
---|
1032 | SCSIPORTAPI
|
---|
1033 | PVPB
|
---|
1034 | NTAPI
|
---|
1035 | ClassGetVpb(
|
---|
1036 | PDEVICE_OBJECT DeviceObject);
|
---|
1037 |
|
---|
1038 | SCSIPORTAPI
|
---|
1039 | NTSTATUS
|
---|
1040 | NTAPI
|
---|
1041 | ClassSpinDownPowerHandler(
|
---|
1042 | PDEVICE_OBJECT DeviceObject,
|
---|
1043 | PIRP Irp);
|
---|
1044 |
|
---|
1045 | NTSTATUS
|
---|
1046 | NTAPI
|
---|
1047 | ClassStopUnitPowerHandler(
|
---|
1048 | PDEVICE_OBJECT DeviceObject,
|
---|
1049 | PIRP Irp);
|
---|
1050 |
|
---|
1051 | NTSTATUS
|
---|
1052 | NTAPI
|
---|
1053 | ClassSetFailurePredictionPoll(
|
---|
1054 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1055 | FAILURE_PREDICTION_METHOD FailurePredictionMethod,
|
---|
1056 | ULONG PollingPeriod);
|
---|
1057 |
|
---|
1058 | VOID
|
---|
1059 | NTAPI
|
---|
1060 | ClassNotifyFailurePredicted(
|
---|
1061 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1062 | PUCHAR Buffer,
|
---|
1063 | ULONG BufferSize,
|
---|
1064 | BOOLEAN LogError,
|
---|
1065 | ULONG UniqueErrorValue,
|
---|
1066 | UCHAR PathId,
|
---|
1067 | UCHAR TargetId,
|
---|
1068 | UCHAR Lun);
|
---|
1069 |
|
---|
1070 | SCSIPORTAPI
|
---|
1071 | VOID
|
---|
1072 | NTAPI
|
---|
1073 | ClassAcquireChildLock(
|
---|
1074 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension);
|
---|
1075 |
|
---|
1076 | SCSIPORTAPI
|
---|
1077 | VOID
|
---|
1078 | NTAPI
|
---|
1079 | ClassReleaseChildLock(
|
---|
1080 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension);
|
---|
1081 |
|
---|
1082 | NTSTATUS
|
---|
1083 | NTAPI
|
---|
1084 | ClassSignalCompletion(
|
---|
1085 | PDEVICE_OBJECT DeviceObject,
|
---|
1086 | PIRP Irp,
|
---|
1087 | PKEVENT Event);
|
---|
1088 |
|
---|
1089 | VOID
|
---|
1090 | NTAPI
|
---|
1091 | ClassSendStartUnit(
|
---|
1092 | PDEVICE_OBJECT DeviceObject);
|
---|
1093 |
|
---|
1094 | SCSIPORTAPI
|
---|
1095 | NTSTATUS
|
---|
1096 | NTAPI
|
---|
1097 | ClassRemoveDevice(
|
---|
1098 | PDEVICE_OBJECT DeviceObject,
|
---|
1099 | UCHAR RemoveType);
|
---|
1100 |
|
---|
1101 | SCSIPORTAPI
|
---|
1102 | NTSTATUS
|
---|
1103 | NTAPI
|
---|
1104 | ClassAsynchronousCompletion(
|
---|
1105 | PDEVICE_OBJECT DeviceObject,
|
---|
1106 | PIRP Irp,
|
---|
1107 | PVOID Event);
|
---|
1108 |
|
---|
1109 | SCSIPORTAPI
|
---|
1110 | VOID
|
---|
1111 | NTAPI
|
---|
1112 | ClassCheckMediaState(
|
---|
1113 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension);
|
---|
1114 |
|
---|
1115 | SCSIPORTAPI
|
---|
1116 | NTSTATUS
|
---|
1117 | NTAPI
|
---|
1118 | ClassCheckVerifyComplete(
|
---|
1119 | PDEVICE_OBJECT DeviceObject,
|
---|
1120 | PIRP Irp,
|
---|
1121 | PVOID Context);
|
---|
1122 |
|
---|
1123 | SCSIPORTAPI
|
---|
1124 | VOID
|
---|
1125 | NTAPI
|
---|
1126 | ClassSetMediaChangeState(
|
---|
1127 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1128 | MEDIA_CHANGE_DETECTION_STATE State,
|
---|
1129 | BOOLEAN Wait);
|
---|
1130 |
|
---|
1131 | SCSIPORTAPI
|
---|
1132 | VOID
|
---|
1133 | NTAPI
|
---|
1134 | ClassEnableMediaChangeDetection(
|
---|
1135 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension);
|
---|
1136 |
|
---|
1137 | SCSIPORTAPI
|
---|
1138 | VOID
|
---|
1139 | NTAPI
|
---|
1140 | ClassDisableMediaChangeDetection(
|
---|
1141 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension);
|
---|
1142 |
|
---|
1143 | SCSIPORTAPI
|
---|
1144 | VOID
|
---|
1145 | NTAPI
|
---|
1146 | ClassCleanupMediaChangeDetection(
|
---|
1147 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension);
|
---|
1148 |
|
---|
1149 | VOID
|
---|
1150 | NTAPI
|
---|
1151 | ClassGetDeviceParameter(
|
---|
1152 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1153 | PWSTR SubkeyName,
|
---|
1154 | PWSTR ParameterName,
|
---|
1155 | PULONG ParameterValue);
|
---|
1156 |
|
---|
1157 | NTSTATUS
|
---|
1158 | NTAPI
|
---|
1159 | ClassSetDeviceParameter(
|
---|
1160 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1161 | PWSTR SubkeyName,
|
---|
1162 | PWSTR ParameterName,
|
---|
1163 | ULONG ParameterValue);
|
---|
1164 |
|
---|
1165 | #if (NTDDI_VERSION >= NTDDI_VISTA)
|
---|
1166 |
|
---|
1167 | PFILE_OBJECT_EXTENSION
|
---|
1168 | NTAPI
|
---|
1169 | ClassGetFsContext(
|
---|
1170 | PCOMMON_DEVICE_EXTENSION CommonExtension,
|
---|
1171 | PFILE_OBJECT FileObject);
|
---|
1172 |
|
---|
1173 | VOID
|
---|
1174 | NTAPI
|
---|
1175 | ClassSendNotification(
|
---|
1176 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1177 | const GUID *Guid,
|
---|
1178 | ULONG ExtraDataSize,
|
---|
1179 | PVOID ExtraData);
|
---|
1180 |
|
---|
1181 | #endif /* (NTDDI_VERSION >= NTDDI_VISTA) */
|
---|
1182 |
|
---|
1183 | static __inline
|
---|
1184 | BOOLEAN
|
---|
1185 | PORT_ALLOCATED_SENSE(
|
---|
1186 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1187 | PSCSI_REQUEST_BLOCK Srb)
|
---|
1188 | {
|
---|
1189 | return ((BOOLEAN)((TEST_FLAG(Srb->SrbFlags, SRB_FLAGS_PORT_DRIVER_ALLOCSENSE) &&
|
---|
1190 | TEST_FLAG(Srb->SrbFlags, SRB_FLAGS_FREE_SENSE_BUFFER)) &&
|
---|
1191 | (Srb->SenseInfoBuffer != FdoExtension->SenseData)));
|
---|
1192 | }
|
---|
1193 |
|
---|
1194 | static __inline
|
---|
1195 | VOID
|
---|
1196 | FREE_PORT_ALLOCATED_SENSE_BUFFER(
|
---|
1197 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1198 | PSCSI_REQUEST_BLOCK Srb)
|
---|
1199 | {
|
---|
1200 | ASSERT(TEST_FLAG(Srb->SrbFlags, SRB_FLAGS_PORT_DRIVER_ALLOCSENSE));
|
---|
1201 | ASSERT(TEST_FLAG(Srb->SrbFlags, SRB_FLAGS_FREE_SENSE_BUFFER));
|
---|
1202 | ASSERT(Srb->SenseInfoBuffer != FdoExtension->SenseData);
|
---|
1203 |
|
---|
1204 | ExFreePool(Srb->SenseInfoBuffer);
|
---|
1205 | Srb->SenseInfoBuffer = FdoExtension->SenseData;
|
---|
1206 | Srb->SenseInfoBufferLength = SENSE_BUFFER_SIZE;
|
---|
1207 | CLEAR_FLAG(Srb->SrbFlags, SRB_FLAGS_FREE_SENSE_BUFFER);
|
---|
1208 | return;
|
---|
1209 | }
|
---|
1210 |
|
---|
1211 | typedef VOID
|
---|
1212 | (NTAPI *PCLASS_SCAN_FOR_SPECIAL_HANDLER)(
|
---|
1213 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1214 | ULONG_PTR Data);
|
---|
1215 |
|
---|
1216 | VOID
|
---|
1217 | NTAPI
|
---|
1218 | ClassScanForSpecial(
|
---|
1219 | PFUNCTIONAL_DEVICE_EXTENSION FdoExtension,
|
---|
1220 | CLASSPNP_SCAN_FOR_SPECIAL_INFO DeviceList[],
|
---|
1221 | PCLASS_SCAN_FOR_SPECIAL_HANDLER Function);
|
---|