ReactOS  0.4.15-dev-5496-g599ba9c
misc.c
Go to the documentation of this file.
1 /*
2  * PROJECT: ReactOS Storport Driver
3  * LICENSE: GPL-2.0+ (https://spdx.org/licenses/GPL-2.0+)
4  * PURPOSE: Storport helper functions
5  * COPYRIGHT: Copyright 2017 Eric Kohl (eric.kohl@reactos.org)
6  */
7 
8 /* INCLUDES *******************************************************************/
9 
10 #include "precomp.h"
11 
12 #define NDEBUG
13 #include <debug.h>
14 
15 
16 /* FUNCTIONS ******************************************************************/
17 
19 NTAPI
21  _In_ PDEVICE_OBJECT LowerDevice,
22  _In_ PIRP Irp)
23 {
24  ASSERT(LowerDevice);
25 
27  return IoCallDriver(LowerDevice, Irp);
28 }
29 
30 
34 {
35  GUID Guid;
36  ULONG Length;
38 
41  sizeof(Guid),
42  &Guid,
43  &Length);
44  if (!NT_SUCCESS(Status))
46 
47  if (RtlCompareMemory(&Guid, &GUID_BUS_TYPE_PCMCIA, sizeof(GUID)) == sizeof(GUID))
48  return PCMCIABus;
49  else if (RtlCompareMemory(&Guid, &GUID_BUS_TYPE_PCI, sizeof(GUID)) == sizeof(GUID))
50  return PCIBus;
51  else if (RtlCompareMemory(&Guid, &GUID_BUS_TYPE_ISAPNP, sizeof(GUID)) == sizeof(GUID))
52  return PNPISABus;
53 
55 }
56 
57 
58 static
59 ULONG
62 {
64  ULONG Size;
65 
66  DPRINT1("GetResourceListSize(%p)\n", ResourceList);
67 
68  Size = sizeof(CM_RESOURCE_LIST);
69  if (ResourceList->Count == 0)
70  {
71  DPRINT1("Size: 0x%lx (%u)\n", Size, Size);
72  return Size;
73  }
74 
75  DPRINT1("ResourceList->Count: %lu\n", ResourceList->Count);
76 
77  Descriptor = &ResourceList->List[0];
78 
79  DPRINT1("PartialResourceList->Count: %lu\n", Descriptor->PartialResourceList.Count);
80 
81  /* Add the size of the partial descriptors */
82  if (Descriptor->PartialResourceList.Count > 1)
83  Size += (Descriptor->PartialResourceList.Count - 1) * sizeof(CM_PARTIAL_RESOURCE_DESCRIPTOR);
84 
85  DPRINT1("Size: 0x%lx (%u)\n", Size, Size);
86  return Size;
87 }
88 
89 
94 {
96  ULONG Size;
97 
98  DPRINT1("CopyResourceList(%lu %p)\n",
99  PoolType, Source);
100 
101  /* Get the size of the resource list */
103 
104  /* Allocate a new buffer */
106  Size,
108  if (Destination == NULL)
109  return NULL;
110 
111  /* Copy the resource list */
113  Source,
114  Size);
115 
116  return Destination;
117 }
118 
119 
120 NTSTATUS
123  PGUID Guid,
124  USHORT Size,
125  USHORT Version,
128 {
129  KEVENT Event;
131  PIRP Irp;
134 
136 
138  DeviceObject,
139  NULL,
140  0,
141  NULL,
142  &Event,
143  &IoStatus);
144  if (Irp == NULL)
146 
148 
149  Stack->MajorFunction = IRP_MJ_PNP;
150  Stack->MinorFunction = IRP_MN_QUERY_INTERFACE;
151  Stack->Parameters.QueryInterface.InterfaceType = Guid;
152  Stack->Parameters.QueryInterface.Size = Size;
153  Stack->Parameters.QueryInterface.Version = Version;
154  Stack->Parameters.QueryInterface.Interface = (PINTERFACE)Interface;
155  Stack->Parameters.QueryInterface.InterfaceSpecificData = InterfaceSpecificData;
156 
157  Irp->IoStatus.Status = STATUS_NOT_SUPPORTED;
158 
160  if (Status == STATUS_PENDING)
161  {
163 
164  Status=IoStatus.Status;
165  }
166 
167  return Status;
168 }
169 
170 
171 BOOLEAN
173  PFDO_DEVICE_EXTENSION DeviceExtension,
175  ULONG SystemIoBusNumber,
176  STOR_PHYSICAL_ADDRESS IoAddress,
178  BOOLEAN InIoSpace,
180 {
181  PCM_FULL_RESOURCE_DESCRIPTOR FullDescriptorA, FullDescriptorT;
182  PCM_PARTIAL_RESOURCE_DESCRIPTOR PartialDescriptorA, PartialDescriptorT;
183  INT i, j;
184 
185  DPRINT1("TranslateResourceListAddress(%p)\n", DeviceExtension);
186 
187  FullDescriptorA = DeviceExtension->AllocatedResources->List;
188  FullDescriptorT = DeviceExtension->TranslatedResources->List;
189  for (i = 0; i < DeviceExtension->AllocatedResources->Count; i++)
190  {
191  for (j = 0; j < FullDescriptorA->PartialResourceList.Count; j++)
192  {
193  PartialDescriptorA = FullDescriptorA->PartialResourceList.PartialDescriptors + j;
194  PartialDescriptorT = FullDescriptorT->PartialResourceList.PartialDescriptors + j;
195 
196  switch (PartialDescriptorA->Type)
197  {
198  case CmResourceTypePort:
199  DPRINT1("Port: 0x%I64x (0x%lx)\n",
200  PartialDescriptorA->u.Port.Start.QuadPart,
201  PartialDescriptorA->u.Port.Length);
202  if (InIoSpace &&
203  IoAddress.QuadPart >= PartialDescriptorA->u.Port.Start.QuadPart &&
204  IoAddress.QuadPart + NumberOfBytes <= PartialDescriptorA->u.Port.Start.QuadPart + PartialDescriptorA->u.Port.Length)
205  {
206  TranslatedAddress->QuadPart = PartialDescriptorT->u.Port.Start.QuadPart +
207  (IoAddress.QuadPart - PartialDescriptorA->u.Port.Start.QuadPart);
208  return TRUE;
209  }
210  break;
211 
213  DPRINT1("Memory: 0x%I64x (0x%lx)\n",
214  PartialDescriptorA->u.Memory.Start.QuadPart,
215  PartialDescriptorA->u.Memory.Length);
216  if (!InIoSpace &&
217  IoAddress.QuadPart >= PartialDescriptorA->u.Memory.Start.QuadPart &&
218  IoAddress.QuadPart + NumberOfBytes <= PartialDescriptorA->u.Memory.Start.QuadPart + PartialDescriptorA->u.Memory.Length)
219  {
220  TranslatedAddress->QuadPart = PartialDescriptorT->u.Memory.Start.QuadPart +
221  (IoAddress.QuadPart - PartialDescriptorA->u.Memory.Start.QuadPart);
222  return TRUE;
223  }
224  break;
225  }
226  }
227 
228  /* Advance to next CM_FULL_RESOURCE_DESCRIPTOR block in memory. */
229  FullDescriptorA = (PCM_FULL_RESOURCE_DESCRIPTOR)(FullDescriptorA->PartialResourceList.PartialDescriptors +
230  FullDescriptorA->PartialResourceList.Count);
231 
232  FullDescriptorT = (PCM_FULL_RESOURCE_DESCRIPTOR)(FullDescriptorT->PartialResourceList.PartialDescriptors +
233  FullDescriptorT->PartialResourceList.Count);
234  }
235 
236  return FALSE;
237 }
238 
239 
240 NTSTATUS
242  PFDO_DEVICE_EXTENSION DeviceExtension,
243  PULONG Vector,
244  PKIRQL Irql,
248 {
249  PCM_FULL_RESOURCE_DESCRIPTOR FullDescriptor;
250  PCM_PARTIAL_RESOURCE_DESCRIPTOR PartialDescriptor;
251  INT i, j;
252 
253  DPRINT1("GetResourceListInterrupt(%p)\n",
254  DeviceExtension);
255 
256  FullDescriptor = DeviceExtension->TranslatedResources->List;
257  for (i = 0; i < DeviceExtension->TranslatedResources->Count; i++)
258  {
259  for (j = 0; j < FullDescriptor->PartialResourceList.Count; j++)
260  {
261  PartialDescriptor = FullDescriptor->PartialResourceList.PartialDescriptors + j;
262 
263  switch (PartialDescriptor->Type)
264  {
266  DPRINT1("Interrupt: Level %lu Vector %lu\n",
267  PartialDescriptor->u.Interrupt.Level,
268  PartialDescriptor->u.Interrupt.Vector);
269 
270  *Vector = PartialDescriptor->u.Interrupt.Vector;
271  *Irql = (KIRQL)PartialDescriptor->u.Interrupt.Level;
273  *ShareVector = (PartialDescriptor->ShareDisposition == CmResourceShareShared) ? TRUE : FALSE;
274  *Affinity = PartialDescriptor->u.Interrupt.Affinity;
275 
276  return STATUS_SUCCESS;
277  }
278  }
279 
280  /* Advance to next CM_FULL_RESOURCE_DESCRIPTOR block in memory. */
281  FullDescriptor = (PCM_FULL_RESOURCE_DESCRIPTOR)(FullDescriptor->PartialResourceList.PartialDescriptors +
282  FullDescriptor->PartialResourceList.Count);
283  }
284 
285  return STATUS_NOT_FOUND;
286 }
287 
288 
289 NTSTATUS
291  PMAPPED_ADDRESS *MappedAddressList,
292  STOR_PHYSICAL_ADDRESS IoAddress,
293  PVOID MappedAddress,
296 {
298 
299  DPRINT1("AllocateAddressMapping()\n");
300 
302  sizeof(MAPPED_ADDRESS),
304  if (Mapping == NULL)
305  {
306  DPRINT1("No memory!\n");
307  return STATUS_NO_MEMORY;
308  }
309 
311 
312  Mapping->NextMappedAddress = *MappedAddressList;
313  *MappedAddressList = Mapping;
314 
315  Mapping->IoAddress = IoAddress;
316  Mapping->MappedAddress = MappedAddress;
317  Mapping->NumberOfBytes = NumberOfBytes;
318  Mapping->BusNumber = BusNumber;
319 
320  return STATUS_SUCCESS;
321 }
322 
323 /* EOF */
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
Definition: glfuncs.h:240
return STATUS_NOT_SUPPORTED
_Must_inspect_result_ _In_ WDFDEVICE _In_ LPCGUID _Out_ PINTERFACE _In_ USHORT _In_ USHORT _In_opt_ PVOID InterfaceSpecificData
Definition: wdffdo.h:461
_In_ PKSERVICE_ROUTINE _In_opt_ PVOID _In_opt_ PKSPIN_LOCK _In_ ULONG _In_ KIRQL _In_ KIRQL _In_ KINTERRUPT_MODE InterruptMode
Definition: iofuncs.h:800
#define STATUS_INSUFFICIENT_RESOURCES
Definition: udferr_usr.h:158
_In_ ULONG _In_ ULONG _In_ ULONG Length
Definition: ntddpcm.h:101
_Must_inspect_result_ _In_ WDFIORESLIST _In_ PIO_RESOURCE_DESCRIPTOR Descriptor
Definition: wdfresource.h:339
enum _INTERFACE_TYPE INTERFACE_TYPE
PIRP NTAPI IoBuildSynchronousFsdRequest(IN ULONG MajorFunction, IN PDEVICE_OBJECT DeviceObject, IN PVOID Buffer, IN ULONG Length, IN PLARGE_INTEGER StartingOffset, IN PKEVENT Event, IN PIO_STATUS_BLOCK IoStatusBlock)
Definition: irp.c:1069
CM_FULL_RESOURCE_DESCRIPTOR List[1]
Definition: hwresource.cpp:165
_In_opt_ PUNICODE_STRING _In_ PDRIVER_OBJECT _In_ PDEVICE_OBJECT _In_ INTERFACE_TYPE BusType
Definition: halfuncs.h:156
PCM_RESOURCE_LIST CopyResourceList(POOL_TYPE PoolType, PCM_RESOURCE_LIST Source)
Definition: misc.c:91
#define TRUE
Definition: types.h:120
_In_ PKSERVICE_ROUTINE _In_opt_ PVOID _In_opt_ PKSPIN_LOCK _In_ ULONG _In_ KIRQL _In_ KIRQL _In_ KINTERRUPT_MODE _In_ BOOLEAN ShareVector
Definition: iofuncs.h:800
static PVOID Mapping[EMS_PHYSICAL_PAGES]
Definition: emsdrv.c:41
#define IRP_MJ_PNP
Definition: cdrw_usr.h:52
LONG NTSTATUS
Definition: precomp.h:26
IN PVOID IN PVOID IN USHORT IN USHORT Size
Definition: pci.h:361
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR::@381::@386 Memory
_In_ ULONG _In_ PHYSICAL_ADDRESS _Inout_ PULONG _Out_ PPHYSICAL_ADDRESS TranslatedAddress
Definition: iofuncs.h:2272
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR::@381::@383 Port
NTSTATUS NTAPI KeWaitForSingleObject(IN PVOID Object, IN KWAIT_REASON WaitReason, IN KPROCESSOR_MODE WaitMode, IN BOOLEAN Alertable, IN PLARGE_INTEGER Timeout OPTIONAL)
Definition: wait.c:416
NTSTATUS AllocateAddressMapping(PMAPPED_ADDRESS *MappedAddressList, STOR_PHYSICAL_ADDRESS IoAddress, PVOID MappedAddress, ULONG NumberOfBytes, ULONG BusNumber)
Definition: misc.c:290
_Out_ PKIRQL Irql
Definition: csq.h:179
int32_t INT
Definition: typedefs.h:58
_Must_inspect_result_ _In_ WDFIORESREQLIST _In_opt_ PWDF_OBJECT_ATTRIBUTES _Out_ WDFIORESLIST * ResourceList
Definition: wdfresource.h:304
INTERFACE_TYPE GetBusInterface(PDEVICE_OBJECT DeviceObject)
Definition: misc.c:32
#define CmResourceTypePort
Definition: hwresource.cpp:123
_In_ WDFREQUEST _In_ PIO_STACK_LOCATION Stack
Definition: wdfrequest.h:636
UCHAR KIRQL
Definition: env_spec_w32.h:591
CM_PARTIAL_RESOURCE_LIST PartialResourceList
Definition: hwresource.cpp:160
_In_ PDEVICE_OBJECT DeviceObject
Definition: wdfdevice.h:2055
NTSTATUS(* NTAPI)(IN PFILE_FULL_EA_INFORMATION EaBuffer, IN ULONG EaLength, OUT PULONG ErrorOffset)
Definition: IoEaTest.cpp:117
#define FALSE
Definition: types.h:117
_In_ PIRP Irp
Definition: csq.h:116
#define TAG_RESOURCE_LIST
Definition: precomp.h:30
struct _CM_FULL_RESOURCE_DESCRIPTOR * PCM_FULL_RESOURCE_DESCRIPTOR
BOOLEAN TranslateResourceListAddress(PFDO_DEVICE_EXTENSION DeviceExtension, INTERFACE_TYPE BusType, ULONG SystemIoBusNumber, STOR_PHYSICAL_ADDRESS IoAddress, ULONG NumberOfBytes, BOOLEAN InIoSpace, PPHYSICAL_ADDRESS TranslatedAddress)
Definition: misc.c:172
_In_ PVOID _In_ ULONG Event
Definition: iotypes.h:467
KAFFINITY * PKAFFINITY
Definition: basetsd.h:197
#define TAG_ADDRESS_MAPPING
Definition: precomp.h:31
unsigned char BOOLEAN
enum _KINTERRUPT_MODE KINTERRUPT_MODE
#define _In_
Definition: ms_sal.h:308
NTSTATUS NTAPI IoGetDeviceProperty(IN PDEVICE_OBJECT DeviceObject, IN DEVICE_REGISTRY_PROPERTY DeviceProperty, IN ULONG BufferLength, OUT PVOID PropertyBuffer, OUT PULONG ResultLength)
Definition: pnpmgr.c:1952
static ULONG GetResourceListSize(PCM_RESOURCE_LIST ResourceList)
Definition: misc.c:60
struct _INTERFACE * PINTERFACE
_In_opt_ PUNICODE_STRING _In_ PDRIVER_OBJECT _In_ PDEVICE_OBJECT _In_ INTERFACE_TYPE _In_ ULONG BusNumber
Definition: halfuncs.h:156
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
Definition: glfuncs.h:250
Status
Definition: gdiplustypes.h:24
#define STATUS_NOT_FOUND
Definition: shellext.h:72
#define ASSERT(a)
Definition: mode.c:44
#define NT_SUCCESS(StatCode)
Definition: apphelp.c:32
#define STATUS_PENDING
Definition: ntstatus.h:82
_Must_inspect_result_ _In_ WDFOBJECT _In_ CONST GUID * Guid
Definition: wdfobject.h:760
INT POOL_TYPE
Definition: typedefs.h:78
_In_ ULONG _In_ ULONG _In_ ULONG _Out_ PKIRQL _Out_ PKAFFINITY Affinity
Definition: halfuncs.h:170
_In_ PUNICODE_STRING _Inout_ PUNICODE_STRING Destination
Definition: rtlfuncs.h:2991
IN PVOID IN PVOID IN USHORT Version
Definition: pci.h:361
#define IRP_MN_QUERY_INTERFACE
#define ExAllocatePoolWithTag(hernya, size, tag)
Definition: env_spec_w32.h:350
char * PBOOLEAN
Definition: retypes.h:11
CM_PARTIAL_RESOURCE_DESCRIPTOR PartialDescriptors[1]
Definition: hwresource.cpp:119
KIRQL * PKIRQL
Definition: env_spec_w32.h:592
__drv_aliasesMem FORCEINLINE PIO_STACK_LOCATION IoGetNextIrpStackLocation(_In_ PIRP Irp)
Definition: iofuncs.h:2695
struct _CM_RESOURCE_LIST CM_RESOURCE_LIST
#define KeInitializeEvent(pEvt, foo, foo2)
Definition: env_spec_w32.h:477
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
Definition: glfuncs.h:248
IN PVOID IN PVOID IN USHORT IN USHORT IN PINTERFACE Interface
Definition: pci.h:361
unsigned short USHORT
Definition: pedump.c:61
NTSTATUS QueryBusInterface(PDEVICE_OBJECT DeviceObject, PGUID Guid, USHORT Size, USHORT Version, PBUS_INTERFACE_STANDARD Interface, PVOID InterfaceSpecificData)
Definition: misc.c:121
#define STATUS_NO_MEMORY
Definition: ntstatus.h:260
_Must_inspect_result_ typedef _In_ PHYSICAL_ADDRESS _Inout_ PLARGE_INTEGER NumberOfBytes
Definition: iotypes.h:1035
unsigned int * PULONG
Definition: retypes.h:1
NTSTATUS NTAPI ForwardIrpAndForget(IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp)
Definition: misc.c:18
#define NULL
Definition: types.h:112
NTSTATUS NTAPI IoCallDriver(IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp)
Definition: irp.c:1218
#define IoSkipCurrentIrpStackLocation(Irp)
Definition: ntifs_ex.h:421
#define CmResourceTypeInterrupt
Definition: hwresource.cpp:124
#define DPRINT1
Definition: precomp.h:8
struct _CM_PARTIAL_RESOURCE_DESCRIPTOR::@381::@384 Interrupt
PCM_RESOURCE_LIST TranslatedResources
Definition: precomp.h:104
#define CM_RESOURCE_INTERRUPT_LATCHED
Definition: cmtypes.h:144
_Must_inspect_result_ _In_ WDFDEVICE _In_ DEVICE_REGISTRY_PROPERTY _In_ _Strict_type_match_ POOL_TYPE PoolType
Definition: wdfdevice.h:3810
__in UCHAR __in POWER_STATE __in_opt PVOID __in PIO_STATUS_BLOCK IoStatus
Definition: mxum.h:155
unsigned int ULONG
Definition: retypes.h:1
#define RtlZeroMemory(Destination, Length)
Definition: typedefs.h:262
#define RtlCopyMemory(Destination, Source, Length)
Definition: typedefs.h:263
_In_ UINT _In_ UINT _In_ PNDIS_PACKET Source
Definition: ndis.h:3167
#define STATUS_SUCCESS
Definition: shellext.h:65
union _CM_PARTIAL_RESOURCE_DESCRIPTOR::@381 u
#define CmResourceTypeMemory
Definition: hwresource.cpp:125
nsresult QueryInterface(nsIIDRef riid, void **result)
#define RtlCompareMemory(s1, s2, l)
Definition: env_spec_w32.h:465
LONGLONG QuadPart
Definition: typedefs.h:114
NTSTATUS GetResourceListInterrupt(PFDO_DEVICE_EXTENSION DeviceExtension, PULONG Vector, PKIRQL Irql, KINTERRUPT_MODE *InterruptMode, PBOOLEAN ShareVector, PKAFFINITY Affinity)
Definition: misc.c:241
PCM_RESOURCE_LIST AllocatedResources
Definition: precomp.h:103