3 Copyright (c) Alex Ionescu. All rights reserved.
11 Type definitions for the Configuration Manager.
15 Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006
29 #define MAX_BUS_NAME 24
32 // PLUGPLAY_CONTROL_RELATED_DEVICE_DATA.Relations
34 #define PNP_GET_PARENT_DEVICE 1
35 #define PNP_GET_CHILD_DEVICE 2
36 #define PNP_GET_SIBLING_DEVICE 3
39 // PLUGPLAY_CONTROL_STATUS_DATA Operations
41 #define PNP_GET_DEVICE_STATUS 0
42 #define PNP_SET_DEVICE_STATUS 1
43 #define PNP_CLEAR_DEVICE_STATUS 2
50 #define CmResourceTypeNull 0
51 #define CmResourceTypePort 1
52 #define CmResourceTypeInterrupt 2
53 #define CmResourceTypeMemory 3
54 #define CmResourceTypeDma 4
55 #define CmResourceTypeDeviceSpecific 5
56 #define CmResourceTypeBusNumber 6
57 #define CmResourceTypeMaximum 7
58 #define CmResourceTypeNonArbitrated 128
59 #define CmResourceTypeConfigData 128
60 #define CmResourceTypeDevicePrivate 129
61 #define CmResourceTypePcCardConfig 130
62 #define CmResourceTypeMfCardConfig 131
66 // Resource Descriptor Share Dispositions
68 typedef enum _CM_SHARE_DISPOSITION
70 CmResourceShareUndetermined
,
71 CmResourceShareDeviceExclusive
,
72 CmResourceShareDriverExclusive
,
74 } CM_SHARE_DISPOSITION
;
79 // Port Resource Descriptor Flags
81 #define CM_RESOURCE_PORT_MEMORY 0x0000
82 #define CM_RESOURCE_PORT_IO 0x0001
83 #define CM_RESOURCE_PORT_10_BIT_DECODE 0x0004
84 #define CM_RESOURCE_PORT_12_BIT_DECODE 0x0008
85 #define CM_RESOURCE_PORT_16_BIT_DECODE 0x0010
86 #define CM_RESOURCE_PORT_POSITIVE_DECODE 0x0020
87 #define CM_RESOURCE_PORT_PASSIVE_DECODE 0x0040
88 #define CM_RESOURCE_PORT_WINDOW_DECODE 0x0080
91 // Memory Resource Descriptor Flags
93 #define CM_RESOURCE_MEMORY_READ_WRITE 0x0000
94 #define CM_RESOURCE_MEMORY_READ_ONLY 0x0001
95 #define CM_RESOURCE_MEMORY_WRITE_ONLY 0x0002
96 #define CM_RESOURCE_MEMORY_PREFETCHABLE 0x0004
97 #define CM_RESOURCE_MEMORY_COMBINEDWRITE 0x0008
98 #define CM_RESOURCE_MEMORY_24 0x0010
99 #define CM_RESOURCE_MEMORY_CACHEABLE 0x0020
102 // DMA Resource Descriptor Flags
104 #define CM_RESOURCE_DMA_8 0x0000
105 #define CM_RESOURCE_DMA_16 0x0001
106 #define CM_RESOURCE_DMA_32 0x0002
107 #define CM_RESOURCE_DMA_8_AND_16 0x0004
108 #define CM_RESOURCE_DMA_BUS_MASTER 0x0008
109 #define CM_RESOURCE_DMA_TYPE_A 0x0010
110 #define CM_RESOURCE_DMA_TYPE_B 0x0020
111 #define CM_RESOURCE_DMA_TYPE_F 0x0040
114 // NtInitializeRegistry Flags
116 #define CM_BOOT_FLAG_SMSS 0x0000
117 #define CM_BOOT_FLAG_SETUP 0x0001
118 #define CM_BOOT_FLAG_ACCEPTED 0x0002
119 #define CM_BOOT_FLAG_MAX 0x03E9
121 #ifdef NTOS_MODE_USER
124 // Information Classes for NtQueryKey
126 typedef enum _KEY_INFORMATION_CLASS
132 KeyCachedInformation
,
134 } KEY_INFORMATION_CLASS
;
136 typedef enum _KEY_VALUE_INFORMATION_CLASS
138 KeyValueBasicInformation
,
139 KeyValueFullInformation
,
140 KeyValuePartialInformation
,
141 KeyValueFullInformationAlign64
,
142 KeyValuePartialInformationAlign64
143 } KEY_VALUE_INFORMATION_CLASS
;
145 typedef enum _KEY_SET_INFORMATION_CLASS
147 KeyWriteTimeInformation
,
148 KeyUserFlagsInformation
,
150 } KEY_SET_INFORMATION_CLASS
;
155 // Plag and Play Classes
157 typedef enum _PLUGPLAY_CONTROL_CLASS
159 PlugPlayControlUserResponse
= 0x07,
160 PlugPlayControlProperty
= 0x0A,
161 PlugPlayControlGetRelatedDevice
= 0x0C,
162 PlugPlayControlDeviceStatus
= 0x0E,
163 PlugPlayControlGetDeviceDepth
,
164 PlugPlayControlResetDevice
= 0x14
165 } PLUGPLAY_CONTROL_CLASS
;
167 typedef enum _PLUGPLAY_BUS_CLASS
172 } PLUGPLAY_BUS_CLASS
, *PPLUGPLAY_BUS_CLASS
;
175 // Plag and Play Bus Types
177 typedef enum _PLUGPLAY_VIRTUAL_BUS_TYPE
180 MaxPlugPlayVirtualBusType
181 } PLUGPLAY_VIRTUAL_BUS_TYPE
, *PPLUGPLAY_VIRTUAL_BUS_TYPE
;
184 // Plag and Play Event Categories
186 typedef enum _PLUGPLAY_EVENT_CATEGORY
188 HardwareProfileChangeEvent
,
189 TargetDeviceChangeEvent
,
190 DeviceClassChangeEvent
,
198 } PLUGPLAY_EVENT_CATEGORY
;
200 #ifdef NTOS_MODE_USER
203 // Information Structures for NtQueryKeyInformation
205 typedef struct _KEY_WRITE_TIME_INFORMATION
207 LARGE_INTEGER LastWriteTime
;
208 } KEY_WRITE_TIME_INFORMATION
, *PKEY_WRITE_TIME_INFORMATION
;
210 typedef struct _KEY_USER_FLAGS_INFORMATION
213 } KEY_USER_FLAGS_INFORMATION
, *PKEY_USER_FLAGS_INFORMATION
;
215 typedef struct _KEY_FULL_INFORMATION
217 LARGE_INTEGER LastWriteTime
;
225 ULONG MaxValueNameLen
;
226 ULONG MaxValueDataLen
;
228 } KEY_FULL_INFORMATION
, *PKEY_FULL_INFORMATION
;
230 typedef struct _KEY_NAME_INFORMATION
233 } KEY_NAME_INFORMATION
, *PKEY_NAME_INFORMATION
;
236 typedef struct _KEY_NODE_INFORMATION
238 LARGE_INTEGER LastWriteTime
;
244 } KEY_NODE_INFORMATION
, *PKEY_NODE_INFORMATION
;
246 typedef struct _KEY_VALUE_ENTRY
248 PUNICODE_STRING ValueName
;
252 } KEY_VALUE_ENTRY
, *PKEY_VALUE_ENTRY
;
254 typedef struct _KEY_VALUE_PARTIAL_INFORMATION
260 } KEY_VALUE_PARTIAL_INFORMATION
, *PKEY_VALUE_PARTIAL_INFORMATION
;
262 typedef struct _KEY_VALUE_BASIC_INFORMATION
268 } KEY_VALUE_BASIC_INFORMATION
, *PKEY_VALUE_BASIC_INFORMATION
;
270 typedef struct _KEY_VALUE_FULL_INFORMATION
278 } KEY_VALUE_FULL_INFORMATION
, *PKEY_VALUE_FULL_INFORMATION
;
280 typedef struct _KEY_BASIC_INFORMATION
282 LARGE_INTEGER LastWriteTime
;
286 } KEY_BASIC_INFORMATION
, *PKEY_BASIC_INFORMATION
;
291 // Plug and Play Event Block
293 typedef struct _PLUGPLAY_EVENT_BLOCK
296 PLUGPLAY_EVENT_CATEGORY EventCategory
;
306 WCHAR SymbolicLinkName
[ANYSIZE_ARRAY
];
310 WCHAR DeviceIds
[ANYSIZE_ARRAY
];
314 WCHAR DeviceId
[ANYSIZE_ARRAY
];
318 PVOID NotificationStructure
;
319 WCHAR DeviceIds
[ANYSIZE_ARRAY
];
320 } CustomNotification
;
324 } ProfileNotification
;
327 ULONG NotificationCode
;
328 ULONG NotificationData
;
332 PNP_VETO_TYPE VetoType
;
333 WCHAR DeviceIdVetoNameBuffer
[ANYSIZE_ARRAY
];
337 GUID BlockedDriverGuid
;
338 } BlockedDriverNotification
;
340 } PLUGPLAY_EVENT_BLOCK
, *PPLUGPLAY_EVENT_BLOCK
;
343 // Plug and Play Control Classes
347 typedef struct _PLUGPLAY_CONTROL_PROPERTY_DATA
349 UNICODE_STRING DeviceInstance
;
353 } PLUGPLAY_CONTROL_PROPERTY_DATA
, *PPLUGPLAY_CONTROL_PROPERTY_DATA
;
356 typedef struct _PLUGPLAY_CONTROL_RELATED_DEVICE_DATA
358 UNICODE_STRING TargetDeviceInstance
;
360 PWCHAR RelatedDeviceInstance
;
361 ULONG RelatedDeviceInstanceLength
;
362 } PLUGPLAY_CONTROL_RELATED_DEVICE_DATA
, *PPLUGPLAY_CONTROL_RELATED_DEVICE_DATA
;
365 typedef struct _PLUGPLAY_CONTOL_STATUS_DATA
367 UNICODE_STRING DeviceInstance
;
371 } PLUGPLAY_CONTROL_STATUS_DATA
, *PPLUGPLAY_CONTROL_STATUS_DATA
;
374 typedef struct _PLUGPLAY_CONTROL_DEPTH_DATA
376 UNICODE_STRING DeviceInstance
;
378 } PLUGPLAY_CONTROL_DEPTH_DATA
, *PPLUGPLAY_CONTROL_DEPTH_DATA
;
381 typedef struct _PLUGPLAY_CONTROL_RESET_DEVICE_DATA
383 UNICODE_STRING DeviceInstance
;
384 } PLUGPLAY_CONTROL_RESET_DEVICE_DATA
, *PPLUGPLAY_CONTROL_RESET_DEVICE_DATA
;
387 // Plug and Play Bus Type Definition
389 typedef struct _PLUGPLAY_BUS_TYPE
391 PLUGPLAY_BUS_CLASS BusClass
;
394 INTERFACE_TYPE SystemBusType
;
395 PLUGPLAY_VIRTUAL_BUS_TYPE PlugPlayVirtualBusType
;
397 } PLUGPLAY_BUS_TYPE
, *PPLUGPLAY_BUS_TYPE
;
400 // Plug and Play Bus Instance Definition
402 typedef struct _PLUGPLAY_BUS_INSTANCE
404 PLUGPLAY_BUS_TYPE BusType
;
406 WCHAR BusName
[MAX_BUS_NAME
];
407 } PLUGPLAY_BUS_INSTANCE
, *PPLUGPLAY_BUS_INSTANCE
;
409 #ifdef NTOS_MODE_USER
412 // Partial Resource Descriptor and List for Hardware
414 #include <pshpack1.h>
415 typedef struct _CM_PARTIAL_RESOURCE_DESCRIPTOR
418 UCHAR ShareDisposition
;
424 PHYSICAL_ADDRESS Start
;
429 PHYSICAL_ADDRESS Start
;
440 PHYSICAL_ADDRESS Start
;
464 } DeviceSpecificData
;
466 } CM_PARTIAL_RESOURCE_DESCRIPTOR
, *PCM_PARTIAL_RESOURCE_DESCRIPTOR
;
468 typedef struct _CM_PARTIAL_RESOURCE_LIST
473 CM_PARTIAL_RESOURCE_DESCRIPTOR PartialDescriptors
[1];
474 } CM_PARTIAL_RESOURCE_LIST
, *PCM_PARTIAL_RESOURCE_LIST
;
477 // Full Resource Descriptor and List for Hardware
479 typedef struct _CM_FULL_RESOURCE_DESCRIPTOR
481 INTERFACE_TYPE InterfaceType
;
483 CM_PARTIAL_RESOURCE_LIST PartialResourceList
;
484 } CM_FULL_RESOURCE_DESCRIPTOR
, *PCM_FULL_RESOURCE_DESCRIPTOR
;
486 typedef struct _CM_RESOURCE_LIST
489 CM_FULL_RESOURCE_DESCRIPTOR List
[1];
490 } CM_RESOURCE_LIST
, *PCM_RESOURCE_LIST
;
493 // ROM Block Structure
495 typedef struct _CM_ROM_BLOCK
499 } CM_ROM_BLOCK
, *PCM_ROM_BLOCK
;
502 // Disk/INT13 Structures
504 typedef struct _CM_INT13_DRIVE_PARAMETER
508 USHORT SectorsPerTrack
;
511 } CM_INT13_DRIVE_PARAMETER
, *PCM_INT13_DRIVE_PARAMETER
;
513 typedef struct _CM_DISK_GEOMETRY_DEVICE_DATA
515 ULONG BytesPerSector
;
516 ULONG NumberOfCylinders
;
517 ULONG SectorsPerTrack
;
519 } CM_DISK_GEOMETRY_DEVICE_DATA
, *PCM_DISK_GEOMETRY_DEVICE_DATA
;
523 #endif // _!NTOS_MODE_USER