58 ASSERT(IoDesc->Type == CmDesc->Type);
61 for (
Start = IoDesc->u.BusNumber.MinBusNumber;
62 Start <= IoDesc->
u.BusNumber.MaxBusNumber - IoDesc->u.BusNumber.Length + 1;
65 CmDesc->u.BusNumber.Length = IoDesc->u.BusNumber.Length;
66 CmDesc->u.BusNumber.Start =
Start;
74 DPRINT1(
"Satisfying bus number requirement with 0x%x (length: 0x%x)\n",
Start, CmDesc->u.BusNumber.Length);
91 ASSERT(IoDesc->Type == CmDesc->Type);
95 if (IoDesc->u.Memory.Alignment == 0)
96 IoDesc->u.Memory.Alignment = 1;
99 Start <= (
ULONGLONG)IoDesc->u.Memory.MaximumAddress.QuadPart - IoDesc->u.Memory.Length + 1;
100 Start += IoDesc->u.Memory.Alignment)
102 CmDesc->u.Memory.Length = IoDesc->u.Memory.Length;
108 ConflictingDesc.
u.
Memory.Length;
112 DPRINT1(
"Satisfying memory requirement with 0x%I64x (length: 0x%x)\n",
Start, CmDesc->u.Memory.Length);
129 ASSERT(IoDesc->Type == CmDesc->Type);
133 if (IoDesc->u.Port.Alignment == 0)
134 IoDesc->u.Port.Alignment = 1;
137 Start <= (
ULONGLONG)IoDesc->u.Port.MaximumAddress.QuadPart - IoDesc->u.Port.Length + 1;
138 Start += IoDesc->u.Port.Alignment)
140 CmDesc->u.Port.Length = IoDesc->u.Port.Length;
149 DPRINT(
"Satisfying port requirement with 0x%I64x (length: 0x%x)\n",
Start, CmDesc->u.Port.Length);
154 DPRINT1(
"IopFindPortResource failed!\n");
166 ASSERT(IoDesc->Type == CmDesc->Type);
169 for (Channel = IoDesc->u.Dma.MinimumChannel;
170 Channel <= IoDesc->
u.Dma.MaximumChannel;
173 CmDesc->u.Dma.Channel = Channel;
174 CmDesc->u.Dma.Port = 0;
178 DPRINT1(
"Satisfying DMA requirement with channel 0x%x\n", Channel);
194 ASSERT(IoDesc->Type == CmDesc->Type);
197 for (
Vector = IoDesc->u.Interrupt.MinimumVector;
201 CmDesc->u.Interrupt.Vector =
Vector;
202 CmDesc->u.Interrupt.Level =
Vector;
203 CmDesc->u.Interrupt.Affinity = (
KAFFINITY)-1;
207 DPRINT1(
"Satisfying interrupt requirement with IRQ 0x%x\n",
Vector);
212 DPRINT1(
"Failed to satisfy interrupt requirement with IRQ 0x%x-0x%x\n",
213 IoDesc->u.Interrupt.MinimumVector,
214 IoDesc->u.Interrupt.MaximumVector);
229 OldCount = (*ResourceList)->List[0].PartialResourceList.
Count;
245 else if (OldCount != 0)
267 for (ii = 0; ii < ResList->Count; ii++)
277 DPRINT(
"Skipping unneeded alternate\n");
284 DPRINT1(
"Unable to satisfy preferred resource or alternates in list %lu\n",
i);
290 for (iii = 0; PartialList && iii < PartialList->
Count && !Matched; iii++)
300 switch (IoDesc->
Type)
312 DPRINT(
"Interrupt - Not a match! 0x%x not inside 0x%x to 0x%x\n",
331 DPRINT(
"Memory/Port - Not a match! 0x%I64x with length 0x%x not inside 0x%I64x to 0x%I64x with length 0x%x\n",
332 CmDesc->
u.
Memory.Start.QuadPart,
334 IoDesc->
u.
Memory.MinimumAddress.QuadPart,
335 IoDesc->
u.
Memory.MaximumAddress.QuadPart,
351 DPRINT(
"Bus Number - Not a match! 0x%x with length 0x%x not inside 0x%x to 0x%x with length 0x%x\n",
362 if (CmDesc->
u.
Dma.Channel >= IoDesc->
u.
Dma.MinimumChannel &&
363 CmDesc->
u.
Dma.Channel <= IoDesc->
u.
Dma.MaximumChannel)
370 DPRINT(
"DMA - Not a match! 0x%x not inside 0x%x to 0x%x\n",
371 CmDesc->
u.
Dma.Channel,
372 IoDesc->
u.
Dma.MinimumChannel,
373 IoDesc->
u.
Dma.MaximumChannel);
398 switch (IoDesc->
Type)
404 DPRINT1(
"Failed to find an available interrupt resource (0x%x to 0x%x)\n",
407 FoundResource =
FALSE;
415 DPRINT1(
"Failed to find an available port resource (0x%I64x to 0x%I64x length: 0x%x)\n",
416 IoDesc->
u.
Port.MinimumAddress.QuadPart, IoDesc->
u.
Port.MaximumAddress.QuadPart,
417 IoDesc->
u.
Port.Length);
419 FoundResource =
FALSE;
427 DPRINT1(
"Failed to find an available memory resource (0x%I64x to 0x%I64x length: 0x%x)\n",
428 IoDesc->
u.
Memory.MinimumAddress.QuadPart, IoDesc->
u.
Memory.MaximumAddress.QuadPart,
431 FoundResource =
FALSE;
439 DPRINT1(
"Failed to find an available bus number resource (0x%x to 0x%x length: 0x%x)\n",
443 FoundResource =
FALSE;
451 DPRINT1(
"Failed to find an available dma resource (0x%x to 0x%x)\n",
452 IoDesc->
u.
Dma.MinimumChannel, IoDesc->
u.
Dma.MaximumChannel);
454 FoundResource =
FALSE;
459 DPRINT1(
"Unsupported resource type: %x\n", IoDesc->
Type);
460 FoundResource =
FALSE;
465 if (!FoundResource && IoDesc->
Option == 0)
468 DPRINT1(
"Unable to satisfy required resource in list %lu\n",
i);
471 else if (!FoundResource)
474 AlternateRequired =
TRUE;
480 AlternateRequired =
FALSE;
484 if (PartialList ==
NULL)
531 if (AlternateRequired)
533 DPRINT1(
"Unable to satisfy preferred resource or alternates in list %lu\n",
i);
544 DPRINT1(
"Out of alternate lists!\n");
575 for (ii = 0; ii < ResList->
Count; ii++)
587 if (ResDesc->Type != ResDesc2->
Type)
590 switch (ResDesc->Type)
594 (
ULONGLONG)ResDesc->u.Memory.Start.QuadPart + ResDesc->u.Memory.Length >
601 DPRINT1(
"Resource conflict: Memory (0x%I64x to 0x%I64x vs. 0x%I64x to 0x%I64x)\n",
602 ResDesc->u.Memory.Start.QuadPart, ResDesc->u.Memory.Start.QuadPart +
603 ResDesc->u.Memory.Length, ResDesc2->
u.
Memory.Start.QuadPart,
615 (
ULONGLONG)ResDesc->u.Port.Start.QuadPart + ResDesc->u.Port.Length >
618 ResDesc2->
u.
Port.Length > (
ULONGLONG)ResDesc->u.Port.Start.QuadPart))
622 DPRINT1(
"Resource conflict: Port (0x%I64x to 0x%I64x vs. 0x%I64x to 0x%I64x)\n",
623 ResDesc->u.Port.Start.QuadPart, ResDesc->u.Port.Start.QuadPart +
624 ResDesc->u.Port.Length, ResDesc2->
u.
Port.Start.QuadPart,
625 ResDesc2->
u.
Port.Start.QuadPart + ResDesc2->
u.
Port.Length);
635 if (ResDesc->u.Interrupt.Vector == ResDesc2->
u.
Interrupt.Vector)
639 DPRINT1(
"Resource conflict: IRQ (0x%x 0x%x vs. 0x%x 0x%x)\n",
640 ResDesc->u.Interrupt.Vector, ResDesc->u.Interrupt.Level,
651 if ((ResDesc->u.BusNumber.Start < ResDesc2->
u.
BusNumber.Start &&
652 ResDesc->u.BusNumber.Start + ResDesc->u.BusNumber.Length >
654 ResDesc->u.BusNumber.Start && ResDesc2->
u.
BusNumber.Start +
655 ResDesc2->
u.
BusNumber.Length > ResDesc->u.BusNumber.Start))
659 DPRINT1(
"Resource conflict: Bus number (0x%x to 0x%x vs. 0x%x to 0x%x)\n",
660 ResDesc->u.BusNumber.Start, ResDesc->u.BusNumber.Start +
661 ResDesc->u.BusNumber.Length, ResDesc2->
u.
BusNumber.Start,
672 if (ResDesc->u.Dma.Channel == ResDesc2->
u.
Dma.Channel)
676 DPRINT1(
"Resource conflict: Dma (0x%x 0x%x vs. 0x%x 0x%x)\n",
677 ResDesc->u.Dma.Channel, ResDesc->u.Dma.Port,
678 ResDesc2->
u.
Dma.Channel, ResDesc2->
u.
Dma.Port);
692 if (
Result && ConflictingDescriptor)
734 Status = ZwCreateKey(&ControlKey,
747 Status = ZwSetValueKey(ControlKey,
770 DPRINT(
"Sending IRP_MN_FILTER_RESOURCE_REQUIREMENTS to device stack\n");
772 Stack.Parameters.FilterResourceRequirements.IoResourceRequirementList =
DeviceNode->ResourceRequirements;
779 DPRINT1(
"IopInitiatePnpIrp(IRP_MN_FILTER_RESOURCE_REQUIREMENTS) failed\n");
799 HANDLE PnpMgrLevel1, PnpMgrLevel2, ResourceMapKey;
804 L"\\Registry\\Machine\\HARDWARE\\RESOURCEMAP");
810 Status = ZwCreateKey(&ResourceMapKey,
826 Status = ZwCreateKey(&PnpMgrLevel1,
843 Status = ZwCreateKey(&PnpMgrLevel2,
912 Status = ZwSetValueKey(PnpMgrLevel2,
930 Status = ZwSetValueKey(PnpMgrLevel2,
987 FullDescriptor = &
DeviceNode->ResourceList->List[0];
993 for (
j = 0;
j < pPartialResourceList->
Count;
j++)
1004 switch (DescriptorRaw->
Type)
1012 DescriptorRaw->
u.
Port.Start,
1014 &DescriptorTranslated->
u.
Port.Start))
1017 DPRINT1(
"Failed to translate port resource (Start: 0x%I64x)\n", DescriptorRaw->
u.
Port.Start.QuadPart);
1023 DPRINT1(
"Guessed incorrect address space: 1 -> 0\n");
1027 DescriptorRaw->
Flags =
1041 &DescriptorTranslated->
u.
Interrupt.Affinity);
1043 if (!DescriptorTranslated->
u.
Interrupt.Vector)
1046 DPRINT1(
"Failed to translate interrupt resource (Vector: 0x%x | Level: 0x%x)\n", DescriptorRaw->
u.
Interrupt.Vector,
1058 DescriptorRaw->
u.
Memory.Start,
1060 &DescriptorTranslated->
u.
Memory.Start))
1063 DPRINT1(
"Failed to translate memory resource (Start: 0x%I64x)\n", DescriptorRaw->
u.
Memory.Start.QuadPart);
1069 DPRINT1(
"Guessed incorrect address space: 0 -> 1\n");
1083 DPRINT1(
"Unknown resource descriptor type 0x%x\n", DescriptorRaw->
Type);
1146 DPRINT1(
"Boot resources for %wZ cause a resource conflict!\n", &
DeviceNode->InstancePath);
1169 DPRINT1(
"Failed to fixup a resource list from supplied resources for %wZ\n", &
DeviceNode->InstancePath);
1226 FullDescriptor = &ResourceList1->List[0];
1227 for (
i = 0;
i < ResourceList1->Count;
i++)
1232 for (ii = 0; ii < ResList->
Count; ii++)
1241 ConflictingDescriptor);
1260 ULONG KeyInformationLength,
RequiredLength, KeyValueInformationLength, KeyNameInformationLength;
1264 ULONG ChildKeyIndex1 = 0, ChildKeyIndex2 = 0, ChildKeyIndex3 = 0;
1282 Status = ZwEnumerateKey(ResourceMapKey,
1294 KeyInformationLength,
1296 if (!KeyInformation)
1302 Status = ZwEnumerateKey(ResourceMapKey,
1306 KeyInformationLength,
1325 Status = ZwOpenKey(&ChildKey2,
1334 Status = ZwEnumerateKey(ChildKey2,
1346 KeyInformationLength,
1348 if (!KeyInformation)
1354 Status = ZwEnumerateKey(ChildKey2,
1358 KeyInformationLength,
1384 Status = ZwEnumerateValueKey(ChildKey3,
1396 KeyValueInformationLength,
1398 if (!KeyValueInformation)
1404 Status = ZwEnumerateValueKey(ChildKey3,
1407 KeyValueInformation,
1408 KeyValueInformationLength,
1419 Status = ZwEnumerateValueKey(ChildKey3,
1429 KeyNameInformationLength +
sizeof(
WCHAR),
1437 Status = ZwEnumerateValueKey(ChildKey3,
1441 KeyNameInformationLength,
1468 ConflictingDescriptor))
1481 if (ResourceMapKey !=
NULL)
1483 if (ChildKey2 !=
NULL)
1485 if (ChildKey3 !=
NULL)
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble * u
IN PUNICODE_STRING IN POBJECT_ATTRIBUTES ObjectAttributes
#define CmResourceTypeDeviceSpecific
return STATUS_NOT_SUPPORTED
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR * PCM_PARTIAL_RESOURCE_DESCRIPTOR
#define CmResourceTypeDevicePrivate
#define STATUS_INSUFFICIENT_RESOURCES
#define STATUS_NO_MORE_ENTRIES
#define OBJ_CASE_INSENSITIVE
static BOOLEAN IopFindMemoryResource(IN PIO_RESOURCE_DESCRIPTOR IoDesc, OUT PCM_PARTIAL_RESOURCE_DESCRIPTOR CmDesc)
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR::@385::@388 Interrupt
CM_FULL_RESOURCE_DESCRIPTOR List[1]
struct _IO_RESOURCE_DESCRIPTOR::@1580::@1583 Interrupt
_CONST_RETURN wchar_t *__cdecl wcsstr(_In_z_ const wchar_t *_Str, _In_z_ const wchar_t *_SubStr)
NTSYSAPI NTSTATUS NTAPI ZwClose(_In_ HANDLE Handle)
#define IRP_MN_FILTER_RESOURCE_REQUIREMENTS
_In_ ULONG _In_ PHYSICAL_ADDRESS _Inout_ PULONG AddressSpace
NTSTATUS NTAPI IopDetectResourceConflict(IN PCM_RESOURCE_LIST ResourceList, IN BOOLEAN Silent, OUT OPTIONAL PCM_PARTIAL_RESOURCE_DESCRIPTOR ConflictingDescriptor)
#define DNF_NO_RESOURCE_REQUIRED
struct _IO_RESOURCE_REQUIREMENTS_LIST * PIO_RESOURCE_REQUIREMENTS_LIST
struct _IO_RESOURCE_DESCRIPTOR::@1580::@1587 BusNumber
static BOOLEAN IopCheckResourceDescriptor(IN PCM_PARTIAL_RESOURCE_DESCRIPTOR ResDesc, IN PCM_RESOURCE_LIST ResourceList, IN BOOLEAN Silent, OUT OPTIONAL PCM_PARTIAL_RESOURCE_DESCRIPTOR ConflictingDescriptor)
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR::@385::@387 Port
#define OBJ_KERNEL_HANDLE
_Must_inspect_result_ _In_ WDFIORESREQLIST _In_opt_ PWDF_OBJECT_ATTRIBUTES _Out_ WDFIORESLIST * ResourceList
_In_ ACCESS_MASK _In_ POBJECT_ATTRIBUTES _Reserved_ ULONG _In_opt_ PUNICODE_STRING _In_ ULONG _Out_opt_ PULONG Disposition
#define CmResourceTypePort
#define DNF_RESOURCE_ASSIGNED
#define STATUS_BUFFER_TOO_SMALL
struct _IO_RESOURCE_DESCRIPTOR::@1580::@1581 Port
_In_ WDFREQUEST _In_ PIO_STACK_LOCATION Stack
static NTSTATUS IopFilterResourceRequirements(IN PDEVICE_NODE DeviceNode)
CM_PARTIAL_RESOURCE_LIST PartialResourceList
return STATUS_NOT_IMPLEMENTED
union _CM_PARTIAL_RESOURCE_DESCRIPTOR::@385 u
static BOOLEAN IopFindInterruptResource(IN PIO_RESOURCE_DESCRIPTOR IoDesc, OUT PCM_PARTIAL_RESOURCE_DESCRIPTOR CmDesc)
NTSTATUS(* NTAPI)(IN PFILE_FULL_EA_INFORMATION EaBuffer, IN ULONG EaLength, OUT PULONG ErrorOffset)
ULONG NTAPI PnpDetermineResourceListSize(IN PCM_RESOURCE_LIST ResourceList)
static BOOLEAN IopFindBusNumberResource(IN PIO_RESOURCE_DESCRIPTOR IoDesc, OUT PCM_PARTIAL_RESOURCE_DESCRIPTOR CmDesc)
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR::@385::@391 Dma
#define IopDeviceNodeSetFlag(DeviceNode, Flag)
NTSTATUS NTAPI IopAssignDeviceResources(IN PDEVICE_NODE DeviceNode)
_In_ WDF_WMI_PROVIDER_CONTROL Control
#define CM_PROB_NORMAL_CONFLICT
_At_(*)(_In_ PWSK_CLIENT Client, _In_opt_ PUNICODE_STRING NodeName, _In_opt_ PUNICODE_STRING ServiceName, _In_opt_ ULONG NameSpace, _In_opt_ GUID *Provider, _In_opt_ PADDRINFOEXW Hints, _Outptr_ PADDRINFOEXW *Result, _In_opt_ PEPROCESS OwningProcess, _In_opt_ PETHREAD OwningThread, _Inout_ PIRP Irp Result)(Mem)) NTSTATUS(WSKAPI *PFN_WSK_GET_ADDRESS_INFO
NTSTATUS NTAPI HalAdjustResourceList(IN PIO_RESOURCE_REQUIREMENTS_LIST *ResourceList)
NTSTATUS NTAPI IoGetDeviceProperty(IN PDEVICE_OBJECT DeviceObject, IN DEVICE_REGISTRY_PROPERTY DeviceProperty, IN ULONG BufferLength, OUT PVOID PropertyBuffer, OUT PULONG ResultLength)
#define REG_RESOURCE_LIST
NTHALAPI ULONG NTAPI HalGetInterruptVector(INTERFACE_TYPE, ULONG, ULONG, ULONG, PKIRQL, PKAFFINITY)
_Must_inspect_result_ _In_ WDFDEVICE _In_ PCUNICODE_STRING KeyName
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR::@385::@393 BusNumber
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint GLint GLint j
struct _IO_RESOURCE_DESCRIPTOR::@1580::@1584 Dma
#define NT_SUCCESS(StatCode)
static LONG WINAPI EnumKey(HANDLE hcKey, DWORD dwIndex, LPWSTR pszName, PDWORD pcchName, PFILETIME pftLastWriteTime, HANDLE hSpooler)
NTSTATUS IopUpdateResourceMap(IN PDEVICE_NODE DeviceNode, PWCHAR Level1Key, PWCHAR Level2Key)
#define CM_PROB_TRANSLATION_FAILED
struct _IO_RESOURCE_DESCRIPTOR::@1580::@1582 Memory
static BOOLEAN IopFindPortResource(IN PIO_RESOURCE_DESCRIPTOR IoDesc, OUT PCM_PARTIAL_RESOURCE_DESCRIPTOR CmDesc)
#define IO_RESOURCE_ALTERNATIVE
#define STATUS_UNSUCCESSFUL
FORCEINLINE PCM_FULL_RESOURCE_DESCRIPTOR CmiGetNextResourceDescriptor(_In_ const CM_FULL_RESOURCE_DESCRIPTOR *ResourceDescriptor)
static NTSTATUS IopUpdateControlKeyWithResources(IN PDEVICE_NODE DeviceNode)
#define ExAllocatePoolWithTag(hernya, size, tag)
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING ValueName
static NTSTATUS IopTranslateDeviceResources(IN PDEVICE_NODE DeviceNode)
NTSTATUS NTAPI ObCloseHandle(IN HANDLE Handle, IN KPROCESSOR_MODE AccessMode)
CM_PARTIAL_RESOURCE_DESCRIPTOR PartialDescriptors[1]
static BOOLEAN IopCheckForResourceConflict(IN PCM_RESOURCE_LIST ResourceList1, IN PCM_RESOURCE_LIST ResourceList2, IN BOOLEAN Silent, OUT OPTIONAL PCM_PARTIAL_RESOURCE_DESCRIPTOR ConflictingDescriptor)
#define ExAllocatePool(type, size)
static BOOLEAN IopCheckDescriptorForConflict(PCM_PARTIAL_RESOURCE_DESCRIPTOR CmDesc, OPTIONAL PCM_PARTIAL_RESOURCE_DESCRIPTOR ConflictingDescriptor)
NTSTATUS IopUpdateResourceMapForPnPDevice(IN PDEVICE_NODE DeviceNode)
union _IO_RESOURCE_DESCRIPTOR::@1580 u
BOOLEAN NTAPI HalTranslateBusAddress(IN INTERFACE_TYPE InterfaceType, IN ULONG BusNumber, IN PHYSICAL_ADDRESS BusAddress, IN OUT PULONG AddressSpace, OUT PPHYSICAL_ADDRESS TranslatedAddress)
INTERFACE_TYPE InterfaceType
#define CM_RESOURCE_PORT_MEMORY
NTSTATUS NTAPI IopOpenRegistryKeyEx(PHANDLE KeyHandle, HANDLE ParentKey, PUNICODE_STRING Name, ACCESS_MASK DesiredAccess)
#define STATUS_BUFFER_OVERFLOW
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
static BOOLEAN IopFindDmaResource(IN PIO_RESOURCE_DESCRIPTOR IoDesc, OUT PCM_PARTIAL_RESOURCE_DESCRIPTOR CmDesc)
_In_ PKSERVICE_ROUTINE _In_opt_ PVOID _In_opt_ PKSPIN_LOCK _In_ ULONG Vector
NTSYSAPI NTSTATUS NTAPI RtlAppendUnicodeStringToString(PUNICODE_STRING Destination, PUNICODE_STRING Source)
static OUT PIO_STATUS_BLOCK IoStatusBlock
_In_ ULONG _Out_opt_ PULONG RequiredLength
#define DNF_ASSIGNING_RESOURCES
#define CmResourceTypeInterrupt
FORCEINLINE PIO_RESOURCE_LIST IopGetNextResourceList(_In_ const IO_RESOURCE_LIST *ResourceList)
_In_ WDFIORESREQLIST RequirementsList
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
#define InitializeObjectAttributes(p, n, a, r, s)
char * cleanup(char *str)
#define RtlCopyMemory(Destination, Source, Length)
#define CmResourceTypeBusNumber
#define ExFreePoolWithTag(_P, _T)
#define REG_OPTION_VOLATILE
#define IopDeviceNodeClearFlag(DeviceNode, Flag)
#define CmResourceTypeMemory
#define STATUS_CONFLICTING_ADDRESSES
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR::@385::@390 Memory
NTSTATUS NTAPI IopInitiatePnpIrp(IN PDEVICE_OBJECT DeviceObject, IN PIO_STATUS_BLOCK IoStatusBlock, IN UCHAR MinorFunction, IN PIO_STACK_LOCATION Stack)
#define CmResourceTypeDma
#define KEY_ENUMERATE_SUB_KEYS
#define RTL_CONSTANT_STRING(s)
NTSTATUS NTAPI IopFixupResourceListWithRequirements(IN PIO_RESOURCE_REQUIREMENTS_LIST RequirementsList, OUT PCM_RESOURCE_LIST *ResourceList)
PULONG MinorVersion OPTIONAL