1 /*++
2 
3 Copyright (c) Microsoft Corporation
4 
5 Module Name:
6 
7     FxDeviceInit.hpp
8 
9 Abstract:
10 
11 
12 Author:
13 
14 
15 Environment:
16 
17     kernel mode only
18 
19 Revision History:
20 
21 --*/
22 
23 #ifndef __FXDEVICEINIT_HPP__
24 #define __FXDEVICEINIT_HPP__
25 
26 enum FxDeviceInitType {
27     FxDeviceInitTypeFdo = 0,
28     FxDeviceInitTypePdo,
29     FxDeviceInitTypeControlDevice
30 };
31 
32 struct FileObjectInit {
33     WDF_FILEOBJECT_CLASS Class;
34 
35     WDF_OBJECT_ATTRIBUTES Attributes;
36 
37     WDF_FILEOBJECT_CONFIG Callbacks;
38 
39     WDF_TRI_STATE AutoForwardCleanupClose;
40 
41     BOOLEAN Set;
42 };
43 
44 struct SecurityInit {
45     FxString* Sddl;
46 
47     GUID DeviceClass;
48 
49     BOOLEAN DeviceClassSet;
50 };
51 
52 struct PnpPowerInit {
53     WDF_PNPPOWER_EVENT_CALLBACKS PnpPowerEventCallbacks;
54 
55     WDF_POWER_POLICY_EVENT_CALLBACKS PolicyEventCallbacks;
56 
57     FxPnpStateCallback* PnpStateCallbacks;
58 
59     FxPowerStateCallback* PowerStateCallbacks;
60 
61     FxPowerPolicyStateCallback* PowerPolicyStateCallbacks;
62 
63     WDF_TRI_STATE PowerPolicyOwner;
64 };
65 
66 struct FdoInit {
67     WDF_FDO_EVENT_CALLBACKS EventCallbacks;
68 
69     WDF_CHILD_LIST_CONFIG ListConfig;
70 
71     WDF_OBJECT_ATTRIBUTES ListConfigAttributes;
72 
73     BOOLEAN Filter;
74 
75     MdDeviceObject PhysicalDevice;
76 };
77 
78 
79 
80 
81 #include "FxDeviceInitShared.hpp"
82 
83 struct ControlInit {
84     ControlInit(
85         VOID
86         )
87     {
88         ShutdownNotification = NULL;
89         Flags = 0;
90     }
91 
92     PFN_WDF_DEVICE_SHUTDOWN_NOTIFICATION ShutdownNotification;
93 
94     UCHAR Flags;
95 };
96 
97 //
98 // The typedef for a pointer to this structure is exposed in wdfdevice.h
99 //
100 struct WDFDEVICE_INIT : public FxStump {
101 public:
102     WDFDEVICE_INIT(
103         __in FxDriver* Driver
104         );
105 
106     ~WDFDEVICE_INIT();
107 
108     VOID
109     SetPdo(
110         __in FxDevice* Parent
111         );
112 
113     BOOLEAN
114     IsFdoInit(
115         VOID
116         )
117     {
118         return InitType == FxDeviceInitTypeFdo;
119     }
120 
121     BOOLEAN
122     IsNotFdoInit(
123         VOID
124         )
125     {
126         return InitType != FxDeviceInitTypeFdo;
127     }
128 
129     BOOLEAN
130     IsPdoInit(
131         VOID
132         )
133     {
134         return InitType == FxDeviceInitTypePdo;
135     }
136 
137     BOOLEAN
138     IsNotPdoInit(
139         VOID
140         )
141     {
142         return InitType != FxDeviceInitTypePdo;
143     }
144     BOOLEAN
145     IsNotControlDeviceInit(
146         VOID
147         )
148     {
149         return InitType != FxDeviceInitTypeControlDevice;
150     }
151 
152     BOOLEAN
153     IsControlDeviceInit(
154         VOID
155         )
156     {
157         return InitType == FxDeviceInitTypeControlDevice;
158     }
159 
160     BOOLEAN
161     HasName(
162         VOID
163         )
164     {
165         if (DeviceName != NULL ||
166             (Characteristics & FILE_AUTOGENERATED_DEVICE_NAME)) {
167             return TRUE;
168         }
169         else {
170             return FALSE;
171         }
172     }
173 
174     BOOLEAN
175     ShouldCreateSecure(
176         VOID
177         );
178 
179     BOOLEAN
180     IsPwrPolOwner(
181         VOID
182         )
183     {
184         if (PnpPower.PowerPolicyOwner == WdfTrue) {
185             return TRUE;
186         }
187         else if (PnpPower.PowerPolicyOwner == WdfFalse) {
188             return FALSE;
189         }
190         else if (IsPdoInit()) {
191             //
192             // This is a PDO. If we are a raw PDO, we own pwr policy.
193             //
194             return Pdo.Raw;
195         }
196         else {
197             ASSERT(IsFdoInit());
198 
199             //
200             // This is an FDO. If we are not a filter, we own pwr policy.
201             //
202             return (Fdo.Filter == FALSE ? TRUE : FALSE);
203         }
204     }
205 
206     _Must_inspect_result_
207     NTSTATUS
208     AssignName(
209         __in PFX_DRIVER_GLOBALS FxDriverGlobals,
210         __in const UNICODE_STRING* Name
211         );
212 
213     static
214     _Must_inspect_result_
215     PWDFDEVICE_INIT
216     _AllocateControlDeviceInit(
217         __in FxDriver* Driver,
218         __in const UNICODE_STRING* SDDLString
219         );
220 
221     VOID
222     AddCxDeviceInit(
223         __in PWDFCXDEVICE_INIT CxDeviceInit
224         );
225 
226     VOID
227     AssignIoType(
228         _In_ PWDF_IO_TYPE_CONFIG IoTypeConfig
229         );
230 
231 public:
232     PFX_DRIVER_GLOBALS DriverGlobals;
233 
234     FxDriver* Driver;
235 
236     FxDevice* CreatedDevice;
237 
238     BOOLEAN CreatedOnStack;
239 
240     BOOLEAN Exclusive;
241 
242     BOOLEAN PowerPageable;
243 
244     BOOLEAN Inrush;
245 
246     //
247     // If set, the Cx/Client intends to leverage Self IO Target
248     //
249     BOOLEAN RequiresSelfIoTarget;
250 
251     ULONG RemoveLockOptionFlags;
252 
253     FxDeviceInitType InitType;
254 
255     WDF_DEVICE_IO_TYPE ReadWriteIoType;
256 
257     DEVICE_TYPE DeviceType;
258 
259     FxString* DeviceName;
260 
261     ULONG Characteristics;
262 
263     FileObjectInit FileObject;
264 
265     SecurityInit Security;
266 
267     WDF_OBJECT_ATTRIBUTES RequestAttributes;
268 
269     FxIrpPreprocessInfo* PreprocessInfo;
270 
271     PFN_WDF_IO_IN_CALLER_CONTEXT IoInCallerContextCallback;
272 
273     WDF_RELEASE_HARDWARE_ORDER_ON_FAILURE ReleaseHardwareOrderOnFailure;
274 
275     PnpPowerInit    PnpPower;
276     FdoInit         Fdo;
277     PdoInit         Pdo;
278     ControlInit     Control;
279 
280     //
281     // Class extension's device init.
282     //
283     LIST_ENTRY      CxDeviceInitListHead;
284 
285 #if (FX_CORE_MODE == FX_CORE_USER_MODE)
286     //
287     // IoType preference for IOCTL
288     //
289     WDF_DEVICE_IO_TYPE DeviceControlIoType;
290 
291     //
292     // Direct I/O threshold
293     //
294     ULONG DirectTransferThreshold;
295 
296     //
297     // Weak reference to host side device stack
298     //
299     IWudfDeviceStack * DevStack;
300 
301     //
302     // Kernel redirector's side object name.
303     //
304     PWSTR KernelDeviceName;
305 
306     //
307     // PnP devinode hw key handle
308     //
309     HKEY PdoKey;
310 
311     //
312     // Registry sub-path name containing driver configuration information.
313     // The registry path name is relative to the "device key".
314     //
315     PWSTR ConfigRegistryPath;
316 
317     //
318     // PDO Instance ID
319     //
320     PWSTR DevInstanceID;
321 
322     //
323     // This ID is used by Host to associated host device and its driver info.
324     //
325     ULONG DriverID;
326 #endif
327 
328 };
329 
330 #endif __FXDEVICEINIT_HPP__
331