35 #define TAG_RTLREGISTRY 'vrqR' 72 Irp->IoStatus.Information = 0;
117 if (
DriverObject->DriverExtension->ServiceKeyName.Buffer)
245 *DriverName = driverName;
264 if (
String2->Length < String1->Length)
267 Length = String1->Length / 2;
268 pc1 = String1->Buffer;
299 "%s%sSystem32\\Drivers\\%wZ%s\r\n",
339 DPRINT(
"Normalizing image path '%wZ' for service '%wZ'\n", ImagePath,
ServiceName);
341 InputImagePath = *ImagePath;
342 if (InputImagePath.
Length == 0)
345 ImagePath->MaximumLength = DriversPathString.
Length +
350 ImagePath->MaximumLength,
352 if (ImagePath->Buffer ==
NULL)
359 else if (InputImagePath.
Buffer[0] !=
L'\\')
361 ImagePath->Length = 0;
362 ImagePath->MaximumLength = SystemRootString.
Length +
366 ImagePath->MaximumLength,
368 if (ImagePath->Buffer ==
NULL)
378 DPRINT(
"Normalized image path is '%wZ' for service '%wZ'\n", ImagePath,
ServiceName);
421 DPRINT(
"Driver name: '%wZ'\n", &DriverName);
432 Status = ZwQueryKey(ServiceHandle,
484 (
PVOID*)&driverObject);
491 DPRINT1(
"Error while creating driver object \"%wZ\" status %x\n", &DriverName,
Status);
495 DPRINT(
"Created driver object 0x%p for \"%wZ\"\n", driverObject, &DriverName);
501 driverObject->DriverSection = ModuleObject;
502 driverObject->DriverStart = ModuleObject->DllBase;
503 driverObject->DriverSize = ModuleObject->SizeOfImage;
504 driverObject->DriverInit = ModuleObject->EntryPoint;
507 driverObject->DriverExtension->DriverObject = driverObject;
532 (
PVOID*)&driverObject,
548 serviceKeyName.
Length = 0;
554 if (!serviceKeyName.
Buffer)
567 driverObject->DriverExtension->ServiceKeyName = serviceKeyName;
571 driverNamePaged.
Length = 0;
577 if (!driverNamePaged.
Buffer)
587 driverObject->DriverName = driverNamePaged;
591 *DriverEntryStatus =
Status;
594 DPRINT1(
"'%wZ' initialization failed, status (0x%08lx)\n", &DriverName,
Status);
601 if (!driverObject->DeviceObject)
616 if (!driverObject->MajorFunction[
i])
619 DPRINT1(
"Driver <%wZ> set DriverObject->MajorFunction[%lu] to NULL!\n",
620 &driverObject->DriverName,
i);
640 *OutDriverObject = driverObject;
676 PVOID DriverBase = LdrEntry->DllBase;
700 BaseLength *=
sizeof(
WCHAR);
737 *ModuleObject = LdrEntry;
784 if (FileNameWithoutPath ==
NULL)
786 FileNameWithoutPath =
Buffer;
790 FileNameWithoutPath++;
804 if (FileExtension !=
NULL)
844 NextEntry = NextEntry->
Flink;
898 DPRINT(
"Processing %u instances for %wZ module\n", instanceCount,
ModuleName);
900 for (
UINT32 i = 0;
i < instanceCount;
i++)
970 DPRINT(
"IopInitializeBootDrivers()\n");
997 NextEntry = ListHead->
Flink;
998 while (ListHead != NextEntry)
1013 NextEntry = NextEntry->
Flink;
1018 NextEntry = ListHead->
Flink;
1019 while (ListHead != NextEntry)
1048 #else // Hack still needed... 1080 NextEntry2 = NextEntry2->
Flink;
1084 NextEntry2 = NextEntry2->
Blink;
1090 NextEntry = NextEntry->
Flink;
1119 NextEntry = NextEntry->
Flink;
1158 ZwLoadDriver(*DriverList);
1223 DPRINT1(
"No unload privilege!\n");
1236 DPRINT(
"IopUnloadDriver('%wZ', %u)\n", &CapturedServiceName, UnloadPnpDrivers);
1249 &CapturedServiceName,
1313 DPRINT1(
"Driver deletion pending\n");
1331 CapturedServiceName.
Buffer,
1341 DPRINT1(
"RtlQueryRegistryValues() failed (Status %x)\n",
Status);
1353 DPRINT1(
"IopNormalizeImagePath() failed (Status %x)\n",
Status);
1382 DPRINT1(
"Drivers device object is referenced or has attached devices\n");
1384 SafeToUnload =
FALSE;
1415 DPRINT1(
"No DriverUnload function! '%wZ' will not be unloaded!\n", &
DriverObject->DriverName);
1511 WCHAR NameBuffer[100];
1530 LocalDriverName.
Length = NameLength *
sizeof(
WCHAR);
1532 LocalDriverName.
Buffer = NameBuffer;
1537 LocalDriverName = *DriverName;
1580 if (!ServiceKeyName.
Buffer)
1591 DriverObject->DriverExtension->ServiceKeyName = ServiceKeyName;
1646 DPRINT(
"Calling driver entrypoint at %p\n", InitializationFunction);
1651 DPRINT1(
"'%wZ' initialization failed, status (0x%08lx)\n", DriverName,
Status);
1670 DPRINT1(
"Driver <%wZ> set DriverObject->MajorFunction[%lu] to NULL!\n",
1708 if (!ReinitItem)
return;
1737 if (!ReinitItem)
return;
1758 IN ULONG DriverObjectExtensionSize,
1766 *DriverObjectExtension =
NULL;
1771 DriverObjectExtensionSize,
1787 ClientDriverExtension;
1788 while (DriverExtensions)
1803 if (!DriverExtensions)
1825 *DriverObjectExtension = NewDriverExtension + 1;
1845 while (DriverExtensions)
1863 if (!DriverExtensions)
return NULL;
1864 return DriverExtensions + 1;
1912 DPRINT(
"IopNormalizeImagePath() failed (Status %x)\n",
Status);
1916 DPRINT(
"FullImagePath: '%wZ'\n", &ImagePath);
1924 DPRINT(
"Loading module from %wZ\n", &ImagePath);
1930 DPRINT(
"MmLoadSystemImage() failed (Status %lx)\n",
Status);
1944 Status = ZwQueryKey(ServiceHandle,
1954 .Buffer = servName->
Name 1967 &driverEntryStatus);
1970 DPRINT1(
"IopInitializeDriverModule() failed (Status %lx)\n",
Status);
2057 return LoadParams.
Status;
2090 DPRINT1(
"No load privilege!\n");
2103 DPRINT(
"NtLoadDriver('%wZ')\n", &CapturedServiceName);
static __inline NTSTATUS ProbeAndCaptureUnicodeString(OUT PUNICODE_STRING Dest, IN KPROCESSOR_MODE CurrentMode, IN const UNICODE_STRING *UnsafeSrc)
#define RTL_FIND_CHAR_IN_UNICODE_STRING_START_AT_END
#define STATUS_OBJECT_NAME_COLLISION
static const unsigned char pc2[48]
IN PUNICODE_STRING IN POBJECT_ATTRIBUTES ObjectAttributes
BOOLEAN ExpInTextModeSetup
#define DRVO_BUILTIN_DRIVER
_In_ PCWSTR _Inout_ _At_ QueryTable _Pre_unknown_ PRTL_QUERY_REGISTRY_TABLE QueryTable
#define STATUS_DELETE_PENDING
NTSTATUS NTAPI RawFsDriverEntry(IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath)
#define DRVO_LEGACY_DRIVER
#define STATUS_PRIVILEGE_NOT_HELD
VOID NTAPI MmFreeDriverInitialization(IN PLDR_DATA_TABLE_ENTRY LdrEntry)
VOID FASTCALL IopInitializeBootDrivers(VOID)
PDEVICE_OBJECT PhysicalDeviceObject
VOID NTAPI InbvIndicateProgress(VOID)
PDEVICE_NODE IopRootDeviceNode
VOID NTAPI ExQueueWorkItem(IN PWORK_QUEUE_ITEM WorkItem, IN WORK_QUEUE_TYPE QueueType)
IN OUT PLONG IN OUT PLONG Addend IN OUT PLONG IN LONG IN OUT PLONG IN LONG Increment KeRaiseIrqlToDpcLevel
struct _IO_CLIENT_EXTENSION * NextExtension
#define STATUS_INSUFFICIENT_RESOURCES
VOID FASTCALL IopInitializeSystemDrivers(VOID)
NTSTATUS RtlUpcaseUnicodeString(PUNICODE_STRING dst, PUNICODE_STRING src, BOOLEAN Alloc)
#define KeLowerIrql(oldIrql)
_In_ ULONG _In_ ULONG _In_ ULONG Length
static const unsigned char pc1[56]
PUNICODE_STRING *NTAPI CmGetSystemDriverList(VOID)
NTSYSAPI NTSTATUS WINAPI RtlQueryRegistryValues(ULONG, PCWSTR, PRTL_QUERY_REGISTRY_TABLE, PVOID, PVOID)
NTSTATUS NTAPI IoAllocateDriverObjectExtension(IN PDRIVER_OBJECT DriverObject, IN PVOID ClientIdentificationAddress, IN ULONG DriverObjectExtensionSize, OUT PVOID *DriverObjectExtension)
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.
static VOID NTAPI IopLoadUnloadDriverWorker(_Inout_ PVOID Parameter)
#define OBJ_CASE_INSENSITIVE
VOID NTAPI IopReinitializeDrivers(VOID)
_Must_inspect_result_ _Out_ PNDIS_STATUS _In_ NDIS_HANDLE _In_ ULONG _Out_ PNDIS_STRING _Out_ PNDIS_HANDLE KeyHandle
IN BOOLEAN OUT PSTR Buffer
#define STATUS_INVALID_PARAMETER
VOID FASTCALL IopDisplayLoadingMessage(PUNICODE_STRING ServiceName)
NTSYSAPI NTSTATUS NTAPI ZwClose(_In_ HANDLE Handle)
struct _LIST_ENTRY * Blink
FORCEINLINE VOID InsertHeadList(_Inout_ PLIST_ENTRY ListHead, _Inout_ __drv_aliasesMem PLIST_ENTRY Entry)
NTSTRSAFEVAPI RtlStringCchPrintfW(_Out_writes_(cchDest) _Always_(_Post_z_) NTSTRSAFE_PWSTR pszDest, _In_ size_t cchDest, _In_ _Printf_format_string_ NTSTRSAFE_PCWSTR pszFormat,...)
PLIST_ENTRY NTAPI ExInterlockedInsertTailList(IN OUT PLIST_ENTRY ListHead, IN OUT PLIST_ENTRY ListEntry, IN OUT PKSPIN_LOCK Lock)
#define KeGetPreviousMode()
#define IRP_MJ_MAXIMUM_FUNCTION
NTSTATUS IopDoLoadUnloadDriver(_In_opt_ PUNICODE_STRING RegistryPath, _Inout_ PDRIVER_OBJECT *DriverObject)
Process load and unload driver operations. This is mostly for NtLoadDriver and NtUnloadDriver,...
_Must_inspect_result_ _In_ PDRIVER_OBJECT _In_ PCUNICODE_STRING RegistryPath
#define STATUS_FAILED_DRIVER_ENTRY
LIST_ENTRY DriverBootReinitListHead
#define STATUS_INVALID_DEVICE_REQUEST
_In_ LPWSTR _In_ ULONG _In_ ULONG _In_ ULONG _Out_ DEVINFO _In_ HDEV _In_ LPWSTR _In_ HANDLE hDriver
BOOLEAN NTAPI SeSinglePrivilegeCheck(IN LUID PrivilegeValue, IN KPROCESSOR_MODE PreviousMode)
KPROCESSOR_MODE NTAPI ExGetPreviousMode(VOID)
#define FILESYSTEM_ROOT_NAME
NTSTATUS IopLoadDriver(_In_ HANDLE ServiceHandle, _Out_ PDRIVER_OBJECT *DriverObject)
POBJECT_TYPE IoDriverObjectType
ACPI_BUFFER *RetBuffer ACPI_BUFFER *RetBuffer char ACPI_WALK_RESOURCE_CALLBACK void *Context ACPI_BUFFER *RetBuffer UINT16 ACPI_RESOURCE **ResourcePtr ACPI_GENERIC_ADDRESS *Reg UINT32 *ReturnValue UINT8 UINT8 *Slp_TypB ACPI_PHYSICAL_ADDRESS PhysicalAddress64 UINT32 UINT32 *TimeElapsed UINT32 ACPI_STATUS const char UINT32 ACPI_STATUS const char UINT32 const char const char * ModuleName
_In_ PVOID _Out_opt_ PULONG_PTR _Outptr_opt_ PCUNICODE_STRING * ObjectName
VOID NTAPI IoDeleteDriver(IN PDRIVER_OBJECT DriverObject)
NTSTATUS IopGetDriverNames(_In_ HANDLE ServiceHandle, _Out_ PUNICODE_STRING DriverName, _Out_opt_ PUNICODE_STRING ServiceName)
#define LDRP_DRIVER_DEPENDENT_DLL
NTSTATUS NTAPI IopInvalidDeviceRequest(PDEVICE_OBJECT DeviceObject, PIRP Irp)
LONG NTAPI KeSetEvent(IN PKEVENT Event, IN KPRIORITY Increment, IN BOOLEAN Wait)
NTSTATUS NTAPI KeWaitForSingleObject(IN PVOID Object, IN KWAIT_REASON WaitReason, IN KPROCESSOR_MODE WaitMode, IN BOOLEAN Alertable, IN PLARGE_INTEGER Timeout OPTIONAL)
#define OBJ_KERNEL_HANDLE
VOID NTAPI IopReinitializeBootDrivers(VOID)
#define SERVICE_RECOGNIZER_DRIVER
static int Link(const char **args)
#define MAXIMUM_FILENAME_LENGTH
#define RtlMoveMemory(Destination, Source, Length)
NTSYSAPI VOID NTAPI RtlCopyUnicodeString(PUNICODE_STRING DestinationString, PUNICODE_STRING SourceString)
#define STATUS_BUFFER_TOO_SMALL
USHORT NTAPI PpInitGetGroupOrderIndex(IN HANDLE ServiceHandle)
#define DRVO_REINIT_REGISTERED
VOID NTAPI IoRegisterDriverReinitialization(IN PDRIVER_OBJECT DriverObject, IN PDRIVER_REINITIALIZE ReinitRoutine, IN PVOID Context)
NTSTATUS NTAPI RtlFindCharInUnicodeString(_In_ ULONG Flags, _In_ PCUNICODE_STRING SearchString, _In_ PCUNICODE_STRING MatchString, _Out_ PUSHORT Position)
BOOLEAN NTAPI ExAcquireResourceExclusiveLite(IN PERESOURCE Resource, IN BOOLEAN Wait)
GLenum GLuint GLenum GLsizei const GLchar * buf
_In_ PDEVICE_OBJECT DeviceObject
KSPIN_LOCK DriverReinitListLock
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)
KSPIN_LOCK DriverBootReinitListLock
NTSTATUS(* NTAPI)(IN PFILE_FULL_EA_INFORMATION EaBuffer, IN ULONG EaLength, OUT PULONG ErrorOffset)
struct _SETUP_LOADER_BLOCK * SetupLdrBlock
PEPROCESS PsInitialSystemProcess
NTSTATUS NTAPI MmCallDllInitialize(IN PLDR_DATA_TABLE_ENTRY LdrEntry, IN PLIST_ENTRY ListHead)
struct _LOAD_UNLOAD_PARAMS LOAD_UNLOAD_PARAMS
#define OBJ_NAME_PATH_SEPARATOR
PDRIVER_EXTENSION DriverExtension
#define PsGetCurrentProcess
PLIST_ENTRY NTAPI ExInterlockedRemoveHeadList(IN OUT PLIST_ENTRY ListHead, IN OUT PKSPIN_LOCK Lock)
PDEVICE_OBJECT IopGetDeviceObjectFromDeviceInstance(PUNICODE_STRING DeviceInstance)
NTSTATUS FASTCALL IopNormalizeImagePath(_Inout_ _When_(return >=0, _At_(ImagePath->Buffer, _Post_notnull_ __drv_allocatesMem(Mem))) PUNICODE_STRING ImagePath, _In_ PUNICODE_STRING ServiceName)
VOID(NTAPI * PDRIVER_REINITIALIZE)(_In_ struct _DRIVER_OBJECT *DriverObject, _In_opt_ PVOID Context, _In_ ULONG Count)
const LUID SeLoadDriverPrivilege
LIST_ENTRY DriverReinitListHead
#define IoCompleteRequest
NTSTATUS NTAPI IoCreateDriver(_In_opt_ PUNICODE_STRING DriverName, _In_ PDRIVER_INITIALIZE InitializationFunction)
PDRIVER_OBJECT DriverObject
#define SERVICE_FILE_SYSTEM_DRIVER
PLOADER_PARAMETER_BLOCK KeLoaderBlock
__drv_aliasesMem _In_ PVOID ClientIdentificationAddress
PFLT_MESSAGE_WAITER_QUEUE CONTAINING_RECORD(Csq, DEVICE_EXTENSION, IrpQueue)) -> WaiterQ.mLock) _IRQL_raises_(DISPATCH_LEVEL) VOID NTAPI FltpAcquireMessageWaiterLock(_In_ PIO_CSQ Csq, _Out_ PKIRQL Irql)
KEVENT PiEnumerationFinished
_Must_inspect_result_ _In_ PDRIVER_OBJECT DriverObject
#define DRVO_UNLOAD_INVOKED
NTSTATUS NTAPI ObCreateObject(IN KPROCESSOR_MODE ProbeMode OPTIONAL, IN POBJECT_TYPE Type, IN POBJECT_ATTRIBUTES ObjectAttributes OPTIONAL, IN KPROCESSOR_MODE AccessMode, IN OUT PVOID ParseContext OPTIONAL, IN ULONG ObjectSize, IN ULONG PagedPoolCharge OPTIONAL, IN ULONG NonPagedPoolCharge OPTIONAL, OUT PVOID *Object)
NTSTATUS NTAPI MmUnloadSystemImage(IN PVOID ImageHandle)
#define STATUS_ILL_FORMED_SERVICE_ENTRY
NTSTATUS RtlAppendUnicodeToString(IN PUNICODE_STRING Str1, IN PWSTR Str2)
struct _LIST_ENTRY * Flink
static __inline VOID ReleaseCapturedUnicodeString(IN PUNICODE_STRING CapturedString, IN KPROCESSOR_MODE CurrentMode)
_In_ KPROCESSOR_MODE PreviousMode
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize PVOID * BaseAddress
#define __drv_allocatesMem(kind)
#define ExInitializeWorkItem(Item, Routine, Context)
#define DOE_UNLOAD_PENDING
#define TAG_DRIVER_EXTENSION
#define NT_SUCCESS(StatCode)
_In_ WDFCOLLECTION _In_ ULONG Index
LIST_ENTRY PsLoadedModuleList
PLIST_ENTRY DriverReinitTailEntry
NTSTATUS NTAPI MiResolveImageReferences(IN PVOID ImageBase, IN PUNICODE_STRING ImageFileDirectory, IN PUNICODE_STRING NamePrefix OPTIONAL, OUT PCHAR *MissingApi, OUT PWCHAR *MissingDriver, OUT PLOAD_IMPORTS *LoadImports)
#define ObDereferenceObject
PLIST_ENTRY IopGroupTable
LIST_ENTRY BootDriverListHead
NTSYSAPI VOID NTAPI RtlFreeUnicodeString(PUNICODE_STRING UnicodeString)
VOID FASTCALL ExReleaseResourceLite(IN PERESOURCE Resource)
BOOLEAN IopInitializeBuiltinDriver(IN PLDR_DATA_TABLE_ENTRY BootLdrEntry)
VOID NTAPI IopReadyDeviceObjects(IN PDRIVER_OBJECT Driver)
VOID NTAPI IoRegisterBootDriverReinitialization(IN PDRIVER_OBJECT DriverObject, IN PDRIVER_REINITIALIZE ReinitRoutine, IN PVOID Context)
#define STATUS_UNSUCCESSFUL
#define ExAllocatePoolWithTag(hernya, size, tag)
NTSYSAPI BOOLEAN NTAPI RtlCreateUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
DRIVER_INITIALIZE * PDRIVER_INITIALIZE
NTSTATUS NTAPI NtUnloadDriver(IN PUNICODE_STRING DriverServiceName)
NTKERNELAPI volatile KSYSTEM_TIME KeTickCount
_Requires_lock_held_ Interrupt _Releases_lock_ Interrupt _In_ _IRQL_restores_ KIRQL OldIrql
PDRIVER_UNLOAD DriverUnload
PVOID NTAPI IoGetDriverObjectExtension(IN PDRIVER_OBJECT DriverObject, IN PVOID ClientIdentificationAddress)
#define KeEnterCriticalRegion()
_In_ PNDIS_STRING DeviceInstance
struct _DRIVER_OBJECT DRIVER_OBJECT
static const WCHAR Cleanup[]
#define RTL_REGISTRY_ABSOLUTE
static const WCHAR Backslash[]
PPCI_DRIVER_EXTENSION DriverExtension
PLIST_ENTRY DriverBootReinitTailEntry
LIST_ENTRY LoadOrderListHead
NTSTATUS PiPerformSyncDeviceAction(_In_ PDEVICE_OBJECT DeviceObject, _In_ DEVICE_ACTION Action)
Perfom a device operation synchronously via PiQueueDeviceAction.
PDRIVER_OBJECT DriverObject
NTSTATUS NTAPI IopGetRegistryValue(IN HANDLE Handle, IN PWSTR ValueName, OUT PKEY_VALUE_FULL_INFORMATION *Information)
struct _FileName FileName
ERESOURCE IopDriverLoadResource
NTSTATUS NTAPI ObInsertObject(IN PVOID Object, IN PACCESS_STATE AccessState OPTIONAL, IN ACCESS_MASK DesiredAccess, IN ULONG ObjectPointerBias, OUT PVOID *NewObject OPTIONAL, OUT PHANDLE Handle)
UNICODE_STRING RegistryPath
DRIVER_INFORMATION DriverInfo
#define KeLeaveCriticalRegion()
PUNICODE_STRING RegistryPath
#define KeInitializeEvent(pEvt, foo, foo2)
NTSTATUS NTAPI IopOpenRegistryKeyEx(PHANDLE KeyHandle, HANDLE ParentKey, PUNICODE_STRING Name, ACCESS_MASK DesiredAccess)
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
struct _LDR_DATA_TABLE_ENTRY * LdrEntry
VOID NTAPI IopDeleteDriver(IN PVOID ObjectBody)
struct _DRIVER_EXTENSION * PDRIVER_EXTENSION
#define InitializeListHead(ListHead)
UNICODE_STRING IopHardwareDatabaseKey
NTSYSAPI NTSTATUS NTAPI RtlAppendUnicodeStringToString(PUNICODE_STRING Destination, PUNICODE_STRING Source)
UNICODE_STRING BaseDllName
struct _LOAD_UNLOAD_PARAMS * PLOAD_UNLOAD_PARAMS
NTHALAPI VOID NTAPI HalDisplayString(PUCHAR String)
_In_ const STRING * String2
NTSTATUS IopInitializeDriverModule(_In_ PLDR_DATA_TABLE_ENTRY ModuleObject, _In_ HANDLE ServiceHandle, _Out_ PDRIVER_OBJECT *OutDriverObject, _Out_ NTSTATUS *DriverEntryStatus)
Initialize a loaded driver.
char TextBuffer[BUFFERLEN]
struct tagContext Context
BOOLEAN PnPBootDriversLoaded
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
#define RtlZeroMemory(Destination, Length)
#define InitializeObjectAttributes(p, n, a, r, s)
#define RtlCopyMemory(Destination, Source, Length)
PDRIVER_REINITIALIZE ReinitRoutine
static const WCHAR ServicesKeyName[]
#define ExFreePoolWithTag(_P, _T)
PVOID ClientIdentificationAddress
NTSTATUS NTAPI IopUnloadDriver(PUNICODE_STRING DriverServiceName, BOOLEAN UnloadPnpDrivers)
#define IoGetDevObjExtension(DeviceObject)
#define IoGetDrvObjExtension(DriverObject)
NTSTATUS NTAPI ObReferenceObjectByName(IN PUNICODE_STRING ObjectPath, IN ULONG Attributes, IN PACCESS_STATE PassedAccessState, IN ACCESS_MASK DesiredAccess, IN POBJECT_TYPE ObjectType, IN KPROCESSOR_MODE AccessMode, IN OUT PVOID ParseContext, OUT PVOID *ObjectPtr)
static SERVICE_STATUS status
NTSTATUS NTAPI NtLoadDriver(IN PUNICODE_STRING DriverServiceName)
NTSYSAPI BOOLEAN NTAPI RtlEqualUnicodeString(PUNICODE_STRING String1, PUNICODE_STRING String2, BOOLEAN CaseInSensitive)
size_t __cdecl wcslen(_In_z_ const wchar_t *_Str)
base of all file and directory entries
PDRIVER_INITIALIZE DriverInit
#define RTL_QUERY_REGISTRY_DIRECT
NTSTATUS NTAPI MmLoadSystemImage(IN PUNICODE_STRING FileName, IN PUNICODE_STRING NamePrefix OPTIONAL, IN PUNICODE_STRING LoadedName OPTIONAL, IN ULONG Flags, OUT PVOID *ModuleObject, OUT PVOID *ImageBaseAddress)
#define DRVO_BOOTREINIT_REGISTERED
USHORT NTAPI PipGetDriverTagPriority(IN HANDLE ServiceHandle)
#define RTL_CONSTANT_STRING(s)
VOID NTAPI ObMakeTemporaryObject(IN PVOID ObjectBody)
NTSTATUS NTAPI LdrProcessDriverModule(PLDR_DATA_TABLE_ENTRY LdrEntry, PUNICODE_STRING FileName, PLDR_DATA_TABLE_ENTRY *ModuleObject)
PULONG MinorVersion OPTIONAL
BOOLEAN NTAPI IopSuffixUnicodeString(IN PCUNICODE_STRING String1, IN PCUNICODE_STRING String2)