cleanup NtDeviceIoControlFile a bit...remove some redundant stuff

svn path=/trunk/; revision=15235
This commit is contained in:
Alex Ionescu 2005-05-12 04:17:43 +00:00
parent 942e1f4649
commit 32962bc31c

View file

@ -1104,8 +1104,9 @@ IoValidateDeviceIoControlAccess(IN PIRP Irp,
/* /*
* @implemented * @implemented
*/ */
NTSTATUS STDCALL NTSTATUS
NtDeviceIoControlFile (IN HANDLE DeviceHandle, STDCALL
NtDeviceIoControlFile(IN HANDLE DeviceHandle,
IN HANDLE Event OPTIONAL, IN HANDLE Event OPTIONAL,
IN PIO_APC_ROUTINE UserApcRoutine OPTIONAL, IN PIO_APC_ROUTINE UserApcRoutine OPTIONAL,
IN PVOID UserApcContext OPTIONAL, IN PVOID UserApcContext OPTIONAL,
@ -1116,13 +1117,14 @@ NtDeviceIoControlFile (IN HANDLE DeviceHandle,
OUT PVOID OutputBuffer, OUT PVOID OutputBuffer,
IN ULONG OutputBufferLength OPTIONAL) IN ULONG OutputBufferLength OPTIONAL)
{ {
NTSTATUS Status; NTSTATUS Status = STATUS_SUCCESS;
PFILE_OBJECT FileObject; PFILE_OBJECT FileObject;
PDEVICE_OBJECT DeviceObject; PDEVICE_OBJECT DeviceObject;
PIRP Irp; PIRP Irp;
PIO_STACK_LOCATION StackPtr; PIO_STACK_LOCATION StackPtr;
PKEVENT EventObject; PKEVENT EventObject = NULL;
KPROCESSOR_MODE PreviousMode; BOOLEAN LocalEvent;
KPROCESSOR_MODE PreviousMode = ExGetPreviousMode();
DPRINT("NtDeviceIoControlFile(DeviceHandle %x Event %x UserApcRoutine %x " DPRINT("NtDeviceIoControlFile(DeviceHandle %x Event %x UserApcRoutine %x "
"UserApcContext %x IoStatusBlock %x IoControlCode %x " "UserApcContext %x IoStatusBlock %x IoControlCode %x "
@ -1132,27 +1134,23 @@ NtDeviceIoControlFile (IN HANDLE DeviceHandle,
IoControlCode,InputBuffer,InputBufferLength,OutputBuffer, IoControlCode,InputBuffer,InputBufferLength,OutputBuffer,
OutputBufferLength); OutputBufferLength);
if (IoStatusBlock == NULL) if (IoStatusBlock == NULL) return STATUS_ACCESS_VIOLATION;
return STATUS_ACCESS_VIOLATION;
PreviousMode = ExGetPreviousMode();
/* Check granted access against the access rights from IoContolCode */ /* Check granted access against the access rights from IoContolCode */
Status = ObReferenceObjectByHandle (DeviceHandle, Status = ObReferenceObjectByHandle(DeviceHandle,
(IoControlCode >> 14) & 0x3, (IoControlCode >> 14) & 0x3,
IoFileObjectType, IoFileObjectType,
PreviousMode, PreviousMode,
(PVOID *) &FileObject, (PVOID *) &FileObject,
NULL); NULL);
if (!NT_SUCCESS(Status)) if (!NT_SUCCESS(Status)) return Status;
{
return Status;
}
if (Event != NULL) /* Check for an event */
if (Event)
{ {
Status = ObReferenceObjectByHandle (Event, /* Reference it */
SYNCHRONIZE, Status = ObReferenceObjectByHandle(Event,
EVENT_MODIFY_STATE,
ExEventObjectType, ExEventObjectType,
PreviousMode, PreviousMode,
(PVOID*)&EventObject, (PVOID*)&EventObject,
@ -1162,16 +1160,35 @@ NtDeviceIoControlFile (IN HANDLE DeviceHandle,
ObDereferenceObject (FileObject); ObDereferenceObject (FileObject);
return Status; return Status;
} }
/* Clear it */
KeClearEvent(EventObject);
}
/* Check if this is a direct open or not */
if (FileObject->Flags & FO_DIRECT_DEVICE_OPEN)
{
DeviceObject = IoGetAttachedDevice(FileObject->DeviceObject);
} }
else else
{ {
EventObject = &FileObject->Event; DeviceObject = IoGetRelatedDeviceObject(FileObject);
KeResetEvent (EventObject);
} }
DeviceObject = FileObject->DeviceObject; /* Check if we should use Sync IO or not */
if (FileObject->Flags & FO_SYNCHRONOUS_IO)
{
/* Use File Object event */
KeClearEvent(&FileObject->Event);
}
else
{
/* Use local event */
LocalEvent = TRUE;
}
Irp = IoBuildDeviceIoControlRequest (IoControlCode, /* Build the IRP */
Irp = IoBuildDeviceIoControlRequest(IoControlCode,
DeviceObject, DeviceObject,
InputBuffer, InputBuffer,
InputBufferLength, InputBufferLength,
@ -1181,36 +1198,28 @@ NtDeviceIoControlFile (IN HANDLE DeviceHandle,
EventObject, EventObject,
IoStatusBlock); IoStatusBlock);
/* Trigger FileObject/Event dereferencing */ /* Set some extra settings */
Irp->Tail.Overlay.OriginalFileObject = FileObject; Irp->Tail.Overlay.OriginalFileObject = FileObject;
Irp->RequestorMode = PreviousMode; Irp->RequestorMode = PreviousMode;
Irp->Overlay.AsynchronousParameters.UserApcRoutine = UserApcRoutine;
Irp->Overlay.AsynchronousParameters.UserApcContext = UserApcContext;
StackPtr = IoGetNextIrpStackLocation(Irp); StackPtr = IoGetNextIrpStackLocation(Irp);
StackPtr->FileObject = FileObject; StackPtr->FileObject = FileObject;
StackPtr->DeviceObject = DeviceObject;
StackPtr->Parameters.DeviceIoControl.InputBufferLength = InputBufferLength;
StackPtr->Parameters.DeviceIoControl.OutputBufferLength = OutputBufferLength;
Status = IoCallDriver(DeviceObject,Irp); /* Call the Driver */
if (Status == STATUS_PENDING && (FileObject->Flags & FO_SYNCHRONOUS_IO)) Status = IoCallDriver(DeviceObject, Irp);
if (Status == STATUS_PENDING)
{ {
Status = KeWaitForSingleObject (EventObject, if (!LocalEvent)
{
KeWaitForSingleObject(&FileObject->Event,
Executive, Executive,
PreviousMode, PreviousMode,
FileObject->Flags & FO_ALERTABLE_IO, FileObject->Flags & FO_ALERTABLE_IO,
NULL); NULL);
if (Status != STATUS_WAIT_0) Status = FileObject->FinalStatus;
{ }
/* Wait failed. */
return Status;
}
Status = IoStatusBlock->Status;
} }
/* Return the Status */
return Status; return Status;
} }