248 lines
5.7 KiB
C
248 lines
5.7 KiB
C
|
/*++
|
|||
|
|
|||
|
Copyright (c) 1989 Microsoft Corporation
|
|||
|
|
|||
|
Module Name:
|
|||
|
|
|||
|
msinit.c
|
|||
|
|
|||
|
Abstract:
|
|||
|
|
|||
|
This module implements the DRIVER_INITIALIZATION routine for the
|
|||
|
mailslot file system.
|
|||
|
|
|||
|
Author:
|
|||
|
|
|||
|
Manny Weiser (mannyw) 7-Jan-91
|
|||
|
|
|||
|
Revision History:
|
|||
|
|
|||
|
Neill Clift (NeillC) 22-Jan-2000
|
|||
|
Major rework, Do raise exceptions, fix locking, fix cancel logic, fix validation and error handling.
|
|||
|
|
|||
|
--*/
|
|||
|
|
|||
|
#include "mailslot.h"
|
|||
|
#include "zwapi.h"
|
|||
|
|
|||
|
NTSTATUS
|
|||
|
DriverEntry(
|
|||
|
IN PDRIVER_OBJECT DriverObject,
|
|||
|
IN PUNICODE_STRING RegistryPath
|
|||
|
);
|
|||
|
|
|||
|
VOID
|
|||
|
MsfsUnload(
|
|||
|
IN PDRIVER_OBJECT DriverObject
|
|||
|
);
|
|||
|
|
|||
|
#ifdef ALLOC_PRAGMA
|
|||
|
#pragma alloc_text( INIT, DriverEntry )
|
|||
|
#pragma alloc_text( PAGE, MsfsUnload )
|
|||
|
#endif
|
|||
|
|
|||
|
PMSFS_DEVICE_OBJECT msfsDeviceObject = NULL;
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
NTSTATUS
|
|||
|
DriverEntry(
|
|||
|
IN PDRIVER_OBJECT DriverObject,
|
|||
|
IN PUNICODE_STRING RegistryPath
|
|||
|
)
|
|||
|
|
|||
|
/*++
|
|||
|
|
|||
|
Routine Description:
|
|||
|
|
|||
|
This is the initialization routine for the mailslot file system
|
|||
|
device driver. This routine creates the device object for the mailslot
|
|||
|
device and performs all other driver initialization.
|
|||
|
|
|||
|
Arguments:
|
|||
|
|
|||
|
DriverObject - Pointer to driver object created by the system.
|
|||
|
|
|||
|
Return Value:
|
|||
|
|
|||
|
NTSTATUS - The function value is the final status from the initialization
|
|||
|
operation.
|
|||
|
|
|||
|
--*/
|
|||
|
|
|||
|
{
|
|||
|
NTSTATUS status = STATUS_SUCCESS;
|
|||
|
UNICODE_STRING nameString;
|
|||
|
PDEVICE_OBJECT deviceObject;
|
|||
|
|
|||
|
PAGED_CODE();
|
|||
|
|
|||
|
//
|
|||
|
// Initialize MSFS global data.
|
|||
|
//
|
|||
|
|
|||
|
status = MsInitializeData();
|
|||
|
if (!NT_SUCCESS (status)) {
|
|||
|
return status;
|
|||
|
}
|
|||
|
|
|||
|
//
|
|||
|
// Set driver to be completely paged out.
|
|||
|
//
|
|||
|
MmPageEntireDriver(DriverEntry);
|
|||
|
|
|||
|
//
|
|||
|
// Create the MSFS device object.
|
|||
|
//
|
|||
|
|
|||
|
RtlInitUnicodeString( &nameString, L"\\Device\\Mailslot" );
|
|||
|
status = IoCreateDevice( DriverObject,
|
|||
|
sizeof(MSFS_DEVICE_OBJECT)-sizeof(DEVICE_OBJECT),
|
|||
|
&nameString,
|
|||
|
FILE_DEVICE_MAILSLOT,
|
|||
|
0,
|
|||
|
FALSE,
|
|||
|
&deviceObject );
|
|||
|
|
|||
|
if (!NT_SUCCESS( status )) {
|
|||
|
|
|||
|
MsUninitializeData();
|
|||
|
|
|||
|
return status;
|
|||
|
}
|
|||
|
|
|||
|
DriverObject->DriverUnload = MsfsUnload;
|
|||
|
//
|
|||
|
// Now because we use the irp stack for storing a data entry we need
|
|||
|
// to bump up the stack size in the device object we just created.
|
|||
|
//
|
|||
|
|
|||
|
deviceObject->StackSize += 1;
|
|||
|
|
|||
|
//
|
|||
|
// Note that because of the way data copying is done, we set neither
|
|||
|
// the Direct I/O or Buffered I/O bit in DeviceObject->Flags. If
|
|||
|
// data is not buffered we may set up for Direct I/O by hand.
|
|||
|
//
|
|||
|
|
|||
|
//
|
|||
|
// Initialize the driver object with this driver's entry points.
|
|||
|
//
|
|||
|
|
|||
|
DriverObject->MajorFunction[IRP_MJ_CREATE] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdCreate;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_CREATE_MAILSLOT] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdCreateMailslot;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_CLOSE] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdClose;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_READ] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdRead;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_WRITE] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdWrite;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_QUERY_INFORMATION] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdQueryInformation;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_SET_INFORMATION] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdSetInformation;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_QUERY_VOLUME_INFORMATION] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdQueryVolumeInformation;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_CLEANUP] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdCleanup;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_DIRECTORY_CONTROL] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdDirectoryControl;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_FILE_SYSTEM_CONTROL] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdFsControl;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_QUERY_SECURITY] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdQuerySecurityInfo;
|
|||
|
DriverObject->MajorFunction[IRP_MJ_SET_SECURITY] =
|
|||
|
(PDRIVER_DISPATCH)MsFsdSetSecurityInfo;
|
|||
|
|
|||
|
#ifdef _PNP_POWER_
|
|||
|
//
|
|||
|
// Mailslots should probably have a SetPower handler to ensure
|
|||
|
// that the driver is not powered down while a guarateed
|
|||
|
// mailslot delivery is in progress. For now, we'll just
|
|||
|
// ignore this and let the machine set power.
|
|||
|
//
|
|||
|
|
|||
|
deviceObject->DeviceObjectExtension->PowerControlNeeded = FALSE;
|
|||
|
#endif
|
|||
|
|
|||
|
|
|||
|
//
|
|||
|
// Initialize stuff
|
|||
|
//
|
|||
|
|
|||
|
msfsDeviceObject = (PMSFS_DEVICE_OBJECT)deviceObject;
|
|||
|
|
|||
|
//
|
|||
|
// Now initialize the Vcb, and create the root dcb
|
|||
|
//
|
|||
|
|
|||
|
MsInitializeVcb( &msfsDeviceObject->Vcb );
|
|||
|
|
|||
|
//
|
|||
|
// Createt the root DCB
|
|||
|
//
|
|||
|
if (MsCreateRootDcb( &msfsDeviceObject->Vcb ) == NULL) {
|
|||
|
|
|||
|
MsDereferenceVcb (&msfsDeviceObject->Vcb);
|
|||
|
IoDeleteDevice (&msfsDeviceObject->DeviceObject);
|
|||
|
MsUninitializeData();
|
|||
|
|
|||
|
return STATUS_INSUFFICIENT_RESOURCES;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//
|
|||
|
// Return to the caller.
|
|||
|
//
|
|||
|
|
|||
|
return( status );
|
|||
|
}
|
|||
|
|
|||
|
VOID
|
|||
|
MsfsUnload(
|
|||
|
IN PDRIVER_OBJECT DriverObject
|
|||
|
)
|
|||
|
/*++
|
|||
|
|
|||
|
Routine Description:
|
|||
|
|
|||
|
This routine cleans up all of the memory associated with
|
|||
|
the driver.
|
|||
|
|
|||
|
Arguments:
|
|||
|
|
|||
|
DriverObject - Supplies the driver object controlling the device.
|
|||
|
|
|||
|
Return Value:
|
|||
|
|
|||
|
None.
|
|||
|
|
|||
|
--*/
|
|||
|
{
|
|||
|
UNICODE_STRING us;
|
|||
|
//
|
|||
|
// Remove the initial reference to the VCB. This should be the last.
|
|||
|
//
|
|||
|
ASSERT ( msfsDeviceObject->Vcb.Header.ReferenceCount == 1 );
|
|||
|
|
|||
|
MsDereferenceVcb (&msfsDeviceObject->Vcb);
|
|||
|
|
|||
|
RtlInitUnicodeString (&us, L"\\??\\MAILSLOT"); // Created by SMSS
|
|||
|
IoDeleteSymbolicLink (&us);
|
|||
|
|
|||
|
//
|
|||
|
// Delete the device object
|
|||
|
//
|
|||
|
IoDeleteDevice (&msfsDeviceObject->DeviceObject);
|
|||
|
|
|||
|
//
|
|||
|
// Release the globals
|
|||
|
//
|
|||
|
MsUninitializeData();
|
|||
|
}
|