ReactOS 0.4.16-dev-597-gdbf7844
iomgr.c File Reference
#include <ntoskrnl.h>
#include <debug.h>
Include dependency graph for iomgr.c:

Go to the source code of this file.

Macros

#define NDEBUG
 

Functions

VOID NTAPI IopTimerDispatch (IN PKDPC Dpc, IN PVOID DeferredContext, IN PVOID SystemArgument1, IN PVOID SystemArgument2)
 
BOOLEAN NTAPI WmiInitialize (VOID)
 
VOID NTAPI IopInitLookasideLists (VOID)
 
BOOLEAN NTAPI IopCreateObjectTypes (VOID)
 
BOOLEAN NTAPI IopCreateRootDirectories (VOID)
 
BOOLEAN NTAPI IopMarkBootPartition (IN PLOADER_PARAMETER_BLOCK LoaderBlock)
 
BOOLEAN NTAPI IoInitSystem (IN PLOADER_PARAMETER_BLOCK LoaderBlock)
 
BOOLEAN NTAPI IoInitializeCrashDump (IN HANDLE PageFileHandle)
 

Variables

ULONG IopTraceLevel = 0
 
BOOLEAN PnpSystemInit = FALSE
 
POBJECT_TYPE IoDeviceObjectType = NULL
 
POBJECT_TYPE IoFileObjectType = NULL
 
POBJECT_TYPE IoControllerObjectType
 
BOOLEAN IoCountOperations = TRUE
 
ULONG IoReadOperationCount = 0
 
LARGE_INTEGER IoReadTransferCount = {{0, 0}}
 
ULONG IoWriteOperationCount = 0
 
LARGE_INTEGER IoWriteTransferCount = {{0, 0}}
 
ULONG IoOtherOperationCount = 0
 
LARGE_INTEGER IoOtherTransferCount = {{0, 0}}
 
KSPIN_LOCK IoStatisticsLock = 0
 
ULONG IopAutoReboot
 
ULONG IopNumTriageDumpDataBlocks
 
PVOID IopTriageDumpDataBlocks [64]
 
GENERIC_MAPPING IopFileMapping
 
LIST_ENTRY ShutdownListHead
 
LIST_ENTRY LastChanceShutdownListHead
 
KSPIN_LOCK ShutdownListLock
 
POBJECT_TYPE IoAdapterObjectType
 
ERESOURCE IopDatabaseResource
 
ERESOURCE IopSecurityResource
 
ERESOURCE IopDriverLoadResource
 
LIST_ENTRY IopDiskFileSystemQueueHead
 
LIST_ENTRY IopCdRomFileSystemQueueHead
 
LIST_ENTRY IopTapeFileSystemQueueHead
 
LIST_ENTRY IopNetworkFileSystemQueueHead
 
LIST_ENTRY DriverBootReinitListHead
 
LIST_ENTRY DriverReinitListHead
 
LIST_ENTRY IopFsNotifyChangeQueueHead
 
LIST_ENTRY IopErrorLogListHead
 
LIST_ENTRY IopTimerQueueHead
 
KDPC IopTimerDpc
 
KTIMER IopTimer
 
KSPIN_LOCK DriverReinitListLock
 
KSPIN_LOCK DriverBootReinitListLock
 
KSPIN_LOCK IopLogListLock
 
KSPIN_LOCK IopTimerLock
 
PDEVICE_OBJECT IopErrorLogObject
 
BOOLEAN PnPBootDriversInitialized
 
GENERAL_LOOKASIDE IoLargeIrpLookaside
 
GENERAL_LOOKASIDE IoSmallIrpLookaside
 
GENERAL_LOOKASIDE IopMdlLookasideList
 
GENERAL_LOOKASIDE IoCompletionPacketLookaside
 
PLOADER_PARAMETER_BLOCK IopLoaderBlock
 

Macro Definition Documentation

◆ NDEBUG

#define NDEBUG

Definition at line 13 of file iomgr.c.

Function Documentation

◆ IoInitializeCrashDump()

BOOLEAN NTAPI IoInitializeCrashDump ( IN HANDLE  PageFileHandle)

Definition at line 650 of file iomgr.c.

651{
653 return FALSE;
654}
#define UNIMPLEMENTED
Definition: ntoskrnl.c:15
#define FALSE
Definition: types.h:117

Referenced by NtCreatePagingFile().

◆ IoInitSystem()

BOOLEAN NTAPI IoInitSystem ( IN PLOADER_PARAMETER_BLOCK  LoaderBlock)

Definition at line 466 of file iomgr.c.

467{
468 LARGE_INTEGER ExpireTime;
470 CHAR Buffer[256];
471 ANSI_STRING NtBootPath, RootString;
472
473 /* Initialize empty NT Boot Path */
474 RtlInitEmptyAnsiString(&NtBootPath, Buffer, sizeof(Buffer));
475
476 /* Initialize the lookaside lists */
478
479 /* Initialize all locks and lists */
498
499 /* Initialize PnP notifications */
501
502 /* Initialize the reserve IRP */
504 {
505 DPRINT1("IopInitializeReserveIrp failed!\n");
506 return FALSE;
507 }
508
509 /* Initialize Timer List Lock */
511
512 /* Initialize Timer List */
514
515 /* Initialize the DPC/Timer which will call the other Timer Routines */
516 ExpireTime.QuadPart = -10000000;
519 KeSetTimerEx(&IopTimer, ExpireTime, 1000, &IopTimerDpc);
520
521 /* Create Object Types */
523 {
524 DPRINT1("IopCreateObjectTypes failed!\n");
525 return FALSE;
526 }
527
528 /* Create Object Directories */
530 {
531 DPRINT1("IopCreateRootDirectories failed!\n");
532 return FALSE;
533 }
534
535 /* Initialize PnP manager */
537
538 /* Initialize SHIM engine */
540
541 /* Initialize WMI */
543
544 /* Initialize HAL Root Bus Driver */
546
547 /* Reenumerate what HAL has added (synchronously)
548 * This function call should eventually become a 2nd stage of the PnP initialization */
551 NULL,
552 NULL);
553
554 /* Make loader block available for the whole kernel */
555 IopLoaderBlock = LoaderBlock;
556
557 /* Load boot start drivers */
559
560 /* Call back drivers that asked for */
562
563 /* Check if this was a ramdisk boot */
564 if (!_strnicmp(LoaderBlock->ArcBootDeviceName, "ramdisk(0)", 10))
565 {
566 /* Initialize the ramdisk driver */
567 IopStartRamdisk(LoaderBlock);
568 }
569
570 /* No one should need loader block any longer */
572
573 /* Create ARC names for boot devices */
574 Status = IopCreateArcNames(LoaderBlock);
575 if (!NT_SUCCESS(Status))
576 {
577 DPRINT1("IopCreateArcNames failed: %lx\n", Status);
578 return FALSE;
579 }
580
581 /* Mark the system boot partition */
582 if (!IopMarkBootPartition(LoaderBlock))
583 {
584 DPRINT1("IopMarkBootPartition failed!\n");
585 return FALSE;
586 }
587
588 /* The disk subsystem is initialized here and the SystemRoot is set too.
589 * We can finally load other drivers from the boot volume. */
591
592 /* Load system start drivers */
595
596 /* Reinitialize drivers that requested it */
598
599 /* Convert SystemRoot from ARC to NT path */
600 Status = IopReassignSystemRoot(LoaderBlock, &NtBootPath);
601 if (!NT_SUCCESS(Status))
602 {
603 DPRINT1("IopReassignSystemRoot failed: %lx\n", Status);
604 return FALSE;
605 }
606
607 /* Set the ANSI_STRING for the root path */
608 RootString.MaximumLength = NtSystemRoot.MaximumLength / sizeof(WCHAR);
609 RootString.Length = 0;
611 RootString.MaximumLength,
612 TAG_IO);
613
614 /* Convert the path into the ANSI_STRING */
616 if (!NT_SUCCESS(Status))
617 {
618 DPRINT1("RtlUnicodeStringToAnsiString failed: %lx\n", Status);
619 return FALSE;
620 }
621
622 /* Assign drive letters */
623 IoAssignDriveLetters(LoaderBlock,
624 &NtBootPath,
625 (PUCHAR)RootString.Buffer,
626 &RootString);
627
628 /* Update system root */
630 if (!NT_SUCCESS(Status))
631 {
632 DPRINT1("RtlAnsiStringToUnicodeString failed: %lx\n", Status);
633 return FALSE;
634 }
635
636 /* Load the System DLL and its entrypoints */
638 if (!NT_SUCCESS(Status))
639 {
640 DPRINT1("PsLocateSystemDll failed: %lx\n", Status);
641 return FALSE;
642 }
643
644 /* Return success */
645 return TRUE;
646}
LONG NTSTATUS
Definition: precomp.h:26
#define DPRINT1
Definition: precomp.h:8
VOID FASTCALL IoAssignDriveLetters(IN struct _LOADER_PARAMETER_BLOCK *LoaderBlock, IN PSTRING NtDeviceName, OUT PUCHAR NtSystemPath, OUT PSTRING NtSystemPathString)
Definition: ntoskrnl.c:40
Definition: bufpool.h:45
#define NULL
Definition: types.h:112
#define TRUE
Definition: types.h:120
#define NT_SUCCESS(StatCode)
Definition: apphelp.c:33
#define _strnicmp(_String1, _String2, _MaxCount)
Definition: compat.h:23
VOID NTAPI KeInitializeDpc(IN PKDPC Dpc, IN PKDEFERRED_ROUTINE DeferredRoutine, IN PVOID DeferredContext)
Definition: dpc.c:712
#define ExAllocatePoolWithTag(hernya, size, tag)
Definition: env_spec_w32.h:350
NTSTATUS ExInitializeResourceLite(PULONG res)
Definition: env_spec_w32.h:641
#define InitializeListHead(ListHead)
Definition: env_spec_w32.h:944
#define KeInitializeSpinLock(sl)
Definition: env_spec_w32.h:604
#define PagedPool
Definition: env_spec_w32.h:308
Status
Definition: gdiplustypes.h:25
LIST_ENTRY IopErrorLogListHead
Definition: error.c:30
LIST_ENTRY DriverReinitListHead
Definition: driver.c:22
KDPC IopTimerDpc
Definition: iotimer.c:22
VOID NTAPI IopInitLookasideLists(VOID)
Definition: iomgr.c:95
BOOLEAN NTAPI IopCreateRootDirectories(VOID)
Definition: iomgr.c:331
LIST_ENTRY ShutdownListHead
Definition: device.c:21
ERESOURCE IopDriverLoadResource
Definition: driver.c:20
ERESOURCE IopSecurityResource
Definition: iomgr.c:61
BOOLEAN PnPBootDriversInitialized
Definition: pnpinit.c:21
BOOLEAN PnpSystemInit
Definition: iomgr.c:17
KSPIN_LOCK DriverBootReinitListLock
Definition: driver.c:28
BOOLEAN NTAPI WmiInitialize(VOID)
Definition: wmi.c:38
KSPIN_LOCK IoStatisticsLock
Definition: iomgr.c:45
BOOLEAN NTAPI IopMarkBootPartition(IN PLOADER_PARAMETER_BLOCK LoaderBlock)
Definition: iomgr.c:396
KSPIN_LOCK IopTimerLock
Definition: iotimer.c:18
KSPIN_LOCK ShutdownListLock
Definition: device.c:22
LIST_ENTRY IopCdRomFileSystemQueueHead
Definition: volume.c:22
ERESOURCE IopDatabaseResource
Definition: volume.c:20
LIST_ENTRY DriverBootReinitListHead
Definition: driver.c:27
KSPIN_LOCK IopLogListLock
Definition: error.c:31
KSPIN_LOCK DriverReinitListLock
Definition: driver.c:23
KTIMER IopTimer
Definition: iotimer.c:23
LIST_ENTRY LastChanceShutdownListHead
Definition: device.c:21
VOID NTAPI IopTimerDispatch(IN PKDPC Dpc, IN PVOID DeferredContext, IN PVOID SystemArgument1, IN PVOID SystemArgument2)
Definition: iotimer.c:32
LIST_ENTRY IopNetworkFileSystemQueueHead
Definition: volume.c:21
LIST_ENTRY IopDiskFileSystemQueueHead
Definition: volume.c:21
PLOADER_PARAMETER_BLOCK IopLoaderBlock
Definition: iomgr.c:88
LIST_ENTRY IopFsNotifyChangeQueueHead
Definition: volume.c:23
BOOLEAN NTAPI IopCreateObjectTypes(VOID)
Definition: iomgr.c:242
LIST_ENTRY IopTimerQueueHead
Definition: iotimer.c:19
LIST_ENTRY IopTapeFileSystemQueueHead
Definition: volume.c:22
NTSYSAPI NTSTATUS NTAPI RtlUnicodeStringToAnsiString(PANSI_STRING DestinationString, PUNICODE_STRING SourceString, BOOLEAN AllocateDestinationString)
NTSYSAPI NTSTATUS NTAPI RtlAnsiStringToUnicodeString(PUNICODE_STRING DestinationString, PANSI_STRING SourceString, BOOLEAN AllocateDestinationString)
@ SynchronizationTimer
UNICODE_STRING NtSystemRoot
Definition: init.c:76
VOID NTAPI IopReinitializeBootDrivers(VOID)
Definition: driver.c:1532
@ PiActionEnumRootDevices
Definition: io.h:527
BOOLEAN NTAPI IopInitializeReserveIrp(IN PRESERVE_IRP_ALLOCATOR ReserveIrpAllocator)
Definition: irp.c:549
VOID FASTCALL IopInitializeSystemDrivers(VOID)
Definition: driver.c:1210
NTSTATUS NTAPI IopInitializePlugPlayServices(VOID)
Definition: pnpinit.c:287
VOID FASTCALL IopInitializeBootDrivers(VOID)
Definition: driver.c:1023
NTSTATUS NTAPI IopStartRamdisk(IN PLOADER_PARAMETER_BLOCK LoaderBlock)
Definition: ramdisk.c:26
VOID NTAPI IopReinitializeDrivers(VOID)
Definition: driver.c:1496
NTSTATUS NTAPI IopReassignSystemRoot(IN PLOADER_PARAMETER_BLOCK LoaderBlock, OUT PANSI_STRING NtBootPath)
Definition: arcname.c:842
VOID PiQueueDeviceAction(_In_ PDEVICE_OBJECT DeviceObject, _In_ DEVICE_ACTION Action, _In_opt_ PKEVENT CompletionEvent, _Out_opt_ NTSTATUS *CompletionStatus)
Queue a device operation to a worker thread.
Definition: devaction.c:2659
VOID PiInitializeNotifications(VOID)
Definition: pnpnotify.c:55
PDEVICE_NODE IopRootDeviceNode
Definition: devnode.c:18
NTSTATUS NTAPI IopCreateArcNames(IN PLOADER_PARAMETER_BLOCK LoaderBlock)
Definition: arcname.c:39
RESERVE_IRP_ALLOCATOR IopReserveIrpAllocator
Definition: irp.c:19
NTSTATUS NTAPI ApphelpCacheInitialize(VOID)
Definition: apphelp.c:439
NTSTATUS NTAPI PsLocateSystemDll(VOID)
Definition: psmgr.c:187
USHORT MaximumLength
Definition: env_spec_w32.h:377
PDEVICE_OBJECT PhysicalDeviceObject
Definition: iotypes.h:1005
USHORT MaximumLength
Definition: env_spec_w32.h:370
#define TAG_IO
Definition: tag.h:79
BOOLEAN NTAPI KeSetTimerEx(IN OUT PKTIMER Timer, IN LARGE_INTEGER DueTime, IN LONG Period, IN PKDPC Dpc OPTIONAL)
Definition: timerobj.c:294
VOID NTAPI KeInitializeTimerEx(OUT PKTIMER Timer, IN TIMER_TYPE Type)
Definition: timerobj.c:244
unsigned char * PUCHAR
Definition: typedefs.h:53
LONGLONG QuadPart
Definition: typedefs.h:114
#define HalInitPnpDriver
Definition: haltypes.h:300
__wchar_t WCHAR
Definition: xmlstorage.h:180
char CHAR
Definition: xmlstorage.h:175

Referenced by Phase1InitializationDiscard().

◆ IopCreateObjectTypes()

BOOLEAN NTAPI IopCreateObjectTypes ( VOID  )

Definition at line 242 of file iomgr.c.

243{
244 OBJECT_TYPE_INITIALIZER ObjectTypeInitializer;
246
247 /* Initialize default settings */
248 RtlZeroMemory(&ObjectTypeInitializer, sizeof(ObjectTypeInitializer));
249 ObjectTypeInitializer.Length = sizeof(ObjectTypeInitializer);
250 ObjectTypeInitializer.PoolType = NonPagedPool;
251 ObjectTypeInitializer.InvalidAttributes = OBJ_OPENLINK;
252 ObjectTypeInitializer.ValidAccessMask = FILE_ALL_ACCESS;
253 ObjectTypeInitializer.UseDefaultObject = TRUE;
254 ObjectTypeInitializer.GenericMapping = IopFileMapping;
255
256 /* Do the Adapter Type */
257 RtlInitUnicodeString(&Name, L"Adapter");
259 &ObjectTypeInitializer,
260 NULL,
261 &IoAdapterObjectType))) return FALSE;
262
263 /* Do the Controller Type */
264 RtlInitUnicodeString(&Name, L"Controller");
265 ObjectTypeInitializer.DefaultNonPagedPoolCharge = sizeof(CONTROLLER_OBJECT);
267 &ObjectTypeInitializer,
268 NULL,
269 &IoControllerObjectType))) return FALSE;
270
271 /* Do the Device Type */
272 RtlInitUnicodeString(&Name, L"Device");
273 ObjectTypeInitializer.DefaultNonPagedPoolCharge = sizeof(DEVICE_OBJECT);
274 ObjectTypeInitializer.DeleteProcedure = IopDeleteDevice;
275 ObjectTypeInitializer.ParseProcedure = IopParseDevice;
276 ObjectTypeInitializer.SecurityProcedure = IopGetSetSecurityObject;
277 ObjectTypeInitializer.CaseInsensitive = TRUE;
279 &ObjectTypeInitializer,
280 NULL,
281 &IoDeviceObjectType))) return FALSE;
282
283 /* Initialize the Driver object type */
284 RtlInitUnicodeString(&Name, L"Driver");
285 ObjectTypeInitializer.DefaultNonPagedPoolCharge = sizeof(DRIVER_OBJECT);
286 ObjectTypeInitializer.DeleteProcedure = IopDeleteDriver;
287 ObjectTypeInitializer.ParseProcedure = NULL;
288 ObjectTypeInitializer.SecurityProcedure = NULL;
290 &ObjectTypeInitializer,
291 NULL,
292 &IoDriverObjectType))) return FALSE;
293
294 /* Initialize the I/O Completion object type */
295 RtlInitUnicodeString(&Name, L"IoCompletion");
296 ObjectTypeInitializer.DefaultNonPagedPoolCharge = sizeof(KQUEUE);
297 ObjectTypeInitializer.ValidAccessMask = IO_COMPLETION_ALL_ACCESS;
298 ObjectTypeInitializer.InvalidAttributes |= OBJ_PERMANENT;
299 ObjectTypeInitializer.GenericMapping = IopCompletionMapping;
300 ObjectTypeInitializer.DeleteProcedure = IopDeleteIoCompletion;
302 &ObjectTypeInitializer,
303 NULL,
304 &IoCompletionType))) return FALSE;
305
306 /* Initialize the File object type */
307 RtlInitUnicodeString(&Name, L"File");
308 ObjectTypeInitializer.DefaultNonPagedPoolCharge = sizeof(FILE_OBJECT);
309 ObjectTypeInitializer.InvalidAttributes |= OBJ_EXCLUSIVE;
310 ObjectTypeInitializer.MaintainHandleCount = TRUE;
311 ObjectTypeInitializer.ValidAccessMask = FILE_ALL_ACCESS;
312 ObjectTypeInitializer.GenericMapping = IopFileMapping;
313 ObjectTypeInitializer.CloseProcedure = IopCloseFile;
314 ObjectTypeInitializer.DeleteProcedure = IopDeleteFile;
315 ObjectTypeInitializer.SecurityProcedure = IopGetSetSecurityObject;
316 ObjectTypeInitializer.QueryNameProcedure = IopQueryName;
317 ObjectTypeInitializer.ParseProcedure = IopParseFile;
318 ObjectTypeInitializer.UseDefaultObject = FALSE;
320 &ObjectTypeInitializer,
321 NULL,
322 &IoFileObjectType))) return FALSE;
323
324 /* Success */
325 return TRUE;
326}
struct NameRec_ * Name
Definition: cdprocs.h:460
struct _DEVICE_OBJECT DEVICE_OBJECT
#define NonPagedPool
Definition: env_spec_w32.h:307
#define OBJ_OPENLINK
Definition: winternl.h:230
#define OBJ_EXCLUSIVE
Definition: winternl.h:227
#define OBJ_PERMANENT
Definition: winternl.h:226
POBJECT_TYPE IoDeviceObjectType
Definition: iomgr.c:35
POBJECT_TYPE IoControllerObjectType
Definition: controller.c:16
GENERIC_MAPPING IopFileMapping
Definition: iomgr.c:50
POBJECT_TYPE IoFileObjectType
Definition: iomgr.c:36
POBJECT_TYPE IoAdapterObjectType
Definition: adapter.c:18
#define IO_COMPLETION_ALL_ACCESS
Definition: file.c:72
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
#define FILE_ALL_ACCESS
Definition: nt_native.h:651
@ FILE_OBJECT
Definition: ntobjenum.h:17
NTSTATUS NTAPI IopGetSetSecurityObject(IN PVOID ObjectBody, IN SECURITY_OPERATION_CODE OperationCode, IN PSECURITY_INFORMATION SecurityInformation, IN OUT PSECURITY_DESCRIPTOR SecurityDescriptor, IN OUT PULONG BufferLength, OUT PSECURITY_DESCRIPTOR *OldSecurityDescriptor, IN POOL_TYPE PoolType, IN OUT PGENERIC_MAPPING GenericMapping)
POBJECT_TYPE IoCompletionType
Definition: iocomp.c:16
NTSTATUS NTAPI IopParseFile(IN PVOID ParseObject, IN PVOID ObjectType, IN OUT PACCESS_STATE AccessState, IN KPROCESSOR_MODE AccessMode, IN ULONG Attributes, IN OUT PUNICODE_STRING CompleteName, IN OUT PUNICODE_STRING RemainingName, IN OUT PVOID Context OPTIONAL, IN PSECURITY_QUALITY_OF_SERVICE SecurityQos OPTIONAL, OUT PVOID *Object)
Definition: file.c:1319
NTSTATUS NTAPI IopQueryName(IN PVOID ObjectBody, IN BOOLEAN HasName, OUT POBJECT_NAME_INFORMATION ObjectNameInfo, IN ULONG Length, OUT PULONG ReturnLength, IN KPROCESSOR_MODE PreviousMode)
Definition: file.c:1926
VOID NTAPI IopDeleteDriver(IN PVOID ObjectBody)
Definition: driver.c:77
VOID NTAPI IopCloseFile(IN PEPROCESS Process OPTIONAL, IN PVOID Object, IN ACCESS_MASK GrantedAccess, IN ULONG ProcessHandleCount, IN ULONG SystemHandleCount)
Definition: file.c:2179
VOID NTAPI IopDeleteDevice(IN PVOID ObjectBody)
Definition: device.c:52
VOID NTAPI IopDeleteIoCompletion(PVOID ObjectBody)
Definition: iocomp.c:100
GENERIC_MAPPING IopCompletionMapping
Definition: iocomp.c:20
VOID NTAPI IopDeleteFile(IN PVOID ObjectBody)
Definition: file.c:1355
NTSTATUS NTAPI IopParseDevice(IN PVOID ParseObject, IN PVOID ObjectType, IN OUT PACCESS_STATE AccessState, IN KPROCESSOR_MODE AccessMode, IN ULONG Attributes, IN OUT PUNICODE_STRING CompleteName, IN OUT PUNICODE_STRING RemainingName, IN OUT PVOID Context, IN PSECURITY_QUALITY_OF_SERVICE SecurityQos OPTIONAL, OUT PVOID *Object)
Definition: file.c:324
POBJECT_TYPE IoDriverObjectType
Definition: driver.c:34
#define L(x)
Definition: ntvdm.h:50
NTSTATUS NTAPI ObCreateObjectType(IN PUNICODE_STRING TypeName, IN POBJECT_TYPE_INITIALIZER ObjectTypeInitializer, IN PVOID Reserved, OUT POBJECT_TYPE *ObjectType)
Definition: oblife.c:1136
OB_CLOSE_METHOD CloseProcedure
Definition: obtypes.h:368
OB_SECURITY_METHOD SecurityProcedure
Definition: obtypes.h:371
GENERIC_MAPPING GenericMapping
Definition: obtypes.h:358
OB_DELETE_METHOD DeleteProcedure
Definition: obtypes.h:369
BOOLEAN MaintainHandleCount
Definition: obtypes.h:361
OB_QUERYNAME_METHOD QueryNameProcedure
Definition: obtypes.h:372
OB_PARSE_METHOD ParseProcedure
Definition: obtypes.h:370
ULONG DefaultNonPagedPoolCharge
Definition: obtypes.h:365
#define RtlZeroMemory(Destination, Length)
Definition: typedefs.h:262
struct _DRIVER_OBJECT DRIVER_OBJECT
struct _CONTROLLER_OBJECT CONTROLLER_OBJECT
struct _KQUEUE KQUEUE

Referenced by IoInitSystem().

◆ IopCreateRootDirectories()

BOOLEAN NTAPI IopCreateRootDirectories ( VOID  )

Definition at line 331 of file iomgr.c.

332{
337
338 /* Create the '\Driver' object directory */
339 RtlInitUnicodeString(&DirName, L"\\Driver");
341 &DirName,
343 NULL,
344 NULL);
348 if (!NT_SUCCESS(Status))
349 {
350 DPRINT1("Failed to create \\Driver directory: 0x%lx\n", Status);
351 return FALSE;
352 }
354
355 /* Create the '\FileSystem' object directory */
356 RtlInitUnicodeString(&DirName, L"\\FileSystem");
358 &DirName,
360 NULL,
361 NULL);
365 if (!NT_SUCCESS(Status))
366 {
367 DPRINT1("Failed to create \\FileSystem directory: 0x%lx\n", Status);
368 return FALSE;
369 }
371
372 /* Create the '\FileSystem' object directory */
373 RtlInitUnicodeString(&DirName, L"\\FileSystem\\Filters");
375 &DirName,
377 NULL,
378 NULL);
382 if (!NT_SUCCESS(Status))
383 {
384 DPRINT1("Failed to create \\FileSystem\\Filters directory: 0x%lx\n", Status);
385 return FALSE;
386 }
388
389 /* Return success */
390 return TRUE;
391}
_In_ PFCB _In_ PCD_NAME DirName
Definition: cdprocs.h:737
IN PUNICODE_STRING IN POBJECT_ATTRIBUTES ObjectAttributes
Definition: conport.c:36
ULONG Handle
Definition: gdb_input.c:15
#define InitializeObjectAttributes(p, n, a, r, s)
Definition: reg.c:106
NTSTATUS NTAPI NtClose(IN HANDLE Handle)
Definition: obhandle.c:3402
#define DIRECTORY_ALL_ACCESS
Definition: nt_native.h:1259
NTSTATUS NTAPI NtCreateDirectoryObject(OUT PHANDLE DirectoryHandle, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes)
Definition: obdir.c:765

Referenced by IoInitSystem().

◆ IopInitLookasideLists()

VOID NTAPI IopInitLookasideLists ( VOID  )

Definition at line 95 of file iomgr.c.

96{
97 ULONG LargeIrpSize, SmallIrpSize, MdlSize;
98 LONG i;
99 PKPRCB Prcb;
100 PGENERAL_LOOKASIDE CurrentList = NULL;
101
102 /* Calculate the sizes */
103 LargeIrpSize = sizeof(IRP) + (8 * sizeof(IO_STACK_LOCATION));
104 SmallIrpSize = sizeof(IRP) + sizeof(IO_STACK_LOCATION);
105 MdlSize = sizeof(MDL) + (23 * sizeof(PFN_NUMBER));
106
107 /* Initialize the Lookaside List for I\O Completion */
111 IOC_TAG1,
112 32,
114
115 /* Initialize the Lookaside List for Large IRPs */
118 LargeIrpSize,
120 64,
122
123
124 /* Initialize the Lookaside List for Small IRPs */
127 SmallIrpSize,
129 32,
131
132 /* Initialize the Lookaside List for MDLs */
135 MdlSize,
136 TAG_MDL,
137 128,
139
140 /* Allocate the global lookaside list buffer */
143 sizeof(GENERAL_LOOKASIDE),
144 TAG_IO);
145
146 /* Loop all processors */
147 for (i = 0; i < KeNumberProcessors; i++)
148 {
149 /* Get the PRCB for this CPU */
150 Prcb = KiProcessorBlock[i];
151 DPRINT("Setting up lookaside for CPU: %x, PRCB: %p\n", i, Prcb);
152
153 /* Write IRP credit limit */
155
156 /* Set the I/O Completion List */
158 if (CurrentList)
159 {
160 /* Initialize the Lookaside List for mini-packets */
165 32,
167 Prcb->PPLookasideList[LookasideCompletionList].P = CurrentList;
168 CurrentList++;
169
170 }
171 else
172 {
174 }
175
176 /* Set the Large IRP List */
178 if (CurrentList)
179 {
180 /* Initialize the Lookaside List for Large IRPs */
183 LargeIrpSize,
185 64,
187 Prcb->PPLookasideList[LookasideLargeIrpList].P = CurrentList;
188 CurrentList++;
189
190 }
191 else
192 {
194 }
195
196 /* Set the Small IRP List */
198 if (CurrentList)
199 {
200 /* Initialize the Lookaside List for Small IRPs */
203 SmallIrpSize,
205 32,
207 Prcb->PPLookasideList[LookasideSmallIrpList].P = CurrentList;
208 CurrentList++;
209
210 }
211 else
212 {
214 }
215
216 /* Set the MDL Completion List */
218 if (CurrentList)
219 {
220 /* Initialize the Lookaside List for MDLs */
223 SmallIrpSize,
224 TAG_MDL,
225 128,
227
228 Prcb->PPLookasideList[LookasideMdlList].P = CurrentList;
229 CurrentList++;
230
231 }
232 else
233 {
235 }
236 }
237}
struct _IRP IRP
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
GENERAL_LOOKASIDE IoLargeIrpLookaside
Definition: iomgr.c:83
GENERAL_LOOKASIDE IoSmallIrpLookaside
Definition: iomgr.c:84
GENERAL_LOOKASIDE IoCompletionPacketLookaside
Definition: iocomp.c:18
GENERAL_LOOKASIDE IopMdlLookasideList
Definition: iomgr.c:85
CCHAR KeNumberProcessors
Definition: krnlinit.c:35
VOID NTAPI ExInitializeSystemLookasideList(IN PGENERAL_LOOKASIDE List, IN POOL_TYPE Type, IN ULONG Size, IN ULONG Tag, IN USHORT MaximumDepth, IN PLIST_ENTRY ListHead)
Definition: lookas.c:31
LIST_ENTRY ExSystemLookasideListHead
Definition: lookas.c:21
@ LookasideLargeIrpList
Definition: mmtypes.h:169
@ LookasideCompletionList
Definition: mmtypes.h:174
@ LookasideMdlList
Definition: mmtypes.h:170
@ LookasideSmallIrpList
Definition: mmtypes.h:168
PKPRCB KiProcessorBlock[]
Definition: krnlinit.c:32
long LONG
Definition: pedump.c:60
ULONG PFN_NUMBER
Definition: ke.h:9
#define DPRINT
Definition: sndvol32.h:73
PP_LOOKASIDE_LIST PPLookasideList[16]
Definition: ketypes.h:717
LONG LookasideIrpFloat
Definition: ketypes.h:748
struct _GENERAL_LOOKASIDE * P
Definition: ketypes.h:871
struct _GENERAL_LOOKASIDE * L
Definition: ketypes.h:872
#define IO_SMALLIRP_CPU
Definition: tag.h:75
#define IO_LARGEIRP
Definition: tag.h:72
#define IO_SMALLIRP
Definition: tag.h:73
#define TAG_MDL
Definition: tag.h:88
#define IO_LARGEIRP_CPU
Definition: tag.h:74
#define IOC_TAG1
Definition: tag.h:76
uint32_t ULONG
Definition: typedefs.h:59
struct LOOKASIDE_ALIGN _GENERAL_LOOKASIDE GENERAL_LOOKASIDE
struct LOOKASIDE_ALIGN _GENERAL_LOOKASIDE * PGENERAL_LOOKASIDE
MDL
Definition: mmtypes.h:117

Referenced by IoInitSystem().

◆ IopMarkBootPartition()

BOOLEAN NTAPI IopMarkBootPartition ( IN PLOADER_PARAMETER_BLOCK  LoaderBlock)

Definition at line 396 of file iomgr.c.

397{
399 STRING DeviceString;
400 CHAR Buffer[256];
406
407 /* Build the ARC device name */
408 sprintf(Buffer, "\\ArcName\\%s", LoaderBlock->ArcBootDeviceName);
409 RtlInitAnsiString(&DeviceString, Buffer);
411 if (!NT_SUCCESS(Status)) return FALSE;
412
413 /* Open it */
415 &DeviceName,
417 NULL,
418 NULL);
423 0,
425 if (!NT_SUCCESS(Status))
426 {
427 /* Fail */
428 KeBugCheckEx(INACCESSIBLE_BOOT_DEVICE,
430 Status,
431 0,
432 0);
433 }
434
435 /* Get the DO */
437 0,
440 (PVOID *)&FileObject,
441 NULL);
442 if (!NT_SUCCESS(Status))
443 {
444 /* Fail */
446 return FALSE;
447 }
448
449 /* Mark it as the boot partition */
450 FileObject->DeviceObject->Flags |= DO_SYSTEM_BOOT_PARTITION;
451
452 /* Save a copy of the DO for the I/O Error Logger */
453 ObReferenceObject(FileObject->DeviceObject);
454 IopErrorLogObject = FileObject->DeviceObject;
455
456 /* Cleanup and return success */
460 return TRUE;
461}
#define FILE_NON_DIRECTORY_FILE
Definition: constants.h:492
#define DO_SYSTEM_BOOT_PARTITION
Definition: env_spec_w32.h:400
_Must_inspect_result_ _In_opt_ PFLT_INSTANCE _Out_ PHANDLE FileHandle
Definition: fltkernel.h:1231
std::wstring STRING
Definition: fontsub.cpp:33
#define OBJ_CASE_INSENSITIVE
Definition: winternl.h:228
PDEVICE_OBJECT IopErrorLogObject
Definition: error.c:38
#define sprintf(buf, format,...)
Definition: sprintf.c:55
static OUT PIO_STATUS_BLOCK IoStatusBlock
Definition: pipe.c:75
#define KernelMode
Definition: asm.h:38
NTSYSAPI NTSTATUS NTAPI ZwOpenFile(_Out_ PHANDLE FileHandle, _In_ ACCESS_MASK DesiredAccess, _In_ POBJECT_ATTRIBUTES ObjectAttributes, _Out_ PIO_STATUS_BLOCK IoStatusBlock, _In_ ULONG ShareAccess, _In_ ULONG OpenOptions)
#define FILE_READ_ATTRIBUTES
Definition: nt_native.h:647
NTSYSAPI VOID NTAPI RtlFreeUnicodeString(PUNICODE_STRING UnicodeString)
NTSYSAPI VOID NTAPI RtlInitAnsiString(PANSI_STRING DestinationString, PCSZ SourceString)
NTSTATUS NTAPI ObReferenceObjectByHandle(IN HANDLE Handle, IN ACCESS_MASK DesiredAccess, IN POBJECT_TYPE ObjectType, IN KPROCESSOR_MODE AccessMode, OUT PVOID *Object, OUT POBJECT_HANDLE_INFORMATION HandleInformation OPTIONAL)
Definition: obref.c:494
VOID NTAPI KeBugCheckEx(_In_ ULONG BugCheckCode, _In_ ULONG_PTR BugCheckParameter1, _In_ ULONG_PTR BugCheckParameter2, _In_ ULONG_PTR BugCheckParameter3, _In_ ULONG_PTR BugCheckParameter4)
Definition: rtlcompat.c:108
uint32_t ULONG_PTR
Definition: typedefs.h:65
_In_ WDFREQUEST _In_ WDFFILEOBJECT FileObject
Definition: wdfdevice.h:550
_Must_inspect_result_ _In_ PWDFDEVICE_INIT _In_opt_ PCUNICODE_STRING DeviceName
Definition: wdfdevice.h:3275
* PFILE_OBJECT
Definition: iotypes.h:1998
#define ObDereferenceObject
Definition: obfuncs.h:203
#define ObReferenceObject
Definition: obfuncs.h:204

Referenced by IoInitSystem().

◆ IopTimerDispatch()

VOID NTAPI IopTimerDispatch ( IN PKDPC  Dpc,
IN PVOID  DeferredContext,
IN PVOID  SystemArgument1,
IN PVOID  SystemArgument2 
)

Definition at line 32 of file iotimer.c.

36{
38 PLIST_ENTRY TimerEntry;
40 ULONG i;
41
42 /* Check if any Timers are actually enabled as of now */
43 if (IopTimerCount)
44 {
45 /* Lock the Timers */
47
48 /* Call the Timer Routine of each enabled Timer */
49 for (TimerEntry = IopTimerQueueHead.Flink, i = IopTimerCount;
50 (TimerEntry != &IopTimerQueueHead) && i;
51 TimerEntry = TimerEntry->Flink)
52 {
53 /* Get the timer and check if it's enabled */
54 Timer = CONTAINING_RECORD(TimerEntry, IO_TIMER, IoTimerList);
55 if (Timer->TimerEnabled)
56 {
57 /* Call the timer routine */
58 Timer->TimerRoutine(Timer->DeviceObject, Timer->Context);
59 i--;
60 }
61 }
62
63 /* Unlock the Timers */
65 }
66}
UCHAR KIRQL
Definition: env_spec_w32.h:591
#define KeReleaseSpinLock(sl, irql)
Definition: env_spec_w32.h:627
#define KeAcquireSpinLock(sl, irql)
Definition: env_spec_w32.h:609
KSPIN_LOCK IopTimerLock
Definition: iotimer.c:18
ULONG IopTimerCount
Definition: iotimer.c:26
LIST_ENTRY IopTimerQueueHead
Definition: iotimer.c:19
Definition: typedefs.h:120
struct _LIST_ENTRY * Flink
Definition: typedefs.h:121
#define CONTAINING_RECORD(address, type, field)
Definition: typedefs.h:260
_Requires_lock_held_ Interrupt _Releases_lock_ Interrupt _In_ _IRQL_restores_ KIRQL OldIrql
Definition: kefuncs.h:778

Referenced by IoInitSystem().

◆ WmiInitialize()

BOOLEAN NTAPI WmiInitialize ( VOID  )

Definition at line 38 of file wmi.c.

40{
41 UNICODE_STRING DriverName = RTL_CONSTANT_STRING(L"\\Driver\\WMIxWDM");
43
44 /* Initialize the GUID object type */
46 if (!NT_SUCCESS(Status))
47 {
48 DPRINT1("WmipInitializeGuidObjectType() failed: 0x%lx\n", Status);
49 return FALSE;
50 }
51
52 /* Create the WMI driver */
53 Status = IoCreateDriver(&DriverName, WmipDriverEntry);
54 if (!NT_SUCCESS(Status))
55 {
56 DPRINT1("Failed to create WMI driver: 0x%lx\n", Status);
57 return FALSE;
58 }
59
60 return TRUE;
61}
NTSTATUS NTAPI WmipInitializeGuidObjectType(VOID)
Definition: guidobj.c:113
NTSTATUS NTAPI IoCreateDriver(_In_opt_ PUNICODE_STRING DriverName, _In_ PDRIVER_INITIALIZE InitializationFunction)
Definition: driver.c:1576
#define RTL_CONSTANT_STRING(s)
Definition: tunneltest.c:14

Referenced by IoInitSystem().

Variable Documentation

◆ DriverBootReinitListHead

LIST_ENTRY DriverBootReinitListHead
extern

◆ DriverBootReinitListLock

KSPIN_LOCK DriverBootReinitListLock
extern

◆ DriverReinitListHead

LIST_ENTRY DriverReinitListHead
extern

Definition at line 22 of file driver.c.

Referenced by IoInitSystem(), IopReinitializeDrivers(), and IoRegisterDriverReinitialization().

◆ DriverReinitListLock

KSPIN_LOCK DriverReinitListLock
extern

Definition at line 23 of file driver.c.

Referenced by IoInitSystem(), IopReinitializeDrivers(), and IoRegisterDriverReinitialization().

◆ IoAdapterObjectType

POBJECT_TYPE IoAdapterObjectType
extern

Definition at line 18 of file adapter.c.

Referenced by IopCreateObjectTypes().

◆ IoCompletionPacketLookaside

GENERAL_LOOKASIDE IoCompletionPacketLookaside
extern

Definition at line 18 of file iocomp.c.

Referenced by IopInitLookasideLists().

◆ IoControllerObjectType

POBJECT_TYPE IoControllerObjectType
extern

Definition at line 16 of file controller.c.

Referenced by IoCreateController(), and IopCreateObjectTypes().

◆ IoCountOperations

BOOLEAN IoCountOperations = TRUE

Definition at line 38 of file iomgr.c.

Referenced by IopUpdateOperationCount(), and IopUpdateTransferCount().

◆ IoDeviceObjectType

POBJECT_TYPE IoDeviceObjectType = NULL

◆ IoFileObjectType

POBJECT_TYPE IoFileObjectType = NULL

Definition at line 36 of file iomgr.c.

Referenced by add_device(), AfdBindSocket(), BasicBehaviorChecks(), CompBattGetDeviceObjectPointer(), Control(), create_snapshot(), CreateGreenFdo(), CreateMixerPinAndSetFormat(), DispTdiAssociateAddress(), duplicate_extents(), Ext2InvalidateVolumes(), IKsPin_PinMasterClock(), invalidate_volumes(), IoCheckDesiredAccess(), IoComputeDesiredAccessFileObject(), IoCreateStreamFileObjectEx(), IoCreateStreamFileObjectLite(), IopCreateObjectTypes(), IopDeviceFsIoControl(), IopGetDeviceObjectPointer(), IopMarkBootPartition(), IopOpenLinkOrRenameTarget(), IopParseDevice(), KernelModeTest(), MmCreateArm3Section(), MmCreateSection(), MountMgrVolumeMountPointChanged(), NtCancelIoFile(), NtCreatePagingFile(), NtFlushBuffersFile(), NtLoadKeyEx(), NtLockFile(), NtNotifyChangeDirectoryFile(), NtQueryDirectoryFile(), NtQueryInformationFile(), NtQueryVolumeInformationFile(), NtReadFile(), NtSaveKeyEx(), NtSaveMergedKeys(), NtSetInformationFile(), NtSetVolumeInformationFile(), NtUnlockFile(), ObpLookupObjectName(), OpenDevice(), FxIoTargetRemote::OpenTargetHandle(), Pin_fnDeviceIoControl(), Pin_fnWrite(), PopAddRemoveSysCapsCallback(), send_subvol(), START_TEST(), TdiOpenDevice(), TestIoCreateFile(), TestObjectTypes(), TestProviderInfo(), TestSharedCacheMap(), TestSymlinks(), TestTcpConnect(), UDFInvalidateVolumes(), VfatSetRenameInformation(), WdmAudControlDeviceState(), WdmAudFrameSize(), WdmAudOpenSysAudioDevices(), WdmAudReadWrite(), and WdmAudResetStream().

◆ IoLargeIrpLookaside

GENERAL_LOOKASIDE IoLargeIrpLookaside

Definition at line 83 of file iomgr.c.

Referenced by IopInitLookasideLists().

◆ IoOtherOperationCount

ULONG IoOtherOperationCount = 0

Definition at line 43 of file iomgr.c.

Referenced by IopUpdateOperationCount(), and QSI_DEF().

◆ IoOtherTransferCount

LARGE_INTEGER IoOtherTransferCount = {{0, 0}}

Definition at line 44 of file iomgr.c.

Referenced by IopUpdateTransferCount(), and QSI_DEF().

◆ IopAutoReboot

ULONG IopAutoReboot

Definition at line 46 of file iomgr.c.

Referenced by KeBugCheckWithTf().

◆ IopCdRomFileSystemQueueHead

LIST_ENTRY IopCdRomFileSystemQueueHead
extern

◆ IopDatabaseResource

◆ IopDiskFileSystemQueueHead

LIST_ENTRY IopDiskFileSystemQueueHead
extern

◆ IopDriverLoadResource

ERESOURCE IopDriverLoadResource
extern

Definition at line 20 of file driver.c.

Referenced by IoInitSystem().

◆ IopErrorLogListHead

LIST_ENTRY IopErrorLogListHead
extern

Definition at line 30 of file error.c.

Referenced by IoInitSystem(), IopGetErrorLogEntry(), IopLogWorker(), and IoWriteErrorLogEntry().

◆ IopErrorLogObject

PDEVICE_OBJECT IopErrorLogObject
extern

Definition at line 38 of file error.c.

Referenced by IopMarkBootPartition().

◆ IopFileMapping

GENERIC_MAPPING IopFileMapping
Initial value:
= {
#define FILE_GENERIC_EXECUTE
Definition: nt_native.h:668
#define FILE_GENERIC_READ
Definition: nt_native.h:653
#define FILE_GENERIC_WRITE
Definition: nt_native.h:660

Definition at line 50 of file iomgr.c.

Referenced by IoGetFileObjectGenericMapping(), and IopCreateObjectTypes().

◆ IopFsNotifyChangeQueueHead

◆ IopLoaderBlock

PLOADER_PARAMETER_BLOCK IopLoaderBlock

Definition at line 88 of file iomgr.c.

Referenced by IoGetBootDiskInformation(), and IoInitSystem().

◆ IopLogListLock

KSPIN_LOCK IopLogListLock
extern

Definition at line 31 of file error.c.

Referenced by IoInitSystem(), IopGetErrorLogEntry(), IopLogWorker(), and IoWriteErrorLogEntry().

◆ IopMdlLookasideList

GENERAL_LOOKASIDE IopMdlLookasideList

Definition at line 85 of file iomgr.c.

Referenced by IopInitLookasideLists().

◆ IopNetworkFileSystemQueueHead

LIST_ENTRY IopNetworkFileSystemQueueHead
extern

Definition at line 21 of file volume.c.

Referenced by IoInitSystem(), IoRegisterFileSystem(), and IoRegisterFsRegistrationChange().

◆ IopNumTriageDumpDataBlocks

ULONG IopNumTriageDumpDataBlocks

Definition at line 47 of file iomgr.c.

◆ IopSecurityResource

ERESOURCE IopSecurityResource

◆ IopTapeFileSystemQueueHead

LIST_ENTRY IopTapeFileSystemQueueHead
extern

◆ IopTimer

KTIMER IopTimer
extern

Definition at line 23 of file iotimer.c.

Referenced by IoInitSystem().

◆ IopTimerDpc

KDPC IopTimerDpc
extern

Definition at line 22 of file iotimer.c.

Referenced by IoInitSystem().

◆ IopTimerLock

◆ IopTimerQueueHead

LIST_ENTRY IopTimerQueueHead
extern

Definition at line 19 of file iotimer.c.

Referenced by IoInitializeTimer(), IoInitSystem(), and IopTimerDispatch().

◆ IopTraceLevel

ULONG IopTraceLevel = 0

Definition at line 16 of file iomgr.c.

◆ IopTriageDumpDataBlocks

PVOID IopTriageDumpDataBlocks[64]

Definition at line 48 of file iomgr.c.

◆ IoReadOperationCount

ULONG IoReadOperationCount = 0

Definition at line 39 of file iomgr.c.

Referenced by IopUpdateOperationCount(), and QSI_DEF().

◆ IoReadTransferCount

LARGE_INTEGER IoReadTransferCount = {{0, 0}}

Definition at line 40 of file iomgr.c.

Referenced by IopUpdateTransferCount(), and QSI_DEF().

◆ IoSmallIrpLookaside

GENERAL_LOOKASIDE IoSmallIrpLookaside

Definition at line 84 of file iomgr.c.

Referenced by IopInitLookasideLists().

◆ IoStatisticsLock

KSPIN_LOCK IoStatisticsLock = 0

Definition at line 45 of file iomgr.c.

Referenced by IoInitSystem().

◆ IoWriteOperationCount

ULONG IoWriteOperationCount = 0

Definition at line 41 of file iomgr.c.

Referenced by IopUpdateOperationCount(), and QSI_DEF().

◆ IoWriteTransferCount

LARGE_INTEGER IoWriteTransferCount = {{0, 0}}

Definition at line 42 of file iomgr.c.

Referenced by IopUpdateTransferCount(), and QSI_DEF().

◆ LastChanceShutdownListHead

LIST_ENTRY LastChanceShutdownListHead
extern

◆ PnPBootDriversInitialized

BOOLEAN PnPBootDriversInitialized
extern

Definition at line 21 of file pnpinit.c.

Referenced by IoInitSystem().

◆ PnpSystemInit

BOOLEAN PnpSystemInit = FALSE

Definition at line 17 of file iomgr.c.

Referenced by IoInitSystem(), and IopInitializeDriverModule().

◆ ShutdownListHead

LIST_ENTRY ShutdownListHead
extern

◆ ShutdownListLock