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) Microsoft Corporation, 2000
Module Name:
init.c
Abstract:
This file contains the initialization code for iSCSI port driver.
Environment:
kernel mode only
Revision History:
--*/ #include "port.h"
NTSTATUS DriverEntry( IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath );
#ifdef ALLOC_PRAGMA
#pragma alloc_text(INIT, DriverEntry)
#endif
PEPROCESS iScsiSystemProcess;
NTSTATUS DriverEntry( IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath ) /*+++
Routine Description:
Entry point for the driver. Arguements:
DriverObject - Pointer to the driver object created by the system. RegistryPath - Registry path for the driver Return Value :
STATUS_SUCCESS if initialization was successful Appropriate NTStatus code on failure --*/ { NTSTATUS status; PISCSIPORT_DRIVER_EXTENSION driverExtension = NULL;
DebugPrint((3, "iSCSI Port DriverEntry\n"));
status = IoAllocateDriverObjectExtension(DriverObject, (PVOID) ISCSI_TAG_DRIVER_EXTENSION, sizeof(ISCSIPORT_DRIVER_EXTENSION), &driverExtension); if (NT_SUCCESS(status)) { RtlZeroMemory(driverExtension, sizeof(ISCSIPORT_DRIVER_EXTENSION)); driverExtension->DriverObject = DriverObject; driverExtension->RegistryPath.Length = RegistryPath->Length; driverExtension->RegistryPath.MaximumLength = RegistryPath->MaximumLength; driverExtension->RegistryPath.Buffer = ExAllocatePoolWithTag(PagedPool, RegistryPath->MaximumLength, ISCSI_TAG_REGPATH); if (driverExtension->RegistryPath.Buffer == NULL) { return STATUS_NO_MEMORY; }
RtlCopyUnicodeString(&(driverExtension->RegistryPath), RegistryPath); } else if (status == STATUS_OBJECT_NAME_COLLISION) {
//
// Extension already exists. Get a pointer to it
//
driverExtension = IoGetDriverObjectExtension( DriverObject, (PVOID) ISCSI_TAG_DRIVER_EXTENSION); ASSERT(driverExtension != NULL); } else { DebugPrint((1, "iSCSI : Could not allocate driver extension %lx\n", status)); return status; }
//
// Update the driver object with the entry points
//
DriverObject->MajorFunction[IRP_MJ_SCSI] = iScsiPortGlobalDispatch; DriverObject->MajorFunction[IRP_MJ_CREATE] = iScsiPortGlobalDispatch; DriverObject->MajorFunction[IRP_MJ_CLOSE] = iScsiPortGlobalDispatch; DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = iScsiPortGlobalDispatch; DriverObject->MajorFunction[IRP_MJ_PNP] = iScsiPortGlobalDispatch; DriverObject->MajorFunction[IRP_MJ_POWER] = iScsiPortGlobalDispatch; DriverObject->MajorFunction[IRP_MJ_SYSTEM_CONTROL] = iScsiPortGlobalDispatch;
DriverObject->DriverUnload = iScsiPortUnload; DriverObject->DriverExtension->AddDevice = iScsiPortAddDevice;
iScsiSystemProcess = IoGetCurrentProcess ();
return STATUS_SUCCESS; }
|