Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/*++
Copyright (c) 1995 Microsoft Corporation
Module Name:
initunlo.c
Abstract:
This module contains the code that is very specific to initialization and unload operations in the irenum driver
Author:
Brian Lieuallen, 7-13-2000
Environment:
Kernel mode
Revision History :
--*/
#include "internal.h"
ULONG DebugFlags; ULONG DebugMemoryTag='oCrI'; PVOID PagedCodeSectionHandle; UNICODE_STRING DriverEntryRegPath;
NTSTATUS DriverEntry( IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath );
VOID IrCommUnload( IN PDRIVER_OBJECT DriverObject );
NTSTATUS UnHandledDispatch( PDEVICE_OBJECT DeviceObject, PIRP Irp );
#pragma alloc_text(INIT,DriverEntry)
#pragma alloc_text(PAGE,IrCommUnload)
NTSTATUS DriverEntry( IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath )
/*++
Routine Description:
The entry point that the system point calls to initialize any driver.
Arguments:
DriverObject - Just what it says, really of little use to the driver itself, it is something that the IO system cares more about.
PathToRegistry - points to the entry for this driver in the current control set of the registry.
Return Value:
STATUS_SUCCESS if we could initialize a single device, otherwise STATUS_NO_SUCH_DEVICE.
--*/
{ //
// We use this to query into the registry as to whether we
// should break at driver entry.
//
RTL_QUERY_REGISTRY_TABLE paramTable[4]; ULONG zero = 0; ULONG debugLevel = 0; ULONG debugFlags = 0; ULONG shouldBreak = 0;
D_PNP(DbgPrint("IRCOMM: DriverEntry\n");)
DriverEntryRegPath.Length=RegistryPath->Length; DriverEntryRegPath.MaximumLength=DriverEntryRegPath.Length+sizeof(WCHAR);
DriverEntryRegPath.Buffer=ALLOCATE_PAGED_POOL(DriverEntryRegPath.MaximumLength);
if (DriverEntryRegPath.Buffer == NULL) {
return STATUS_INSUFFICIENT_RESOURCES; }
RtlCopyMemory( DriverEntryRegPath.Buffer, RegistryPath->Buffer, RegistryPath->Length );
//
// NULL terminate the string
//
DriverEntryRegPath.Buffer[RegistryPath->Length/sizeof(WCHAR)]=L'\0';
//
// Since the registry path parameter is a "counted" UNICODE string, it
// might not be zero terminated. For a very short time allocate memory
// to hold the registry path zero terminated so that we can use it to
// delve into the registry.
//
RtlZeroMemory( ¶mTable[0], sizeof(paramTable) );
paramTable[0].Flags = RTL_QUERY_REGISTRY_DIRECT; paramTable[0].Name = L"BreakOnEntry"; paramTable[0].EntryContext = &shouldBreak; paramTable[0].DefaultType = REG_DWORD; paramTable[0].DefaultData = &zero; paramTable[0].DefaultLength = sizeof(ULONG);
paramTable[1].Flags = RTL_QUERY_REGISTRY_DIRECT; paramTable[1].Name = L"DebugFlags"; paramTable[1].EntryContext = &debugFlags; paramTable[1].DefaultType = REG_DWORD; paramTable[1].DefaultData = &zero; paramTable[1].DefaultLength = sizeof(ULONG);
if (!NT_SUCCESS(RtlQueryRegistryValues( RTL_REGISTRY_ABSOLUTE | RTL_REGISTRY_OPTIONAL, DriverEntryRegPath.Buffer, ¶mTable[0], NULL, NULL ))) {
shouldBreak = 0;
}
#if DBG
DebugFlags=debugFlags; #endif
if (shouldBreak) {
DbgBreakPoint();
} //
// pnp driver entry point
//
DriverObject->DriverExtension->AddDevice = IrCommAddDevice;
//
// Initialize the Driver Object with driver's entry points
//
DriverObject->DriverUnload = IrCommUnload; #if DBG
{ ULONG i;
for (i=0; i <= IRP_MJ_MAXIMUM_FUNCTION; i++) {
DriverObject->MajorFunction[i]=UnHandledDispatch; } } #endif
DriverObject->MajorFunction[IRP_MJ_PNP] = IrCommPnP;
DriverObject->MajorFunction[IRP_MJ_POWER] = IrCommPower;
DriverObject->MajorFunction[IRP_MJ_SYSTEM_CONTROL] = IrCommWmi;
DriverObject->MajorFunction[IRP_MJ_CREATE] = IrCommCreate;
DriverObject->MajorFunction[IRP_MJ_CLOSE] = IrCommClose;
DriverObject->MajorFunction[IRP_MJ_WRITE] = IrCommWrite;
DriverObject->MajorFunction[IRP_MJ_READ] = IrCommRead;
DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = IrCommDeviceControl;
DriverObject->MajorFunction[IRP_MJ_CLEANUP] = IrCommCleanup;
DriverObject->MajorFunction[IRP_MJ_QUERY_INFORMATION] = IrCommQueryInformation; DriverObject->MajorFunction[IRP_MJ_SET_INFORMATION] = IrCommQueryInformation; //
// lock and unlock here so we can get a handle to the section
// so future calls will be faster
//
PagedCodeSectionHandle=MmLockPagableCodeSection(IrCommUnload); MmUnlockPagableImageSection(PagedCodeSectionHandle);
return STATUS_SUCCESS;
} #if DBG
NTSTATUS UnHandledDispatch( PDEVICE_OBJECT DeviceObject, PIRP Irp )
{
NTSTATUS Status=STATUS_NOT_SUPPORTED; PIO_STACK_LOCATION IrpSp=IoGetCurrentIrpStackLocation(Irp);
D_ERROR(DbgPrint("IRCOMM: Unhandled irp mj %x\n",IrpSp->MajorFunction);)
Irp->IoStatus.Status=Status; Irp->IoStatus.Information=0;
IoCompleteRequest(Irp, IO_NO_INCREMENT);
return Status; } #endif
VOID IrCommUnload( IN PDRIVER_OBJECT DriverObject ) {
D_PNP(DbgPrint("IRCOMM: UnLoad\n");)
FREE_POOL(DriverEntryRegPath.Buffer);
return;
}
|