IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/*
|
2006-06-29 23:52:45 +00:00
|
|
|
* PROJECT: ReactOS Kernel
|
|
|
|
* LICENSE: GPL - See COPYING in the top level directory
|
2008-08-23 16:30:14 +00:00
|
|
|
* FILE: ntoskrnl/io/iomgr/irp.c
|
2006-06-29 23:52:45 +00:00
|
|
|
* PURPOSE: IRP Handling Functions
|
|
|
|
* PROGRAMMERS: Alex Ionescu (alex.ionescu@reactos.org)
|
|
|
|
* Gunnar Dalsnes
|
|
|
|
* Filip Navara (navaraf@reactos.org)
|
2018-02-24 13:50:23 +00:00
|
|
|
* Pierre Schweitzer (pierre@reactos.org)
|
1999-01-13 03:00:06 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES ****************************************************************/
|
|
|
|
|
2004-08-15 16:39:12 +00:00
|
|
|
#include <ntoskrnl.h>
|
1999-01-13 03:00:06 +00:00
|
|
|
#define NDEBUG
|
2008-08-30 16:31:06 +00:00
|
|
|
#include <debug.h>
|
1999-01-13 03:00:06 +00:00
|
|
|
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
PIRP IopDeadIrp;
|
2018-02-24 13:50:23 +00:00
|
|
|
RESERVE_IRP_ALLOCATOR IopReserveIrpAllocator;
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* PRIVATE FUNCTIONS ********************************************************/
|
|
|
|
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
|
|
|
IopFreeIrpKernelApc(IN PKAPC Apc,
|
|
|
|
IN PKNORMAL_ROUTINE *NormalRoutine,
|
|
|
|
IN PVOID *NormalContext,
|
|
|
|
IN PVOID *SystemArgument1,
|
|
|
|
IN PVOID *SystemArgument2)
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
|
|
|
/* Free the IRP */
|
|
|
|
IoFreeIrp(CONTAINING_RECORD(Apc, IRP, Tail.Apc));
|
|
|
|
}
|
|
|
|
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
|
|
|
IopAbortIrpKernelApc(IN PKAPC Apc)
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
|
|
|
/* Free the IRP */
|
|
|
|
IoFreeIrp(CONTAINING_RECORD(Apc, IRP, Tail.Apc));
|
|
|
|
}
|
|
|
|
|
2006-07-04 22:28:23 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
IopCleanupFailedIrp(IN PFILE_OBJECT FileObject,
|
2006-07-29 16:56:26 +00:00
|
|
|
IN PKEVENT EventObject OPTIONAL,
|
|
|
|
IN PVOID Buffer OPTIONAL)
|
2006-07-04 22:28:23 +00:00
|
|
|
{
|
|
|
|
PAGED_CODE();
|
|
|
|
|
|
|
|
/* Dereference the event */
|
|
|
|
if (EventObject) ObDereferenceObject(EventObject);
|
|
|
|
|
2006-07-29 16:56:26 +00:00
|
|
|
/* Free a buffer, if any */
|
|
|
|
if (Buffer) ExFreePool(Buffer);
|
|
|
|
|
2006-07-04 22:28:23 +00:00
|
|
|
/* If this was a file opened for synch I/O, then unlock it */
|
|
|
|
if (FileObject->Flags & FO_SYNCHRONOUS_IO) IopUnlockFileObject(FileObject);
|
|
|
|
|
|
|
|
/* Now dereference it and return */
|
|
|
|
ObDereferenceObject(FileObject);
|
|
|
|
return STATUS_INSUFFICIENT_RESOURCES;
|
|
|
|
}
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
IopAbortInterruptedIrp(IN PKEVENT EventObject,
|
|
|
|
IN PIRP Irp)
|
|
|
|
{
|
|
|
|
KIRQL OldIrql;
|
|
|
|
BOOLEAN CancelResult;
|
|
|
|
LARGE_INTEGER Wait;
|
|
|
|
PAGED_CODE();
|
|
|
|
|
|
|
|
/* Raise IRQL to APC */
|
|
|
|
KeRaiseIrql(APC_LEVEL, &OldIrql);
|
|
|
|
|
|
|
|
/* Check if nobody completed it yet */
|
|
|
|
if (!KeReadStateEvent(EventObject))
|
|
|
|
{
|
|
|
|
/* First, cancel it */
|
|
|
|
CancelResult = IoCancelIrp(Irp);
|
|
|
|
KeLowerIrql(OldIrql);
|
|
|
|
|
|
|
|
/* Check if we cancelled it */
|
|
|
|
if (CancelResult)
|
|
|
|
{
|
|
|
|
/* Wait for the IRP to be cancelled */
|
|
|
|
Wait.QuadPart = -100000;
|
|
|
|
while (!KeReadStateEvent(EventObject))
|
|
|
|
{
|
|
|
|
/* Delay indefintely */
|
|
|
|
KeDelayExecutionThread(KernelMode, FALSE, &Wait);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* No cancellation done, so wait for the I/O system to kill it */
|
|
|
|
KeWaitForSingleObject(EventObject,
|
|
|
|
Executive,
|
|
|
|
KernelMode,
|
|
|
|
FALSE,
|
|
|
|
NULL);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* We got preempted, so give up */
|
|
|
|
KeLowerIrql(OldIrql);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
IopDisassociateThreadIrp(VOID)
|
2005-06-04 21:07:00 +00:00
|
|
|
{
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
KIRQL OldIrql, LockIrql;
|
2005-06-04 21:07:00 +00:00
|
|
|
PETHREAD IrpThread;
|
|
|
|
PLIST_ENTRY IrpEntry;
|
|
|
|
PIO_ERROR_LOG_PACKET ErrorLogEntry;
|
2006-06-29 23:52:45 +00:00
|
|
|
PDEVICE_OBJECT DeviceObject = NULL;
|
|
|
|
PIO_STACK_LOCATION IoStackLocation;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* First, raise to APC to protect IrpList */
|
|
|
|
KeRaiseIrql(APC_LEVEL, &OldIrql);
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Get the Thread and check the list */
|
|
|
|
IrpThread = PsGetCurrentThread();
|
|
|
|
if (IsListEmpty(&IrpThread->IrpList))
|
|
|
|
{
|
|
|
|
/* It got completed now, so quit */
|
|
|
|
KeLowerIrql(OldIrql);
|
|
|
|
return;
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
/* Ensure no one will come disturb */
|
|
|
|
LockIrql = KeAcquireQueuedSpinLock(LockQueueIoCompletionLock);
|
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Get the misbehaving IRP */
|
|
|
|
IrpEntry = IrpThread->IrpList.Flink;
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
IopDeadIrp = CONTAINING_RECORD(IrpEntry, IRP, ThreadListEntry);
|
2006-06-29 23:52:45 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Deassociating IRP %p for %p\n",
|
|
|
|
__FUNCTION__,
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
IopDeadIrp,
|
2006-06-29 23:52:45 +00:00
|
|
|
IrpThread);
|
|
|
|
|
|
|
|
/* Don't cancel the IRP if it's already been completed far */
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
if (IopDeadIrp->CurrentLocation == (IopDeadIrp->StackCount + 2))
|
2006-06-29 23:52:45 +00:00
|
|
|
{
|
|
|
|
/* Return */
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
KeReleaseQueuedSpinLock(LockQueueIoCompletionLock, LockIrql);
|
2006-06-29 23:52:45 +00:00
|
|
|
KeLowerIrql(OldIrql);
|
|
|
|
return;
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Disown the IRP! */
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
IopDeadIrp->Tail.Overlay.Thread = NULL;
|
2005-06-04 21:07:00 +00:00
|
|
|
RemoveHeadList(&IrpThread->IrpList);
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
InitializeListHead(&IopDeadIrp->ThreadListEntry);
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2006-06-29 23:52:45 +00:00
|
|
|
/* Get the stack location and check if it's valid */
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
IoStackLocation = IoGetCurrentIrpStackLocation(IopDeadIrp);
|
|
|
|
if (IopDeadIrp->CurrentLocation <= IopDeadIrp->StackCount)
|
2006-06-29 23:52:45 +00:00
|
|
|
{
|
|
|
|
/* Get the device object */
|
|
|
|
DeviceObject = IoStackLocation->DeviceObject;
|
|
|
|
}
|
|
|
|
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
KeReleaseQueuedSpinLock(LockQueueIoCompletionLock, LockIrql);
|
2006-06-29 23:52:45 +00:00
|
|
|
/* Lower IRQL now, since we have the pointers we need */
|
2005-06-04 21:07:00 +00:00
|
|
|
KeLowerIrql(OldIrql);
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Check if we can send an Error Log Entry*/
|
2006-06-29 23:52:45 +00:00
|
|
|
if (DeviceObject)
|
2005-06-04 21:07:00 +00:00
|
|
|
{
|
|
|
|
/* Allocate an entry */
|
2006-06-29 23:52:45 +00:00
|
|
|
ErrorLogEntry = IoAllocateErrorLogEntry(DeviceObject,
|
|
|
|
sizeof(IO_ERROR_LOG_PACKET));
|
|
|
|
if (ErrorLogEntry)
|
|
|
|
{
|
|
|
|
/* Write the entry */
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
ErrorLogEntry->ErrorCode = IO_DRIVER_CANCEL_TIMEOUT;
|
2006-06-29 23:52:45 +00:00
|
|
|
IoWriteErrorLogEntry(ErrorLogEntry);
|
|
|
|
}
|
2005-06-04 21:07:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
|
|
|
IopCleanupIrp(IN PIRP Irp,
|
|
|
|
IN PFILE_OBJECT FileObject)
|
2005-06-04 21:07:00 +00:00
|
|
|
{
|
|
|
|
PMDL Mdl;
|
2006-06-29 23:52:45 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Cleaning IRP %p for %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp,
|
|
|
|
FileObject);
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Check if there's an MDL */
|
|
|
|
while ((Mdl = Irp->MdlAddress))
|
|
|
|
{
|
|
|
|
/* Clear all of them */
|
|
|
|
Irp->MdlAddress = Mdl->Next;
|
|
|
|
IoFreeMdl(Mdl);
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2006-06-29 23:52:45 +00:00
|
|
|
/* Check if the IRP has system buffer */
|
2005-06-04 21:07:00 +00:00
|
|
|
if (Irp->Flags & IRP_DEALLOCATE_BUFFER)
|
|
|
|
{
|
2006-06-29 23:52:45 +00:00
|
|
|
/* Free the buffer */
|
2005-06-04 21:07:00 +00:00
|
|
|
ExFreePoolWithTag(Irp->AssociatedIrp.SystemBuffer, TAG_SYS_BUF);
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2006-06-29 23:52:45 +00:00
|
|
|
/* Check if this IRP has a user event, a file object, and is async */
|
|
|
|
if ((Irp->UserEvent) &&
|
|
|
|
!(Irp->Flags & IRP_SYNCHRONOUS_API) &&
|
|
|
|
(FileObject))
|
2005-06-04 21:07:00 +00:00
|
|
|
{
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
/* Dereference the User Event */
|
2005-06-04 21:07:00 +00:00
|
|
|
ObDereferenceObject(Irp->UserEvent);
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
/* Check if we have a file object and this isn't a create operation */
|
|
|
|
if ((FileObject) && !(Irp->Flags & IRP_CREATE_OPERATION))
|
|
|
|
{
|
|
|
|
/* Dereference the file object */
|
|
|
|
ObDereferenceObject(FileObject);
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Free the IRP */
|
|
|
|
IoFreeIrp(Irp);
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
|
|
|
IopCompleteRequest(IN PKAPC Apc,
|
|
|
|
IN PKNORMAL_ROUTINE* NormalRoutine,
|
|
|
|
IN PVOID* NormalContext,
|
|
|
|
IN PVOID* SystemArgument1,
|
|
|
|
IN PVOID* SystemArgument2)
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
|
|
|
PFILE_OBJECT FileObject;
|
|
|
|
PIRP Irp;
|
2007-03-05 00:47:19 +00:00
|
|
|
PMDL Mdl, NextMdl;
|
2006-06-30 03:15:56 +00:00
|
|
|
PVOID Port = NULL, Key = NULL;
|
|
|
|
BOOLEAN SignaledCreateRequest = FALSE;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Get data from the APC */
|
2006-06-30 03:15:56 +00:00
|
|
|
FileObject = (PFILE_OBJECT)*SystemArgument1;
|
2005-05-07 01:13:04 +00:00
|
|
|
Irp = CONTAINING_RECORD(Apc, IRP, Tail.Apc);
|
2006-06-30 03:15:56 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Completing IRP %p for %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp,
|
|
|
|
FileObject);
|
2005-05-07 01:13:04 +00:00
|
|
|
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Sanity check */
|
2008-12-03 17:28:59 +00:00
|
|
|
ASSERT(Irp->IoStatus.Status != (NTSTATUS)0xFFFFFFFF);
|
2007-03-05 00:47:19 +00:00
|
|
|
|
|
|
|
/* Check if we have a file object */
|
|
|
|
if (*SystemArgument2)
|
|
|
|
{
|
|
|
|
/* Check if we're reparsing */
|
|
|
|
if ((Irp->IoStatus.Status == STATUS_REPARSE) &&
|
|
|
|
(Irp->IoStatus.Information == IO_REPARSE_TAG_MOUNT_POINT))
|
|
|
|
{
|
2014-12-07 17:59:58 +00:00
|
|
|
PREPARSE_DATA_BUFFER ReparseData;
|
|
|
|
|
|
|
|
ReparseData = (PREPARSE_DATA_BUFFER)*SystemArgument2;
|
|
|
|
|
|
|
|
ASSERT(ReparseData->ReparseTag == IO_REPARSE_TAG_MOUNT_POINT);
|
|
|
|
ASSERT(ReparseData->ReparseDataLength < MAXIMUM_REPARSE_DATA_BUFFER_SIZE);
|
|
|
|
ASSERT(ReparseData->Reserved < MAXIMUM_REPARSE_DATA_BUFFER_SIZE);
|
|
|
|
|
|
|
|
IopDoNameTransmogrify(Irp, FileObject, ReparseData);
|
2007-03-05 00:47:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Handle Buffered case first */
|
|
|
|
if (Irp->Flags & IRP_BUFFERED_IO)
|
|
|
|
{
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Check if we have an input buffer and if we succeeded */
|
2007-10-19 23:21:45 +00:00
|
|
|
if ((Irp->Flags & IRP_INPUT_OPERATION) &&
|
2005-11-09 04:29:46 +00:00
|
|
|
(Irp->IoStatus.Status != STATUS_VERIFY_REQUIRED) &&
|
|
|
|
!(NT_ERROR(Irp->IoStatus.Status)))
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2015-05-01 10:49:50 +00:00
|
|
|
_SEH2_TRY
|
|
|
|
{
|
|
|
|
/* Copy the buffer back to the user */
|
|
|
|
RtlCopyMemory(Irp->UserBuffer,
|
|
|
|
Irp->AssociatedIrp.SystemBuffer,
|
|
|
|
Irp->IoStatus.Information);
|
|
|
|
}
|
|
|
|
_SEH2_EXCEPT(EXCEPTION_EXECUTE_HANDLER)
|
|
|
|
{
|
2015-05-01 11:52:32 +00:00
|
|
|
/* Fail the IRP */
|
|
|
|
Irp->IoStatus.Status = _SEH2_GetExceptionCode();
|
2015-05-01 10:49:50 +00:00
|
|
|
}
|
|
|
|
_SEH2_END;
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Also check if we should de-allocate it */
|
|
|
|
if (Irp->Flags & IRP_DEALLOCATE_BUFFER)
|
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Deallocate it */
|
2008-11-07 17:40:44 +00:00
|
|
|
ExFreePool(Irp->AssociatedIrp.SystemBuffer);
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Now we got rid of these two... */
|
|
|
|
Irp->Flags &= ~(IRP_BUFFERED_IO | IRP_DEALLOCATE_BUFFER);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Check if there's an MDL */
|
2007-03-05 00:47:19 +00:00
|
|
|
for (Mdl = Irp->MdlAddress; Mdl; Mdl = NextMdl)
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Free it */
|
|
|
|
NextMdl = Mdl->Next;
|
2005-05-08 16:02:38 +00:00
|
|
|
IoFreeMdl(Mdl);
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
|
|
|
|
2007-03-05 00:47:19 +00:00
|
|
|
/* No MDLs left */
|
|
|
|
Irp->MdlAddress = NULL;
|
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/*
|
|
|
|
* Check if either the request was completed without any errors
|
|
|
|
* (but warnings are OK!), or if it was completed with an error, but
|
|
|
|
* did return from a pending I/O Operation and is not synchronous.
|
|
|
|
*/
|
2015-05-01 10:49:50 +00:00
|
|
|
if (!NT_ERROR(Irp->IoStatus.Status) ||
|
|
|
|
(Irp->PendingReturned &&
|
|
|
|
!IsIrpSynchronous(Irp, FileObject)))
|
2005-05-09 01:38:29 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Get any information we need from the FO before we kill it */
|
|
|
|
if ((FileObject) && (FileObject->CompletionContext))
|
|
|
|
{
|
|
|
|
/* Save Completion Data */
|
|
|
|
Port = FileObject->CompletionContext->Port;
|
|
|
|
Key = FileObject->CompletionContext->Key;
|
|
|
|
}
|
|
|
|
|
2014-10-24 07:16:44 +00:00
|
|
|
/* Check for UserIos */
|
|
|
|
if (Irp->UserIosb != NULL)
|
2005-05-08 10:26:34 +00:00
|
|
|
{
|
2014-10-24 07:16:44 +00:00
|
|
|
/* Use SEH to make sure we don't write somewhere invalid */
|
|
|
|
_SEH2_TRY
|
|
|
|
{
|
|
|
|
/* Save the IOSB Information */
|
|
|
|
*Irp->UserIosb = Irp->IoStatus;
|
|
|
|
}
|
|
|
|
_SEH2_EXCEPT(EXCEPTION_EXECUTE_HANDLER)
|
|
|
|
{
|
|
|
|
/* Ignore any error */
|
|
|
|
}
|
|
|
|
_SEH2_END;
|
2005-05-08 10:26:34 +00:00
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Check if we have an event or a file object */
|
|
|
|
if (Irp->UserEvent)
|
2005-05-08 10:26:34 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* At the very least, this is a PKEVENT, so signal it always */
|
|
|
|
KeSetEvent(Irp->UserEvent, 0, FALSE);
|
|
|
|
|
|
|
|
/* Check if we also have a File Object */
|
2005-05-08 10:26:34 +00:00
|
|
|
if (FileObject)
|
|
|
|
{
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Check if this is an Asynch API */
|
|
|
|
if (!(Irp->Flags & IRP_SYNCHRONOUS_API))
|
|
|
|
{
|
|
|
|
/* Dereference the event */
|
|
|
|
ObDereferenceObject(Irp->UserEvent);
|
|
|
|
}
|
|
|
|
|
2006-06-29 23:01:09 +00:00
|
|
|
/*
|
2006-06-30 03:15:56 +00:00
|
|
|
* Now, if this is a Synch I/O File Object, then this event is
|
|
|
|
* NOT an actual Executive Event, so we won't dereference it,
|
|
|
|
* and instead, we will signal the File Object
|
2006-06-29 23:01:09 +00:00
|
|
|
*/
|
2007-03-05 00:47:19 +00:00
|
|
|
if ((FileObject->Flags & FO_SYNCHRONOUS_IO) &&
|
|
|
|
!(Irp->Flags & IRP_OB_QUERY_NAME))
|
2005-05-08 10:26:34 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Signal the file object and set the status */
|
2005-05-08 10:26:34 +00:00
|
|
|
KeSetEvent(&FileObject->Event, 0, FALSE);
|
2006-06-30 03:15:56 +00:00
|
|
|
FileObject->FinalStatus = Irp->IoStatus.Status;
|
2005-05-08 10:26:34 +00:00
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/*
|
|
|
|
* This could also be a create operation, in which case we want
|
|
|
|
* to make sure there's no APC fired.
|
|
|
|
*/
|
|
|
|
if (Irp->Flags & IRP_CREATE_OPERATION)
|
|
|
|
{
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Clear the APC Routine and remember this */
|
2006-06-30 03:15:56 +00:00
|
|
|
Irp->Overlay.AsynchronousParameters.UserApcRoutine = NULL;
|
|
|
|
SignaledCreateRequest = TRUE;
|
|
|
|
}
|
2005-05-09 00:41:55 +00:00
|
|
|
}
|
2005-05-08 10:26:34 +00:00
|
|
|
}
|
|
|
|
else if (FileObject)
|
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Signal the file object and set the status */
|
2005-05-08 10:26:34 +00:00
|
|
|
KeSetEvent(&FileObject->Event, 0, FALSE);
|
2006-06-30 03:15:56 +00:00
|
|
|
FileObject->FinalStatus = Irp->IoStatus.Status;
|
2007-03-05 00:47:19 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This could also be a create operation, in which case we want
|
|
|
|
* to make sure there's no APC fired.
|
|
|
|
*/
|
|
|
|
if (Irp->Flags & IRP_CREATE_OPERATION)
|
|
|
|
{
|
|
|
|
/* Clear the APC Routine and remember this */
|
|
|
|
Irp->Overlay.AsynchronousParameters.UserApcRoutine = NULL;
|
|
|
|
SignaledCreateRequest = TRUE;
|
|
|
|
}
|
2005-05-08 10:26:34 +00:00
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2009-06-09 16:38:05 +00:00
|
|
|
/* Update transfer count for everything but create operation */
|
|
|
|
if (!(Irp->Flags & IRP_CREATE_OPERATION))
|
|
|
|
{
|
|
|
|
if (Irp->Flags & IRP_WRITE_OPERATION)
|
|
|
|
{
|
|
|
|
/* Update write transfer count */
|
|
|
|
IopUpdateTransferCount(IopWriteTransfer,
|
2009-06-09 16:43:22 +00:00
|
|
|
(ULONG)Irp->IoStatus.Information);
|
2009-06-09 16:38:05 +00:00
|
|
|
}
|
|
|
|
else if (Irp->Flags & IRP_READ_OPERATION)
|
|
|
|
{
|
|
|
|
/* Update read transfer count */
|
|
|
|
IopUpdateTransferCount(IopReadTransfer,
|
2009-06-09 16:43:22 +00:00
|
|
|
(ULONG)Irp->IoStatus.Information);
|
2009-06-09 16:38:05 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Update other transfer count */
|
|
|
|
IopUpdateTransferCount(IopOtherTransfer,
|
2009-06-09 16:43:22 +00:00
|
|
|
(ULONG)Irp->IoStatus.Information);
|
2009-06-09 16:38:05 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Now that we've signaled the events, de-associate the IRP */
|
2006-07-29 16:56:26 +00:00
|
|
|
IopUnQueueIrpFromThread(Irp);
|
2006-06-30 03:15:56 +00:00
|
|
|
|
|
|
|
/* Now check if a User APC Routine was requested */
|
2006-06-29 23:01:09 +00:00
|
|
|
if (Irp->Overlay.AsynchronousParameters.UserApcRoutine)
|
2005-05-08 10:26:34 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Initialize it */
|
2005-05-08 10:26:34 +00:00
|
|
|
KeInitializeApc(&Irp->Tail.Apc,
|
|
|
|
KeGetCurrentThread(),
|
|
|
|
CurrentApcEnvironment,
|
|
|
|
IopFreeIrpKernelApc,
|
|
|
|
IopAbortIrpKernelApc,
|
2006-06-29 23:01:09 +00:00
|
|
|
(PKNORMAL_ROUTINE)Irp->
|
|
|
|
Overlay.AsynchronousParameters.UserApcRoutine,
|
2005-05-08 10:26:34 +00:00
|
|
|
Irp->RequestorMode,
|
2006-06-29 23:01:09 +00:00
|
|
|
Irp->
|
|
|
|
Overlay.AsynchronousParameters.UserApcContext);
|
2005-05-08 10:26:34 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Queue it */
|
|
|
|
KeInsertQueueApc(&Irp->Tail.Apc, Irp->UserIosb, NULL, 2);
|
2005-05-08 10:26:34 +00:00
|
|
|
}
|
2006-06-30 03:15:56 +00:00
|
|
|
else if ((Port) &&
|
|
|
|
(Irp->Overlay.AsynchronousParameters.UserApcContext))
|
2005-05-08 10:26:34 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* We have an I/O Completion setup... create the special Overlay */
|
|
|
|
Irp->Tail.CompletionKey = Key;
|
2008-11-04 21:55:55 +00:00
|
|
|
Irp->Tail.Overlay.PacketType = IopCompletionPacketIrp;
|
2006-06-30 03:15:56 +00:00
|
|
|
KeInsertQueue(Port, &Irp->Tail.Overlay.ListEntry);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Free the IRP since we don't need it anymore */
|
|
|
|
IoFreeIrp(Irp);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Check if we have a file object that wasn't part of a create */
|
|
|
|
if ((FileObject) && !(SignaledCreateRequest))
|
|
|
|
{
|
|
|
|
/* Dereference it, since it's not needed anymore either */
|
2007-03-05 00:47:19 +00:00
|
|
|
ObDereferenceObjectDeferDelete(FileObject);
|
2005-05-08 10:26:34 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
2005-05-09 01:38:29 +00:00
|
|
|
{
|
2006-06-29 23:01:09 +00:00
|
|
|
/*
|
2006-06-30 03:15:56 +00:00
|
|
|
* Either we didn't return from the request, or we did return but this
|
|
|
|
* request was synchronous.
|
2006-06-29 23:01:09 +00:00
|
|
|
*/
|
2006-06-30 03:15:56 +00:00
|
|
|
if ((Irp->PendingReturned) && (FileObject))
|
2005-05-08 10:26:34 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* So we did return with a synch operation, was it the IRP? */
|
|
|
|
if (Irp->Flags & IRP_SYNCHRONOUS_API)
|
2005-05-08 10:26:34 +00:00
|
|
|
{
|
2010-04-04 21:43:51 +00:00
|
|
|
/* Yes, this IRP was synchronous, so return the I/O Status */
|
|
|
|
*Irp->UserIosb = Irp->IoStatus;
|
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Now check if the user gave an event */
|
|
|
|
if (Irp->UserEvent)
|
2005-05-08 10:26:34 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Signal it */
|
|
|
|
KeSetEvent(Irp->UserEvent, 0, FALSE);
|
2005-05-08 10:26:34 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* No event was given, so signal the FO instead */
|
2005-05-08 10:26:34 +00:00
|
|
|
KeSetEvent(&FileObject->Event, 0, FALSE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/*
|
|
|
|
* It's not the IRP that was synchronous, it was the FO
|
|
|
|
* that was opened this way. Signal its event.
|
|
|
|
*/
|
2005-05-08 10:26:34 +00:00
|
|
|
FileObject->FinalStatus = Irp->IoStatus.Status;
|
|
|
|
KeSetEvent(&FileObject->Event, 0, FALSE);
|
|
|
|
}
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Now that we got here, we do this for incomplete I/Os as well */
|
|
|
|
if ((FileObject) && !(Irp->Flags & IRP_CREATE_OPERATION))
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Dereference the File Object unless this was a create */
|
2007-03-05 00:47:19 +00:00
|
|
|
ObDereferenceObjectDeferDelete(FileObject);
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/*
|
|
|
|
* Check if this was an Executive Event (remember that we know this
|
|
|
|
* by checking if the IRP is synchronous)
|
|
|
|
*/
|
|
|
|
if ((Irp->UserEvent) &&
|
|
|
|
(FileObject) &&
|
|
|
|
!(Irp->Flags & IRP_SYNCHRONOUS_API))
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* This isn't a PKEVENT, so dereference it */
|
|
|
|
ObDereferenceObject(Irp->UserEvent);
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Now that we've signaled the events, de-associate the IRP */
|
2006-07-29 16:56:26 +00:00
|
|
|
IopUnQueueIrpFromThread(Irp);
|
2005-05-07 01:13:04 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Free the IRP as well */
|
|
|
|
IoFreeIrp(Irp);
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-24 13:50:23 +00:00
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
IopInitializeReserveIrp(IN PRESERVE_IRP_ALLOCATOR ReserveIrpAllocator)
|
|
|
|
{
|
|
|
|
/* Our allocated stack size */
|
|
|
|
ReserveIrpAllocator->StackSize = 20;
|
|
|
|
|
|
|
|
/* Allocate the IRP now */
|
|
|
|
ReserveIrpAllocator->ReserveIrp = IoAllocateIrp(ReserveIrpAllocator->StackSize, FALSE);
|
|
|
|
/* If we cannot, abort system boot */
|
|
|
|
if (ReserveIrpAllocator->ReserveIrp == NULL)
|
|
|
|
{
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* It's not in use */
|
|
|
|
ReserveIrpAllocator->ReserveIrpInUse = 0;
|
|
|
|
/* And init the event */
|
|
|
|
KeInitializeEvent(&ReserveIrpAllocator->WaitEvent, SynchronizationEvent, FALSE);
|
|
|
|
|
|
|
|
/* All good, keep booting */
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
PIRP
|
|
|
|
NTAPI
|
|
|
|
IopAllocateReserveIrp(IN CCHAR StackSize)
|
|
|
|
{
|
|
|
|
/* If we need a stack size higher than what was allocated, then fail */
|
|
|
|
if (StackSize > IopReserveIrpAllocator.StackSize)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Now, wait until the IRP becomes available and reserve it immediately */
|
|
|
|
while (InterlockedExchange(&IopReserveIrpAllocator.ReserveIrpInUse, 1) == 1)
|
|
|
|
{
|
|
|
|
KeWaitForSingleObject(&IopReserveIrpAllocator.WaitEvent,
|
|
|
|
Executive,
|
|
|
|
KernelMode,
|
|
|
|
FALSE,
|
|
|
|
NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* It's ours! Initialize it */
|
|
|
|
IoInitializeIrp(IopReserveIrpAllocator.ReserveIrp, IoSizeOfIrp(StackSize), StackSize);
|
|
|
|
|
|
|
|
/* And return it to the caller */
|
|
|
|
return IopReserveIrpAllocator.ReserveIrp;
|
|
|
|
}
|
|
|
|
|
|
|
|
VOID
|
|
|
|
IopFreeReserveIrp(IN CCHAR PriorityBoost)
|
|
|
|
{
|
|
|
|
/* Mark we don't use the IRP anymore */
|
|
|
|
InterlockedExchange(&IopReserveIrpAllocator.ReserveIrpInUse, 0);
|
|
|
|
|
|
|
|
/* And set the event if someone is waiting on the IRP */
|
|
|
|
KeSetEvent(&IopReserveIrpAllocator.WaitEvent, PriorityBoost, FALSE);
|
|
|
|
}
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* FUNCTIONS *****************************************************************/
|
1999-01-13 03:00:06 +00:00
|
|
|
|
2004-06-23 21:42:50 +00:00
|
|
|
/*
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
* @implemented
|
2004-06-23 21:42:50 +00:00
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
PIRP
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 03:48:03 +00:00
|
|
|
IoAllocateIrp(IN CCHAR StackSize,
|
|
|
|
IN BOOLEAN ChargeQuota)
|
2004-06-23 21:42:50 +00:00
|
|
|
{
|
2005-05-13 04:49:54 +00:00
|
|
|
PIRP Irp = NULL;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
USHORT Size = IoSizeOfIrp(StackSize);
|
2005-05-13 04:49:54 +00:00
|
|
|
PKPRCB Prcb;
|
2005-05-13 05:41:24 +00:00
|
|
|
UCHAR Flags = 0;
|
2005-05-14 12:54:53 +00:00
|
|
|
PNPAGED_LOOKASIDE_LIST List = NULL;
|
2005-05-13 04:49:54 +00:00
|
|
|
PP_NPAGED_LOOKASIDE_NUMBER ListType = LookasideSmallIrpList;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2008-07-30 13:24:05 +00:00
|
|
|
/* Set Charge Quota Flag */
|
|
|
|
if (ChargeQuota) Flags |= IRP_QUOTA_CHARGED;
|
|
|
|
|
2016-09-03 21:25:45 +00:00
|
|
|
/* Get the PRCB */
|
|
|
|
Prcb = KeGetCurrentPrcb();
|
2011-02-10 13:01:39 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Figure out which Lookaside List to use */
|
2016-09-03 21:25:45 +00:00
|
|
|
if ((StackSize <= 8) && (ChargeQuota == FALSE || Prcb->LookasideIrpFloat > 0))
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Set Fixed Size Flag */
|
2016-09-03 21:25:45 +00:00
|
|
|
Flags |= IRP_ALLOCATED_FIXED_SIZE;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* See if we should use big list */
|
|
|
|
if (StackSize != 1)
|
|
|
|
{
|
|
|
|
Size = IoSizeOfIrp(8);
|
|
|
|
ListType = LookasideLargeIrpList;
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Get the P List First */
|
|
|
|
List = (PNPAGED_LOOKASIDE_LIST)Prcb->PPLookasideList[ListType].P;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Attempt allocation */
|
|
|
|
List->L.TotalAllocates++;
|
|
|
|
Irp = (PIRP)InterlockedPopEntrySList(&List->L.ListHead);
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Check if the P List failed */
|
|
|
|
if (!Irp)
|
|
|
|
{
|
|
|
|
/* Let the balancer know */
|
|
|
|
List->L.AllocateMisses++;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Try the L List */
|
|
|
|
List = (PNPAGED_LOOKASIDE_LIST)Prcb->PPLookasideList[ListType].L;
|
|
|
|
List->L.TotalAllocates++;
|
|
|
|
Irp = (PIRP)InterlockedPopEntrySList(&List->L.ListHead);
|
|
|
|
}
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Check if we have to use the pool */
|
|
|
|
if (!Irp)
|
|
|
|
{
|
|
|
|
/* Did we try lookaside and fail? */
|
|
|
|
if (Flags & IRP_ALLOCATED_FIXED_SIZE) List->L.AllocateMisses++;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Check if we should charge quota */
|
2005-05-13 04:49:54 +00:00
|
|
|
if (ChargeQuota)
|
|
|
|
{
|
2014-05-02 09:17:36 +00:00
|
|
|
Irp = ExAllocatePoolWithQuotaTag(NonPagedPool | POOL_QUOTA_FAIL_INSTEAD_OF_RAISE,
|
|
|
|
Size,
|
|
|
|
TAG_IRP);
|
2005-05-13 04:49:54 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-05-02 09:17:36 +00:00
|
|
|
/* Allocate the IRP with no quota charge */
|
2005-05-13 04:49:54 +00:00
|
|
|
Irp = ExAllocatePoolWithTag(NonPagedPool, Size, TAG_IRP);
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Make sure it was sucessful */
|
2014-05-02 09:17:36 +00:00
|
|
|
if (!Irp) return NULL;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2016-09-03 21:25:45 +00:00
|
|
|
else if (Flags & IRP_QUOTA_CHARGED)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2016-09-03 21:25:45 +00:00
|
|
|
/* Decrement lookaside float */
|
|
|
|
InterlockedDecrement(&Prcb->LookasideIrpFloat);
|
|
|
|
Flags |= IRP_LOOKASIDE_ALLOCATION;
|
|
|
|
|
2008-07-30 13:24:05 +00:00
|
|
|
/* In this case there is no charge quota */
|
|
|
|
Flags &= ~IRP_QUOTA_CHARGED;
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Now Initialize it */
|
|
|
|
IoInitializeIrp(Irp, Size, StackSize);
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Set the Allocation Flags */
|
|
|
|
Irp->AllocationFlags = Flags;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Return it */
|
2006-06-30 03:48:03 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Allocated IRP %p with allocation flags %lx\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp,
|
|
|
|
Flags);
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
return Irp;
|
2004-06-23 21:42:50 +00:00
|
|
|
}
|
2000-03-06 01:02:30 +00:00
|
|
|
|
2013-01-27 16:11:55 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
|
|
|
PIRP
|
|
|
|
NTAPI
|
|
|
|
IopAllocateIrpMustSucceed(IN CCHAR StackSize)
|
|
|
|
{
|
|
|
|
LONG i;
|
|
|
|
PIRP Irp;
|
|
|
|
LARGE_INTEGER Sleep;
|
|
|
|
|
|
|
|
/* Try to get an IRP */
|
|
|
|
Irp = IoAllocateIrp(StackSize, FALSE);
|
|
|
|
if (Irp)
|
|
|
|
return Irp;
|
|
|
|
|
|
|
|
/* If we fail, start looping till we may get one */
|
|
|
|
i = LONG_MAX;
|
|
|
|
do {
|
|
|
|
i--;
|
|
|
|
|
|
|
|
/* First, sleep for 10ms */
|
2016-02-04 20:42:07 +00:00
|
|
|
Sleep.QuadPart = -10 * 1000 * 10;
|
2013-01-27 16:11:55 +00:00
|
|
|
KeDelayExecutionThread(KernelMode, FALSE, &Sleep);
|
|
|
|
|
|
|
|
/* Then, retry allocation */
|
|
|
|
Irp = IoAllocateIrp(StackSize, FALSE);
|
|
|
|
if (Irp)
|
|
|
|
return Irp;
|
|
|
|
} while (i > 0);
|
|
|
|
|
|
|
|
return Irp;
|
|
|
|
}
|
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
2004-06-23 21:42:50 +00:00
|
|
|
*/
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
PIRP
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 03:48:03 +00:00
|
|
|
IoBuildAsynchronousFsdRequest(IN ULONG MajorFunction,
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PVOID Buffer,
|
|
|
|
IN ULONG Length,
|
|
|
|
IN PLARGE_INTEGER StartingOffset,
|
|
|
|
IN PIO_STATUS_BLOCK IoStatusBlock)
|
2004-06-23 21:42:50 +00:00
|
|
|
{
|
2007-04-02 15:08:54 +00:00
|
|
|
PIRP Irp;
|
|
|
|
PIO_STACK_LOCATION StackPtr;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
|
|
|
|
/* Allocate IRP */
|
2006-06-30 03:48:03 +00:00
|
|
|
Irp = IoAllocateIrp(DeviceObject->StackSize, FALSE);
|
2008-08-23 16:30:14 +00:00
|
|
|
if (!Irp) return NULL;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Get the Stack */
|
|
|
|
StackPtr = IoGetNextIrpStackLocation(Irp);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Write the Major function and then deal with it */
|
2005-05-09 01:38:29 +00:00
|
|
|
StackPtr->MajorFunction = (UCHAR)MajorFunction;
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Do not handle the following here */
|
2006-06-30 03:48:03 +00:00
|
|
|
if ((MajorFunction != IRP_MJ_FLUSH_BUFFERS) &&
|
|
|
|
(MajorFunction != IRP_MJ_SHUTDOWN) &&
|
|
|
|
(MajorFunction != IRP_MJ_PNP) &&
|
|
|
|
(MajorFunction != IRP_MJ_POWER))
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
|
|
|
/* Check if this is Buffered IO */
|
|
|
|
if (DeviceObject->Flags & DO_BUFFERED_IO)
|
|
|
|
{
|
|
|
|
/* Allocate the System Buffer */
|
2006-06-29 23:01:09 +00:00
|
|
|
Irp->AssociatedIrp.SystemBuffer =
|
|
|
|
ExAllocatePoolWithTag(NonPagedPool, Length, TAG_SYS_BUF);
|
2006-06-30 03:48:03 +00:00
|
|
|
if (!Irp->AssociatedIrp.SystemBuffer)
|
|
|
|
{
|
|
|
|
/* Free the IRP and fail */
|
|
|
|
IoFreeIrp(Irp);
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Set flags */
|
|
|
|
Irp->Flags = IRP_BUFFERED_IO | IRP_DEALLOCATE_BUFFER;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Handle special IRP_MJ_WRITE Case */
|
|
|
|
if (MajorFunction == IRP_MJ_WRITE)
|
|
|
|
{
|
|
|
|
/* Copy the buffer data */
|
|
|
|
RtlCopyMemory(Irp->AssociatedIrp.SystemBuffer, Buffer, Length);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Set the Input Operation flag and set this as a User Buffer */
|
2005-04-29 14:38:05 +00:00
|
|
|
Irp->Flags |= IRP_INPUT_OPERATION;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
Irp->UserBuffer = Buffer;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (DeviceObject->Flags & DO_DIRECT_IO)
|
|
|
|
{
|
|
|
|
/* Use an MDL for Direct I/O */
|
2006-06-30 03:48:03 +00:00
|
|
|
Irp->MdlAddress = IoAllocateMdl(Buffer,
|
|
|
|
Length,
|
|
|
|
FALSE,
|
|
|
|
FALSE,
|
|
|
|
NULL);
|
|
|
|
if (!Irp->MdlAddress)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Free the IRP and fail */
|
|
|
|
IoFreeIrp(Irp);
|
|
|
|
return NULL;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2018-12-18 20:35:12 +00:00
|
|
|
/* Probe and Lock */
|
|
|
|
_SEH2_TRY
|
|
|
|
{
|
|
|
|
/* Do the probe */
|
|
|
|
MmProbeAndLockPages(Irp->MdlAddress,
|
|
|
|
KernelMode,
|
|
|
|
MajorFunction == IRP_MJ_READ ?
|
|
|
|
IoWriteAccess : IoReadAccess);
|
|
|
|
}
|
|
|
|
_SEH2_EXCEPT(EXCEPTION_EXECUTE_HANDLER)
|
|
|
|
{
|
|
|
|
/* Free the IRP and its MDL */
|
|
|
|
IoFreeMdl(Irp->MdlAddress);
|
|
|
|
IoFreeIrp(Irp);
|
2009-08-26 17:31:02 +00:00
|
|
|
|
|
|
|
/* Fail */
|
2018-12-18 20:35:12 +00:00
|
|
|
_SEH2_YIELD(return NULL);
|
|
|
|
}
|
|
|
|
_SEH2_END;
|
2005-05-09 01:38:29 +00:00
|
|
|
}
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Neither, use the buffer */
|
|
|
|
Irp->UserBuffer = Buffer;
|
|
|
|
}
|
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Check if this is a read */
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
if (MajorFunction == IRP_MJ_READ)
|
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Set the parameters for a read */
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
StackPtr->Parameters.Read.Length = Length;
|
|
|
|
StackPtr->Parameters.Read.ByteOffset = *StartingOffset;
|
|
|
|
}
|
|
|
|
else if (MajorFunction == IRP_MJ_WRITE)
|
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Otherwise, set write parameters */
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
StackPtr->Parameters.Write.Length = Length;
|
|
|
|
StackPtr->Parameters.Write.ByteOffset = *StartingOffset;
|
|
|
|
}
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Set the Current Thread and IOSB */
|
|
|
|
Irp->UserIosb = IoStatusBlock;
|
|
|
|
Irp->Tail.Overlay.Thread = PsGetCurrentThread();
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2008-08-23 16:30:14 +00:00
|
|
|
/* Return the IRP */
|
2006-06-30 03:48:03 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Built IRP %p with Major, Buffer, DO %lx %p %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp,
|
|
|
|
MajorFunction,
|
|
|
|
Buffer,
|
|
|
|
DeviceObject);
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
return Irp;
|
2004-06-23 21:42:50 +00:00
|
|
|
}
|
2000-03-06 01:02:30 +00:00
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
2004-08-10 06:26:42 +00:00
|
|
|
* @implemented
|
1999-01-13 03:00:06 +00:00
|
|
|
*/
|
2005-05-01 19:30:06 +00:00
|
|
|
PIRP
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 03:48:03 +00:00
|
|
|
IoBuildDeviceIoControlRequest(IN ULONG IoControlCode,
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PVOID InputBuffer,
|
|
|
|
IN ULONG InputBufferLength,
|
|
|
|
IN PVOID OutputBuffer,
|
|
|
|
IN ULONG OutputBufferLength,
|
|
|
|
IN BOOLEAN InternalDeviceIoControl,
|
|
|
|
IN PKEVENT Event,
|
|
|
|
IN PIO_STATUS_BLOCK IoStatusBlock)
|
1999-01-13 03:00:06 +00:00
|
|
|
{
|
2007-04-02 15:08:54 +00:00
|
|
|
PIRP Irp;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
PIO_STACK_LOCATION StackPtr;
|
|
|
|
ULONG BufferLength;
|
|
|
|
|
|
|
|
/* Allocate IRP */
|
2006-06-30 03:48:03 +00:00
|
|
|
Irp = IoAllocateIrp(DeviceObject->StackSize, FALSE);
|
2008-08-23 16:30:14 +00:00
|
|
|
if (!Irp) return NULL;
|
2005-05-01 19:30:06 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Get the Stack */
|
|
|
|
StackPtr = IoGetNextIrpStackLocation(Irp);
|
2005-05-01 19:30:06 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Set the DevCtl Type */
|
2005-05-01 19:30:06 +00:00
|
|
|
StackPtr->MajorFunction = InternalDeviceIoControl ?
|
2006-06-29 23:01:09 +00:00
|
|
|
IRP_MJ_INTERNAL_DEVICE_CONTROL :
|
|
|
|
IRP_MJ_DEVICE_CONTROL;
|
2005-05-01 19:30:06 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Set the IOCTL Data */
|
|
|
|
StackPtr->Parameters.DeviceIoControl.IoControlCode = IoControlCode;
|
|
|
|
StackPtr->Parameters.DeviceIoControl.InputBufferLength = InputBufferLength;
|
2006-06-29 23:01:09 +00:00
|
|
|
StackPtr->Parameters.DeviceIoControl.OutputBufferLength =
|
|
|
|
OutputBufferLength;
|
2004-08-10 06:26:42 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Handle the Methods */
|
|
|
|
switch (IO_METHOD_FROM_CTL_CODE(IoControlCode))
|
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Buffered I/O */
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
case METHOD_BUFFERED:
|
2005-05-01 19:30:06 +00:00
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Select the right Buffer Length */
|
|
|
|
BufferLength = InputBufferLength > OutputBufferLength ?
|
|
|
|
InputBufferLength : OutputBufferLength;
|
2005-05-01 19:30:06 +00:00
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Make sure there is one */
|
|
|
|
if (BufferLength)
|
|
|
|
{
|
|
|
|
/* Allocate the System Buffer */
|
|
|
|
Irp->AssociatedIrp.SystemBuffer =
|
|
|
|
ExAllocatePoolWithTag(NonPagedPool,
|
|
|
|
BufferLength,
|
|
|
|
TAG_SYS_BUF);
|
|
|
|
if (!Irp->AssociatedIrp.SystemBuffer)
|
|
|
|
{
|
|
|
|
/* Free the IRP and fail */
|
|
|
|
IoFreeIrp(Irp);
|
|
|
|
return NULL;
|
|
|
|
}
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Check if we got a buffer */
|
|
|
|
if (InputBuffer)
|
|
|
|
{
|
|
|
|
/* Copy into the System Buffer */
|
|
|
|
RtlCopyMemory(Irp->AssociatedIrp.SystemBuffer,
|
|
|
|
InputBuffer,
|
|
|
|
InputBufferLength);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Write the flags */
|
|
|
|
Irp->Flags = IRP_BUFFERED_IO | IRP_DEALLOCATE_BUFFER;
|
|
|
|
if (OutputBuffer) Irp->Flags |= IRP_INPUT_OPERATION;
|
|
|
|
|
|
|
|
/* Save the Buffer */
|
|
|
|
Irp->UserBuffer = OutputBuffer;
|
|
|
|
}
|
|
|
|
else
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Clear the Flags and Buffer */
|
|
|
|
Irp->Flags = 0;
|
|
|
|
Irp->UserBuffer = NULL;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2006-06-30 03:48:03 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
/* Direct I/O */
|
|
|
|
case METHOD_IN_DIRECT:
|
|
|
|
case METHOD_OUT_DIRECT:
|
2005-05-01 19:30:06 +00:00
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Check if we got an input buffer */
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
if (InputBuffer)
|
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Allocate the System Buffer */
|
|
|
|
Irp->AssociatedIrp.SystemBuffer =
|
|
|
|
ExAllocatePoolWithTag(NonPagedPool,
|
|
|
|
InputBufferLength,
|
|
|
|
TAG_SYS_BUF);
|
|
|
|
if (!Irp->AssociatedIrp.SystemBuffer)
|
|
|
|
{
|
|
|
|
/* Free the IRP and fail */
|
|
|
|
IoFreeIrp(Irp);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Copy into the System Buffer */
|
2005-05-01 19:30:06 +00:00
|
|
|
RtlCopyMemory(Irp->AssociatedIrp.SystemBuffer,
|
|
|
|
InputBuffer,
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
InputBufferLength);
|
2005-05-01 19:30:06 +00:00
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Write the flags */
|
|
|
|
Irp->Flags = IRP_BUFFERED_IO | IRP_DEALLOCATE_BUFFER;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2006-06-30 03:48:03 +00:00
|
|
|
else
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2008-08-23 16:30:14 +00:00
|
|
|
/* Clear the flags */
|
2006-06-30 03:48:03 +00:00
|
|
|
Irp->Flags = 0;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2005-05-01 19:30:06 +00:00
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Check if we got an output buffer */
|
|
|
|
if (OutputBuffer)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Allocate the System Buffer */
|
|
|
|
Irp->MdlAddress = IoAllocateMdl(OutputBuffer,
|
|
|
|
OutputBufferLength,
|
|
|
|
FALSE,
|
|
|
|
FALSE,
|
|
|
|
Irp);
|
|
|
|
if (!Irp->MdlAddress)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Free the IRP and fail */
|
|
|
|
IoFreeIrp(Irp);
|
|
|
|
return NULL;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2006-06-30 03:48:03 +00:00
|
|
|
|
|
|
|
/* Probe and Lock */
|
2008-11-24 13:40:26 +00:00
|
|
|
_SEH2_TRY
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Do the probe */
|
|
|
|
MmProbeAndLockPages(Irp->MdlAddress,
|
|
|
|
KernelMode,
|
|
|
|
IO_METHOD_FROM_CTL_CODE(IoControlCode) ==
|
|
|
|
METHOD_IN_DIRECT ?
|
|
|
|
IoReadAccess : IoWriteAccess);
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2008-11-24 13:40:26 +00:00
|
|
|
_SEH2_EXCEPT(EXCEPTION_EXECUTE_HANDLER)
|
2006-06-30 03:48:03 +00:00
|
|
|
{
|
|
|
|
/* Free the MDL */
|
|
|
|
IoFreeMdl(Irp->MdlAddress);
|
2005-05-01 19:30:06 +00:00
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Free the input buffer and IRP */
|
|
|
|
if (InputBuffer) ExFreePool(Irp->AssociatedIrp.SystemBuffer);
|
|
|
|
IoFreeIrp(Irp);
|
2009-08-26 17:31:02 +00:00
|
|
|
|
|
|
|
/* Fail */
|
|
|
|
_SEH2_YIELD(return NULL);
|
2006-06-30 03:48:03 +00:00
|
|
|
}
|
2008-11-24 13:40:26 +00:00
|
|
|
_SEH2_END;
|
2006-06-30 03:48:03 +00:00
|
|
|
}
|
|
|
|
break;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
|
|
|
|
case METHOD_NEITHER:
|
|
|
|
|
2006-06-30 03:48:03 +00:00
|
|
|
/* Just save the Buffer */
|
|
|
|
Irp->UserBuffer = OutputBuffer;
|
|
|
|
StackPtr->Parameters.DeviceIoControl.Type3InputBuffer = InputBuffer;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2005-05-01 19:30:06 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Now write the Event and IoSB */
|
|
|
|
Irp->UserIosb = IoStatusBlock;
|
|
|
|
Irp->UserEvent = Event;
|
2004-08-10 06:26:42 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Sync IRPs are queued to requestor thread's irp cancel/cleanup list */
|
|
|
|
Irp->Tail.Overlay.Thread = PsGetCurrentThread();
|
|
|
|
IoQueueThreadIrp(Irp);
|
2005-05-01 19:30:06 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Return the IRP */
|
2006-06-30 03:48:03 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Built IRP %p with IOCTL, Buffers, DO %lx %p %p %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp,
|
|
|
|
IoControlCode,
|
|
|
|
InputBuffer,
|
|
|
|
OutputBuffer,
|
|
|
|
DeviceObject);
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
return Irp;
|
1999-01-13 03:00:06 +00:00
|
|
|
}
|
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
1999-01-13 03:00:06 +00:00
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
PIRP
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 03:48:03 +00:00
|
|
|
IoBuildSynchronousFsdRequest(IN ULONG MajorFunction,
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PVOID Buffer,
|
|
|
|
IN ULONG Length,
|
|
|
|
IN PLARGE_INTEGER StartingOffset,
|
|
|
|
IN PKEVENT Event,
|
|
|
|
IN PIO_STATUS_BLOCK IoStatusBlock)
|
1999-01-13 03:00:06 +00:00
|
|
|
{
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
PIRP Irp;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Do the big work to set up the IRP */
|
|
|
|
Irp = IoBuildAsynchronousFsdRequest(MajorFunction,
|
|
|
|
DeviceObject,
|
|
|
|
Buffer,
|
|
|
|
Length,
|
|
|
|
StartingOffset,
|
|
|
|
IoStatusBlock );
|
2006-06-30 03:48:03 +00:00
|
|
|
if (!Irp) return NULL;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2010-03-29 08:51:12 +00:00
|
|
|
/* Set the Event which makes it Syncronous */
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
Irp->UserEvent = Event;
|
1999-01-13 03:00:06 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Sync IRPs are queued to requestor thread's irp cancel/cleanup list */
|
|
|
|
IoQueueThreadIrp(Irp);
|
2006-06-30 19:37:45 +00:00
|
|
|
return Irp;
|
1999-01-13 03:00:06 +00:00
|
|
|
}
|
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
BOOLEAN
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 04:29:32 +00:00
|
|
|
IoCancelIrp(IN PIRP Irp)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2006-06-30 04:29:32 +00:00
|
|
|
KIRQL OldIrql;
|
|
|
|
PDRIVER_CANCEL CancelRoutine;
|
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Canceling IRP %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp);
|
2006-07-02 16:20:10 +00:00
|
|
|
ASSERT(Irp->Type == IO_TYPE_IRP);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-07-02 16:20:10 +00:00
|
|
|
/* Acquire the cancel lock and cancel the IRP */
|
2006-06-30 04:29:32 +00:00
|
|
|
IoAcquireCancelSpinLock(&OldIrql);
|
|
|
|
Irp->Cancel = TRUE;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 04:29:32 +00:00
|
|
|
/* Clear the cancel routine and get the old one */
|
2017-04-05 14:00:03 +00:00
|
|
|
CancelRoutine = IoSetCancelRoutine(Irp, NULL);
|
2006-06-30 04:29:32 +00:00
|
|
|
if (CancelRoutine)
|
|
|
|
{
|
|
|
|
/* We had a routine, make sure the IRP isn't completed */
|
|
|
|
if (Irp->CurrentLocation > (Irp->StackCount + 1))
|
|
|
|
{
|
|
|
|
/* It is, bugcheck */
|
|
|
|
KeBugCheckEx(CANCEL_STATE_IN_COMPLETED_IRP,
|
|
|
|
(ULONG_PTR)Irp,
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
(ULONG_PTR)CancelRoutine,
|
2006-06-30 04:29:32 +00:00
|
|
|
0,
|
|
|
|
0);
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 04:29:32 +00:00
|
|
|
/* Set the cancel IRQL And call the routine */
|
|
|
|
Irp->CancelIrql = OldIrql;
|
|
|
|
CancelRoutine(IoGetCurrentIrpStackLocation(Irp)->DeviceObject, Irp);
|
|
|
|
return TRUE;
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 04:29:32 +00:00
|
|
|
/* Otherwise, release the cancel lock and fail */
|
|
|
|
IoReleaseCancelSpinLock(OldIrql);
|
|
|
|
return FALSE;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
|
|
|
|
2006-06-29 23:01:09 +00:00
|
|
|
/*
|
2006-06-30 04:29:32 +00:00
|
|
|
* @implemented
|
1999-01-13 03:00:06 +00:00
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 04:29:32 +00:00
|
|
|
IoCancelThreadIo(IN PETHREAD Thread)
|
1999-01-13 03:00:06 +00:00
|
|
|
{
|
2005-06-04 21:07:00 +00:00
|
|
|
KIRQL OldIrql;
|
|
|
|
ULONG Retries = 3000;
|
|
|
|
LARGE_INTEGER Interval;
|
2006-07-02 18:47:54 +00:00
|
|
|
PLIST_ENTRY ListHead, NextEntry;
|
|
|
|
PIRP Irp;
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
PAGED_CODE();
|
|
|
|
|
|
|
|
/* Windows isn't using given thread, but using current. */
|
|
|
|
Thread = PsGetCurrentThread();
|
|
|
|
|
2006-06-30 04:29:32 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Canceling IRPs for Thread %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Thread);
|
2004-10-22 20:43:58 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Raise to APC to protect the IrpList */
|
2008-02-07 07:10:13 +00:00
|
|
|
KeRaiseIrql(APC_LEVEL, &OldIrql);
|
2002-04-10 09:58:45 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Start by cancelling all the IRPs in the current thread queue. */
|
2006-07-02 16:20:10 +00:00
|
|
|
ListHead = &Thread->IrpList;
|
|
|
|
NextEntry = ListHead->Flink;
|
|
|
|
while (ListHead != NextEntry)
|
2005-06-04 21:07:00 +00:00
|
|
|
{
|
2010-08-15 08:48:03 +00:00
|
|
|
/* Get the IRP */
|
2006-07-02 16:20:10 +00:00
|
|
|
Irp = CONTAINING_RECORD(NextEntry, IRP, ThreadListEntry);
|
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Cancel it */
|
|
|
|
IoCancelIrp(Irp);
|
2010-08-15 08:48:03 +00:00
|
|
|
|
|
|
|
/* Move to the next entry */
|
|
|
|
NextEntry = NextEntry->Flink;
|
2005-06-04 21:07:00 +00:00
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Wait 100 milliseconds */
|
|
|
|
Interval.QuadPart = -1000000;
|
2004-10-22 20:43:58 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Wait till all the IRPs are completed or cancelled. */
|
|
|
|
while (!IsListEmpty(&Thread->IrpList))
|
|
|
|
{
|
|
|
|
/* Now we can lower */
|
2008-02-07 07:10:13 +00:00
|
|
|
KeLowerIrql(OldIrql);
|
2003-01-25 16:16:54 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Wait a short while and then look if all our IRPs were completed. */
|
|
|
|
KeDelayExecutionThread(KernelMode, FALSE, &Interval);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/*
|
|
|
|
* Don't stay here forever if some broken driver doesn't complete
|
|
|
|
* the IRP.
|
|
|
|
*/
|
2008-08-23 16:30:14 +00:00
|
|
|
if (!(Retries--))
|
|
|
|
{
|
|
|
|
/* Print out a message and remove the IRP */
|
|
|
|
DPRINT1("Broken driver did not complete!\n");
|
[FASTFAT]
Make our FAT driver PNP aware.
On PNP requests it should handle, it will return STATUS_NOT_IMPLEMENTED.
On the others, it will pass them to lower driver.
This is the first step outside the kernel into getting IoGetRelatedTargetDevice (and so notifications) working.
It doesn't work at the moment, as class2 doesn't handle PNP.
[NTOSKRNL]
Some fixes to IRP cancelation process:
- Renamed IopRemoveThreadIrp() to IopDisassociateThreadIrp() to match Windows 2k3
- Made dead IRP global, to make its debug easier.
- IopDisassociateThreadIrp(), Handle dead IRP at dispatch level, using IoCompletionLock.
- IopDisassociateThreadIrp(), Use the proper error code to write the entry to logs.
- IoCancelIrp(), removed non needed ASSERT, which is even not present on Windows, removed corresponding var as well.
- IoCancelIrp(), fixed parameters to KeBugCheckEx() call.
- IoCancelThreadIo() is pageable.
- IoCancelThreadIo() under Windows isn't using given thread, but using current. Do the same here.
All that stuff doesn't fix bug #5550, it comes from outside.
Patch by Pierre Schweitzer, modified by me to make it compile. If it breaks anything, don't blame me!
svn path=/trunk/; revision=48560
2010-08-18 23:21:15 +00:00
|
|
|
IopDisassociateThreadIrp();
|
2008-08-23 16:30:14 +00:00
|
|
|
}
|
2003-05-16 12:03:11 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* Raise the IRQL Again */
|
2008-02-07 07:10:13 +00:00
|
|
|
KeRaiseIrql(APC_LEVEL, &OldIrql);
|
2005-06-04 21:07:00 +00:00
|
|
|
}
|
2006-06-30 04:29:32 +00:00
|
|
|
|
2005-06-04 21:07:00 +00:00
|
|
|
/* We're done, lower the IRQL */
|
2008-02-07 07:10:13 +00:00
|
|
|
KeLowerIrql(OldIrql);
|
1999-01-13 03:00:06 +00:00
|
|
|
}
|
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2012-03-05 20:43:47 +00:00
|
|
|
#undef IoCallDriver
|
2000-03-06 01:02:30 +00:00
|
|
|
NTSTATUS
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 05:45:02 +00:00
|
|
|
IoCallDriver(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp)
|
2000-03-06 01:02:30 +00:00
|
|
|
{
|
2008-08-23 16:30:14 +00:00
|
|
|
/* Call fastcall */
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
return IofCallDriver(DeviceObject, Irp);
|
2000-03-06 01:02:30 +00:00
|
|
|
}
|
|
|
|
|
2012-03-05 20:43:47 +00:00
|
|
|
#define IoCallDriver IofCallDriver
|
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2012-03-05 20:43:47 +00:00
|
|
|
#undef IoCompleteRequest
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 05:45:02 +00:00
|
|
|
IoCompleteRequest(IN PIRP Irp,
|
|
|
|
IN CCHAR PriorityBoost)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
|
|
|
/* Call the fastcall */
|
|
|
|
IofCompleteRequest(Irp, PriorityBoost);
|
|
|
|
}
|
|
|
|
|
2012-03-05 20:43:47 +00:00
|
|
|
#define IoCompleteRequest IofCompleteRequest
|
|
|
|
|
1999-01-13 03:00:06 +00:00
|
|
|
/*
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
* @implemented
|
1999-01-13 03:00:06 +00:00
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoEnqueueIrp(IN PIRP Irp)
|
1999-01-13 03:00:06 +00:00
|
|
|
{
|
2006-06-30 04:29:32 +00:00
|
|
|
/* This is the same as calling IoQueueThreadIrp */
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoQueueThreadIrp(Irp);
|
|
|
|
}
|
1999-01-28 21:41:05 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
NTSTATUS
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
FASTCALL
|
2006-06-30 05:45:02 +00:00
|
|
|
IofCallDriver(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
|
|
|
PDRIVER_OBJECT DriverObject;
|
2008-08-23 16:30:14 +00:00
|
|
|
PIO_STACK_LOCATION StackPtr;
|
2002-04-10 09:58:45 +00:00
|
|
|
|
2009-10-20 16:47:01 +00:00
|
|
|
/* Make sure this is a valid IRP */
|
|
|
|
ASSERT(Irp->Type == IO_TYPE_IRP);
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Get the Driver Object */
|
|
|
|
DriverObject = DeviceObject->DriverObject;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 04:29:32 +00:00
|
|
|
/* Decrease the current location and check if */
|
|
|
|
Irp->CurrentLocation--;
|
|
|
|
if (Irp->CurrentLocation <= 0)
|
|
|
|
{
|
|
|
|
/* This IRP ran out of stack, bugcheck */
|
|
|
|
KeBugCheckEx(NO_MORE_IRP_STACK_LOCATIONS, (ULONG_PTR)Irp, 0, 0, 0);
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 04:29:32 +00:00
|
|
|
/* Now update the stack location */
|
2008-08-23 16:30:14 +00:00
|
|
|
StackPtr = IoGetNextIrpStackLocation(Irp);
|
|
|
|
Irp->Tail.Overlay.CurrentStackLocation = StackPtr;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
|
|
|
|
/* Get the Device Object */
|
2008-08-23 16:30:14 +00:00
|
|
|
StackPtr->DeviceObject = DeviceObject;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Call it */
|
2008-08-23 16:30:14 +00:00
|
|
|
return DriverObject->MajorFunction[StackPtr->MajorFunction](DeviceObject,
|
|
|
|
Irp);
|
1999-01-13 03:00:06 +00:00
|
|
|
}
|
|
|
|
|
2007-03-05 00:47:19 +00:00
|
|
|
FORCEINLINE
|
|
|
|
VOID
|
|
|
|
IopClearStackLocation(IN PIO_STACK_LOCATION IoStackLocation)
|
|
|
|
{
|
|
|
|
IoStackLocation->MinorFunction = 0;
|
|
|
|
IoStackLocation->Flags = 0;
|
|
|
|
IoStackLocation->Control &= SL_ERROR_RETURNED;
|
|
|
|
IoStackLocation->Parameters.Others.Argument1 = 0;
|
|
|
|
IoStackLocation->Parameters.Others.Argument2 = 0;
|
|
|
|
IoStackLocation->Parameters.Others.Argument3 = 0;
|
|
|
|
IoStackLocation->FileObject = NULL;
|
|
|
|
}
|
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
1999-01-13 03:00:06 +00:00
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2005-05-07 01:13:04 +00:00
|
|
|
FASTCALL
|
2006-06-30 03:15:56 +00:00
|
|
|
IofCompleteRequest(IN PIRP Irp,
|
|
|
|
IN CCHAR PriorityBoost)
|
1999-01-13 03:00:06 +00:00
|
|
|
{
|
2007-03-05 00:47:19 +00:00
|
|
|
PIO_STACK_LOCATION StackPtr, LastStackPtr;
|
2005-05-07 01:13:04 +00:00
|
|
|
PDEVICE_OBJECT DeviceObject;
|
2006-06-30 03:15:56 +00:00
|
|
|
PFILE_OBJECT FileObject;
|
|
|
|
PETHREAD Thread;
|
2005-05-07 01:13:04 +00:00
|
|
|
NTSTATUS Status;
|
2007-03-05 00:47:19 +00:00
|
|
|
PMDL Mdl, NextMdl;
|
|
|
|
ULONG MasterCount;
|
2006-06-30 03:15:56 +00:00
|
|
|
PIRP MasterIrp;
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
ULONG Flags;
|
2007-03-05 00:47:19 +00:00
|
|
|
NTSTATUS ErrorCode = STATUS_SUCCESS;
|
2014-12-16 21:15:57 +00:00
|
|
|
PREPARSE_DATA_BUFFER DataBuffer = NULL;
|
2006-06-30 03:15:56 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Completing IRP %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp);
|
2004-08-12 16:43:12 +00:00
|
|
|
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
/* Make sure this IRP isn't getting completed twice or is invalid */
|
2007-03-05 00:47:19 +00:00
|
|
|
if ((Irp->CurrentLocation) > (Irp->StackCount + 1))
|
2006-06-30 03:15:56 +00:00
|
|
|
{
|
|
|
|
/* Bugcheck */
|
|
|
|
KeBugCheckEx(MULTIPLE_IRP_COMPLETE_REQUESTS, (ULONG_PTR)Irp, 0, 0, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Some sanity checks */
|
2007-03-05 00:47:19 +00:00
|
|
|
ASSERT(Irp->Type == IO_TYPE_IRP);
|
2005-05-07 01:13:04 +00:00
|
|
|
ASSERT(!Irp->CancelRoutine);
|
|
|
|
ASSERT(Irp->IoStatus.Status != STATUS_PENDING);
|
2008-12-03 17:28:59 +00:00
|
|
|
ASSERT(Irp->IoStatus.Status != (NTSTATUS)0xFFFFFFFF);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Get the last stack */
|
|
|
|
LastStackPtr = (PIO_STACK_LOCATION)(Irp + 1);
|
|
|
|
if (LastStackPtr->Control & SL_ERROR_RETURNED)
|
|
|
|
{
|
|
|
|
/* Get the error code */
|
2010-01-13 22:35:43 +00:00
|
|
|
ErrorCode = PtrToUlong(LastStackPtr->Parameters.Others.Argument4);
|
2007-03-05 00:47:19 +00:00
|
|
|
}
|
|
|
|
|
2010-05-29 16:00:43 +00:00
|
|
|
/*
|
|
|
|
* Start the loop with the current stack and point the IRP to the next stack
|
|
|
|
* and then keep incrementing the stack as we loop through. The IRP should
|
|
|
|
* always point to the next stack location w.r.t the one currently being
|
|
|
|
* analyzed, so completion routine code will see the appropriate value.
|
|
|
|
* Because of this, we must loop until the current stack location is +1 of
|
|
|
|
* the stack count, because when StackPtr is at the end, CurrentLocation is +1.
|
|
|
|
*/
|
|
|
|
for (StackPtr = IoGetCurrentIrpStackLocation(Irp),
|
|
|
|
Irp->CurrentLocation++,
|
|
|
|
Irp->Tail.Overlay.CurrentStackLocation++;
|
|
|
|
Irp->CurrentLocation <= (Irp->StackCount + 1);
|
|
|
|
StackPtr++,
|
|
|
|
Irp->CurrentLocation++,
|
|
|
|
Irp->Tail.Overlay.CurrentStackLocation++)
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
|
|
|
/* Set Pending Returned */
|
|
|
|
Irp->PendingReturned = StackPtr->Control & SL_PENDING_RETURNED;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Check if we failed */
|
|
|
|
if (!NT_SUCCESS(Irp->IoStatus.Status))
|
|
|
|
{
|
|
|
|
/* Check if it was changed by a completion routine */
|
|
|
|
if (Irp->IoStatus.Status != ErrorCode)
|
|
|
|
{
|
|
|
|
/* Update the error for the current stack */
|
|
|
|
ErrorCode = Irp->IoStatus.Status;
|
|
|
|
StackPtr->Control |= SL_ERROR_RETURNED;
|
2010-01-13 22:35:43 +00:00
|
|
|
LastStackPtr->Parameters.Others.Argument4 = UlongToPtr(ErrorCode);
|
2007-03-05 00:47:19 +00:00
|
|
|
LastStackPtr->Control |= SL_ERROR_RETURNED;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Check if there is a Completion Routine to Call */
|
2005-05-09 01:38:29 +00:00
|
|
|
if ((NT_SUCCESS(Irp->IoStatus.Status) &&
|
2005-05-07 01:13:04 +00:00
|
|
|
(StackPtr->Control & SL_INVOKE_ON_SUCCESS)) ||
|
2005-05-09 01:38:29 +00:00
|
|
|
(!NT_SUCCESS(Irp->IoStatus.Status) &&
|
2005-05-07 01:13:04 +00:00
|
|
|
(StackPtr->Control & SL_INVOKE_ON_ERROR)) ||
|
2007-03-05 00:47:19 +00:00
|
|
|
(Irp->Cancel &&
|
|
|
|
(StackPtr->Control & SL_INVOKE_ON_CANCEL)))
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Clear the stack location */
|
|
|
|
IopClearStackLocation(StackPtr);
|
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Check for highest-level device completion routines */
|
|
|
|
if (Irp->CurrentLocation == (Irp->StackCount + 1))
|
|
|
|
{
|
|
|
|
/* Clear the DO, since the current stack location is invalid */
|
|
|
|
DeviceObject = NULL;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Otherwise, return the real one */
|
|
|
|
DeviceObject = IoGetCurrentIrpStackLocation(Irp)->DeviceObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Call the completion routine */
|
2005-05-07 01:13:04 +00:00
|
|
|
Status = StackPtr->CompletionRoutine(DeviceObject,
|
|
|
|
Irp,
|
|
|
|
StackPtr->Context);
|
2004-06-06 08:36:31 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Don't touch the Packet in this case, since it might be gone! */
|
2005-05-07 01:13:04 +00:00
|
|
|
if (Status == STATUS_MORE_PROCESSING_REQUIRED) return;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Otherwise, check if this is a completed IRP */
|
|
|
|
if ((Irp->CurrentLocation <= Irp->StackCount) &&
|
|
|
|
(Irp->PendingReturned))
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Mark it as pending */
|
2005-07-29 13:28:34 +00:00
|
|
|
IoMarkIrpPending(Irp);
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
2007-03-05 00:47:19 +00:00
|
|
|
|
|
|
|
/* Clear the stack location */
|
|
|
|
IopClearStackLocation(StackPtr);
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
2010-05-29 16:00:43 +00:00
|
|
|
}
|
2004-10-22 20:43:58 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Check if the IRP is an associated IRP */
|
2005-05-07 01:13:04 +00:00
|
|
|
if (Irp->Flags & IRP_ASSOCIATED_IRP)
|
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Get the master IRP and count */
|
|
|
|
MasterIrp = Irp->AssociatedIrp.MasterIrp;
|
2007-03-05 00:47:19 +00:00
|
|
|
MasterCount = InterlockedDecrement(&MasterIrp->AssociatedIrp.IrpCount);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Free the MDLs */
|
2007-03-05 00:47:19 +00:00
|
|
|
for (Mdl = Irp->MdlAddress; Mdl; Mdl = NextMdl)
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Go to the next one */
|
2007-03-05 00:47:19 +00:00
|
|
|
NextMdl = Mdl->Next;
|
2005-05-07 01:13:04 +00:00
|
|
|
IoFreeMdl(Mdl);
|
|
|
|
}
|
2006-06-30 03:15:56 +00:00
|
|
|
|
|
|
|
/* Free the IRP itself */
|
2005-05-07 01:13:04 +00:00
|
|
|
IoFreeIrp(Irp);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Complete the Master IRP */
|
2007-03-05 00:47:19 +00:00
|
|
|
if (!MasterCount) IofCompleteRequest(MasterIrp, PriorityBoost);
|
2005-05-07 01:13:04 +00:00
|
|
|
return;
|
|
|
|
}
|
2004-04-20 19:04:11 +00:00
|
|
|
|
2014-12-08 20:44:19 +00:00
|
|
|
/* Check whether we have to reparse */
|
|
|
|
if (Irp->IoStatus.Status == STATUS_REPARSE)
|
|
|
|
{
|
|
|
|
if (Irp->IoStatus.Information > IO_REMOUNT)
|
|
|
|
{
|
|
|
|
/* If that's a reparse tag we understand, save the buffer from deletion */
|
|
|
|
if (Irp->IoStatus.Information == IO_REPARSE_TAG_MOUNT_POINT)
|
|
|
|
{
|
|
|
|
ASSERT(Irp->Tail.Overlay.AuxiliaryBuffer != NULL);
|
|
|
|
DataBuffer = (PREPARSE_DATA_BUFFER)Irp->Tail.Overlay.AuxiliaryBuffer;
|
|
|
|
Irp->Tail.Overlay.AuxiliaryBuffer = NULL;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Irp->IoStatus.Status = STATUS_IO_REPARSE_TAG_NOT_HANDLED;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Check if we have an auxiliary buffer */
|
|
|
|
if (Irp->Tail.Overlay.AuxiliaryBuffer)
|
|
|
|
{
|
|
|
|
/* Free it */
|
|
|
|
ExFreePool(Irp->Tail.Overlay.AuxiliaryBuffer);
|
|
|
|
Irp->Tail.Overlay.AuxiliaryBuffer = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Check if this is a Paging I/O or Close Operation */
|
|
|
|
if (Irp->Flags & (IRP_PAGING_IO | IRP_CLOSE_OPERATION))
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2007-03-05 00:47:19 +00:00
|
|
|
/* Handle a Close Operation or Sync Paging I/O */
|
2005-05-07 01:13:04 +00:00
|
|
|
if (Irp->Flags & (IRP_SYNCHRONOUS_PAGING_IO | IRP_CLOSE_OPERATION))
|
|
|
|
{
|
|
|
|
/* Set the I/O Status and Signal the Event */
|
2007-03-05 00:47:19 +00:00
|
|
|
Flags = Irp->Flags & (IRP_SYNCHRONOUS_PAGING_IO | IRP_PAGING_IO);
|
2005-05-07 01:13:04 +00:00
|
|
|
*Irp->UserIosb = Irp->IoStatus;
|
|
|
|
KeSetEvent(Irp->UserEvent, PriorityBoost, FALSE);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Free the IRP for a Paging I/O Only, Close is handled by us */
|
2018-02-24 13:50:23 +00:00
|
|
|
if (Flags)
|
|
|
|
{
|
|
|
|
/* If we were using the reserve IRP, then call the appropriate
|
|
|
|
* free function (to make the IRP available again)
|
|
|
|
*/
|
|
|
|
if (Irp == IopReserveIrpAllocator.ReserveIrp)
|
|
|
|
{
|
|
|
|
IopFreeReserveIrp(PriorityBoost);
|
|
|
|
}
|
|
|
|
/* Otherwise, free for real! */
|
|
|
|
else
|
|
|
|
{
|
|
|
|
IoFreeIrp(Irp);
|
|
|
|
}
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
}
|
2005-05-07 01:13:04 +00:00
|
|
|
else
|
|
|
|
{
|
2005-07-29 13:28:34 +00:00
|
|
|
#if 0
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Page 166 */
|
|
|
|
KeInitializeApc(&Irp->Tail.Apc
|
2005-07-29 13:28:34 +00:00
|
|
|
&Irp->Tail.Overlay.Thread->Tcb,
|
2005-05-07 01:13:04 +00:00
|
|
|
Irp->ApcEnvironment,
|
|
|
|
IopCompletePageWrite,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
KernelMode,
|
|
|
|
NULL);
|
|
|
|
KeInsertQueueApc(&Irp->Tail.Apc,
|
2003-12-31 14:16:18 +00:00
|
|
|
NULL,
|
2005-05-07 01:13:04 +00:00
|
|
|
NULL,
|
|
|
|
PriorityBoost);
|
2005-07-29 13:28:34 +00:00
|
|
|
#else
|
|
|
|
/* Not implemented yet. */
|
2013-01-07 22:11:06 +00:00
|
|
|
UNIMPLEMENTED_DBGBREAK("Not supported!\n");
|
2005-07-29 13:28:34 +00:00
|
|
|
#endif
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
2006-06-30 03:15:56 +00:00
|
|
|
|
|
|
|
/* Get out of here */
|
2005-05-07 01:13:04 +00:00
|
|
|
return;
|
|
|
|
}
|
2003-12-31 14:16:18 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Unlock MDL Pages, page 167. */
|
2005-05-08 16:02:38 +00:00
|
|
|
Mdl = Irp->MdlAddress;
|
|
|
|
while (Mdl)
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2014-12-08 20:44:19 +00:00
|
|
|
MmUnlockPages(Mdl);
|
2006-06-29 23:01:09 +00:00
|
|
|
Mdl = Mdl->Next;
|
2005-05-09 01:38:29 +00:00
|
|
|
}
|
2003-12-31 14:16:18 +00:00
|
|
|
|
2005-05-07 01:13:04 +00:00
|
|
|
/* Check if we should exit because of a Deferred I/O (page 168) */
|
2006-06-30 03:15:56 +00:00
|
|
|
if ((Irp->Flags & IRP_DEFER_IO_COMPLETION) && !(Irp->PendingReturned))
|
2005-05-07 01:13:04 +00:00
|
|
|
{
|
2014-12-08 20:44:19 +00:00
|
|
|
/* Restore the saved reparse buffer for the caller */
|
|
|
|
if (Irp->IoStatus.Status == STATUS_REPARSE &&
|
|
|
|
Irp->IoStatus.Information == IO_REPARSE_TAG_MOUNT_POINT)
|
|
|
|
{
|
|
|
|
Irp->Tail.Overlay.AuxiliaryBuffer = (PCHAR)DataBuffer;
|
|
|
|
}
|
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/*
|
|
|
|
* Return without queuing the completion APC, since the caller will
|
|
|
|
* take care of doing its own optimized completion at PASSIVE_LEVEL.
|
|
|
|
*/
|
2005-05-07 01:13:04 +00:00
|
|
|
return;
|
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Get the thread and file object */
|
|
|
|
Thread = Irp->Tail.Overlay.Thread;
|
|
|
|
FileObject = Irp->Tail.Overlay.OriginalFileObject;
|
|
|
|
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
/* Make sure the IRP isn't canceled */
|
2005-05-07 01:13:04 +00:00
|
|
|
if (!Irp->Cancel)
|
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Initialize the APC */
|
2005-05-07 01:13:04 +00:00
|
|
|
KeInitializeApc(&Irp->Tail.Apc,
|
|
|
|
&Thread->Tcb,
|
|
|
|
Irp->ApcEnvironment,
|
|
|
|
IopCompleteRequest,
|
|
|
|
NULL,
|
2006-06-30 03:15:56 +00:00
|
|
|
NULL,
|
2005-05-07 01:13:04 +00:00
|
|
|
KernelMode,
|
|
|
|
NULL);
|
2006-06-30 03:15:56 +00:00
|
|
|
|
|
|
|
/* Queue it */
|
2005-05-07 01:13:04 +00:00
|
|
|
KeInsertQueueApc(&Irp->Tail.Apc,
|
|
|
|
FileObject,
|
2014-12-08 20:44:19 +00:00
|
|
|
DataBuffer,
|
2005-05-07 01:13:04 +00:00
|
|
|
PriorityBoost);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
/* The IRP just got canceled... does a thread still own it? */
|
2006-06-30 03:15:56 +00:00
|
|
|
if (Thread)
|
2005-06-04 21:07:00 +00:00
|
|
|
{
|
2006-06-30 03:15:56 +00:00
|
|
|
/* Yes! There is still hope! Initialize the APC */
|
2005-06-04 21:07:00 +00:00
|
|
|
KeInitializeApc(&Irp->Tail.Apc,
|
|
|
|
&Thread->Tcb,
|
|
|
|
Irp->ApcEnvironment,
|
|
|
|
IopCompleteRequest,
|
|
|
|
NULL,
|
2006-06-30 03:15:56 +00:00
|
|
|
NULL,
|
2005-06-04 21:07:00 +00:00
|
|
|
KernelMode,
|
|
|
|
NULL);
|
2006-06-30 03:15:56 +00:00
|
|
|
|
|
|
|
/* Queue it */
|
2005-06-04 21:07:00 +00:00
|
|
|
KeInsertQueueApc(&Irp->Tail.Apc,
|
|
|
|
FileObject,
|
2014-12-08 20:44:19 +00:00
|
|
|
DataBuffer,
|
2005-06-04 21:07:00 +00:00
|
|
|
PriorityBoost);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Nothing left for us to do, kill it */
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
ASSERT(Irp->Cancel);
|
2005-06-04 21:07:00 +00:00
|
|
|
IopCleanupIrp(Irp, FileObject);
|
|
|
|
}
|
2005-05-07 01:13:04 +00:00
|
|
|
}
|
1999-01-13 03:00:06 +00:00
|
|
|
}
|
|
|
|
|
2007-12-03 09:03:38 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
2008-08-23 16:30:14 +00:00
|
|
|
IopSynchronousCompletion(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp,
|
|
|
|
IN PVOID Context)
|
2007-12-03 09:03:38 +00:00
|
|
|
{
|
|
|
|
if (Irp->PendingReturned)
|
|
|
|
KeSetEvent((PKEVENT)Context, IO_NO_INCREMENT, FALSE);
|
|
|
|
return STATUS_MORE_PROCESSING_REQUIRED;
|
|
|
|
}
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/*
|
2007-12-03 09:03:38 +00:00
|
|
|
* @implemented
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
*/
|
|
|
|
BOOLEAN
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoForwardIrpSynchronously(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp)
|
|
|
|
{
|
2007-12-03 09:03:38 +00:00
|
|
|
KEVENT Event;
|
|
|
|
NTSTATUS Status;
|
|
|
|
|
|
|
|
/* Check if next stack location is available */
|
2020-09-07 01:57:17 +00:00
|
|
|
if (Irp->CurrentLocation > Irp->StackCount || Irp->CurrentLocation <= 1)
|
2007-12-03 09:03:38 +00:00
|
|
|
{
|
|
|
|
/* No more stack location */
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Initialize event */
|
|
|
|
KeInitializeEvent(&Event, NotificationEvent, FALSE);
|
|
|
|
|
|
|
|
/* Copy stack location for next driver */
|
|
|
|
IoCopyCurrentIrpStackLocationToNext(Irp);
|
|
|
|
|
|
|
|
/* Set a completion routine, which will signal the event */
|
|
|
|
IoSetCompletionRoutine(Irp, IopSynchronousCompletion, &Event, TRUE, TRUE, TRUE);
|
|
|
|
|
|
|
|
/* Call next driver */
|
|
|
|
Status = IoCallDriver(DeviceObject, Irp);
|
|
|
|
|
|
|
|
/* Check if irp is pending */
|
|
|
|
if (Status == STATUS_PENDING)
|
|
|
|
{
|
|
|
|
/* Yes, wait for its completion */
|
|
|
|
KeWaitForSingleObject(&Event, Suspended, KernelMode, FALSE, NULL);
|
|
|
|
}
|
|
|
|
|
2008-08-23 16:30:14 +00:00
|
|
|
/* Return success */
|
2007-12-03 09:03:38 +00:00
|
|
|
return TRUE;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2000-03-06 01:02:30 +00:00
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 05:45:02 +00:00
|
|
|
IoFreeIrp(IN PIRP Irp)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
2005-05-13 04:49:54 +00:00
|
|
|
PNPAGED_LOOKASIDE_LIST List;
|
2016-09-03 21:25:45 +00:00
|
|
|
PP_NPAGED_LOOKASIDE_NUMBER ListType = LookasideSmallIrpList;
|
2005-05-13 04:49:54 +00:00
|
|
|
PKPRCB Prcb;
|
2006-06-30 04:29:32 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Freeing IRPs %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp);
|
|
|
|
|
|
|
|
/* Make sure the Thread IRP list is empty and that it OK to free it */
|
- Fix SleepEx.
- Put volatile statements in EX_RUNDOWN_REF, IRP, DEVICE_OBJECT, ERESOURCE, FILE_OBJECT, IO_REMOVE_LOCK, WORK_QUEUE_ITEM where required (thanks to Microsoft's changes in the WDK to mark the fields properly).
- Update FILE_OBJECT definition.
- Add some asserts to some I/O functions.
- Add stub support for File Objects created by XP+ Drivers which have File Object Extensions.
- Add some fixes to IopDeleteFile, including proper reference counting for the DO and VPB, as well as cleanup when the file is closed without a handle.
- Fix a bug in IopSecurityFile.
- Queue and unqueue IRPs in all I/O functions.
- Fully support IRP cancellation now.
- Fix critical bugs in NtDeviceIoControlFile and NtDeviceFsControlFile which were causing double queueing of IRPs and freeing of invalid memory, as well as invalid paramter checking for user-mode buffers.
- Add exhaustive validation checks to IoCreateFile, add more failure cases, and validate the EA buffer. Also support IO_ATTACH_DEVICE_API flag.
- Implement IoCreateStreamFileObjectEx and IoCreateStreamFileObjectLite and fix several bugs in the original implementation of IoCreateStreamFileObject.
- Fix a bug in RtlRaiseException.
- Update Io*ShareAccess routines to support XP+ style semantics related to special File Object flags which disable their use.
- Add validation to all Query/Set routines so that information clasess, lengths, buffers and alignment are properly checked.
- Also add an array for the proper acess rights that each query/set operation requires.
- Check backup/restore privileges during I/O File operations.
- Check traverse access during I/O File Operations.
- Check access privileges to the device during I/O file operations.
- Rename IopReferenceDeviceObject and also verify if an exclusive DO is trying to be invalidly opened.
- Support various extra security checks during I/O File/Device Parse Routine.
- Fix a bug during IopCleanupIrp so that we don't dereference the File OBject if this was a create operation.
- Fix some bogus asserts in IofCompleteRequest, and save the IRP Flags before signalling it's event, since the driver might've freed it behind our back.
- Fix a large bug in ObInsertObject which affected the insert of unnamed objects with forced security options (Such as process/threads).
- Fix the creation of the Process/Thread/Job Obejct Types to that security information is forced.
- Remove "Fix PS!!!" messages since the bug is now fixed and these objects now get proper security descriptors.
- Fix another bug in ObInsertObjet which wasn't properly validating user-mode objects and always assumed kernel mode.
- Silence multiple trace/checkpoint messages that have accumulated throughout time for various debugging purposes.
svn path=/trunk/; revision=25118
2006-12-10 18:40:30 +00:00
|
|
|
ASSERT(Irp->Type == IO_TYPE_IRP);
|
2006-06-30 04:29:32 +00:00
|
|
|
ASSERT(IsListEmpty(&Irp->ThreadListEntry));
|
|
|
|
ASSERT(Irp->CurrentLocation >= Irp->StackCount);
|
|
|
|
|
2016-09-03 21:25:45 +00:00
|
|
|
/* Get the PRCB */
|
|
|
|
Prcb = KeGetCurrentPrcb();
|
|
|
|
|
|
|
|
/* If this was a lookaside alloc, increment lookaside float */
|
|
|
|
if (Irp->AllocationFlags & IRP_LOOKASIDE_ALLOCATION)
|
|
|
|
{
|
|
|
|
Irp->AllocationFlags &= ~IRP_LOOKASIDE_ALLOCATION;
|
|
|
|
InterlockedIncrement(&Prcb->LookasideIrpFloat);
|
|
|
|
}
|
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* If this was a pool alloc, free it with the pool */
|
|
|
|
if (!(Irp->AllocationFlags & IRP_ALLOCATED_FIXED_SIZE))
|
|
|
|
{
|
|
|
|
/* Free it */
|
2008-08-31 15:29:21 +00:00
|
|
|
ExFreePoolWithTag(Irp, TAG_IRP);
|
2005-05-13 04:49:54 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Check if this was a Big IRP */
|
2006-06-30 04:29:32 +00:00
|
|
|
if (Irp->StackCount != 1) ListType = LookasideLargeIrpList;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Use the P List */
|
|
|
|
List = (PNPAGED_LOOKASIDE_LIST)Prcb->PPLookasideList[ListType].P;
|
|
|
|
List->L.TotalFrees++;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Check if the Free was within the Depth or not */
|
|
|
|
if (ExQueryDepthSList(&List->L.ListHead) >= List->L.Depth)
|
|
|
|
{
|
|
|
|
/* Let the balancer know */
|
|
|
|
List->L.FreeMisses++;
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2005-05-13 04:49:54 +00:00
|
|
|
/* Use the L List */
|
|
|
|
List = (PNPAGED_LOOKASIDE_LIST)Prcb->PPLookasideList[ListType].L;
|
|
|
|
List->L.TotalFrees++;
|
|
|
|
|
|
|
|
/* Check if the Free was within the Depth or not */
|
|
|
|
if (ExQueryDepthSList(&List->L.ListHead) >= List->L.Depth)
|
2006-06-29 23:01:09 +00:00
|
|
|
{
|
2005-05-13 04:49:54 +00:00
|
|
|
/* All lists failed, use the pool */
|
|
|
|
List->L.FreeMisses++;
|
2008-08-31 15:29:21 +00:00
|
|
|
ExFreePoolWithTag(Irp, TAG_IRP);
|
2005-05-15 13:59:57 +00:00
|
|
|
Irp = NULL;
|
2005-05-13 04:49:54 +00:00
|
|
|
}
|
|
|
|
}
|
2006-06-29 23:01:09 +00:00
|
|
|
|
2006-06-30 04:29:32 +00:00
|
|
|
/* The free was within the Depth */
|
2005-05-15 13:59:57 +00:00
|
|
|
if (Irp)
|
|
|
|
{
|
2016-09-14 12:45:45 +00:00
|
|
|
/* Remove the association with the process */
|
|
|
|
if (Irp->AllocationFlags & IRP_QUOTA_CHARGED)
|
|
|
|
{
|
|
|
|
ExReturnPoolQuota(Irp);
|
|
|
|
Irp->AllocationFlags &= ~IRP_QUOTA_CHARGED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Add it to the lookaside list */
|
2016-09-03 21:25:45 +00:00
|
|
|
InterlockedPushEntrySList(&List->L.ListHead,
|
|
|
|
(PSLIST_ENTRY)Irp);
|
2005-05-15 13:59:57 +00:00
|
|
|
}
|
2005-05-13 04:49:54 +00:00
|
|
|
}
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
|
|
|
|
- Export KeI386MachineType and KeInitializeThreadedDpc
- Stubplement and export IoEnumerateRegisteredFiltersList, IoGetPagingIoPriority, KdRefreshDebuggerNotPresent, KeAcquireInStackQueuedSpinLockForDpc, KeReleaseInStackQueuedSpinLockForDpc, KeAcquireSpinLockForDpc, KeReleaseSpinLockForDpc, KeRegisterNmiCallback, KeDeregisterNmiCallback, KeInitializeCrashDumpHeader, KeTestSpinLock and MmAllocatePagesForMdlEx
- Add IO_PAGING_PRIORITY enumeration and PNMI_CALLBACK prototype to headers
svn path=/trunk/; revision=35103
2008-08-04 15:48:46 +00:00
|
|
|
/*
|
2008-09-25 14:29:11 +00:00
|
|
|
* @implemented
|
- Export KeI386MachineType and KeInitializeThreadedDpc
- Stubplement and export IoEnumerateRegisteredFiltersList, IoGetPagingIoPriority, KdRefreshDebuggerNotPresent, KeAcquireInStackQueuedSpinLockForDpc, KeReleaseInStackQueuedSpinLockForDpc, KeAcquireSpinLockForDpc, KeReleaseSpinLockForDpc, KeRegisterNmiCallback, KeDeregisterNmiCallback, KeInitializeCrashDumpHeader, KeTestSpinLock and MmAllocatePagesForMdlEx
- Add IO_PAGING_PRIORITY enumeration and PNMI_CALLBACK prototype to headers
svn path=/trunk/; revision=35103
2008-08-04 15:48:46 +00:00
|
|
|
*/
|
|
|
|
IO_PAGING_PRIORITY
|
2008-09-25 14:29:11 +00:00
|
|
|
FASTCALL
|
- Export KeI386MachineType and KeInitializeThreadedDpc
- Stubplement and export IoEnumerateRegisteredFiltersList, IoGetPagingIoPriority, KdRefreshDebuggerNotPresent, KeAcquireInStackQueuedSpinLockForDpc, KeReleaseInStackQueuedSpinLockForDpc, KeAcquireSpinLockForDpc, KeReleaseSpinLockForDpc, KeRegisterNmiCallback, KeDeregisterNmiCallback, KeInitializeCrashDumpHeader, KeTestSpinLock and MmAllocatePagesForMdlEx
- Add IO_PAGING_PRIORITY enumeration and PNMI_CALLBACK prototype to headers
svn path=/trunk/; revision=35103
2008-08-04 15:48:46 +00:00
|
|
|
IoGetPagingIoPriority(IN PIRP Irp)
|
|
|
|
{
|
2008-09-25 14:29:11 +00:00
|
|
|
IO_PAGING_PRIORITY Priority;
|
|
|
|
ULONG Flags;
|
|
|
|
|
|
|
|
/* Get the flags */
|
|
|
|
Flags = Irp->Flags;
|
|
|
|
|
|
|
|
/* Check what priority it has */
|
2010-08-16 20:18:25 +00:00
|
|
|
if (Flags & IRP_CLASS_CACHE_OPERATION)
|
2008-09-25 14:29:11 +00:00
|
|
|
{
|
|
|
|
/* High priority */
|
|
|
|
Priority = IoPagingPriorityHigh;
|
|
|
|
}
|
|
|
|
else if (Flags & IRP_PAGING_IO)
|
|
|
|
{
|
|
|
|
/* Normal priority */
|
|
|
|
Priority = IoPagingPriorityNormal;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Invalid -- not a paging IRP */
|
|
|
|
Priority = IoPagingPriorityInvalid;
|
|
|
|
}
|
- Export KeI386MachineType and KeInitializeThreadedDpc
- Stubplement and export IoEnumerateRegisteredFiltersList, IoGetPagingIoPriority, KdRefreshDebuggerNotPresent, KeAcquireInStackQueuedSpinLockForDpc, KeReleaseInStackQueuedSpinLockForDpc, KeAcquireSpinLockForDpc, KeReleaseSpinLockForDpc, KeRegisterNmiCallback, KeDeregisterNmiCallback, KeInitializeCrashDumpHeader, KeTestSpinLock and MmAllocatePagesForMdlEx
- Add IO_PAGING_PRIORITY enumeration and PNMI_CALLBACK prototype to headers
svn path=/trunk/; revision=35103
2008-08-04 15:48:46 +00:00
|
|
|
|
2008-09-25 14:29:11 +00:00
|
|
|
/* Return the priority */
|
|
|
|
return Priority;
|
- Export KeI386MachineType and KeInitializeThreadedDpc
- Stubplement and export IoEnumerateRegisteredFiltersList, IoGetPagingIoPriority, KdRefreshDebuggerNotPresent, KeAcquireInStackQueuedSpinLockForDpc, KeReleaseInStackQueuedSpinLockForDpc, KeAcquireSpinLockForDpc, KeReleaseSpinLockForDpc, KeRegisterNmiCallback, KeDeregisterNmiCallback, KeInitializeCrashDumpHeader, KeTestSpinLock and MmAllocatePagesForMdlEx
- Add IO_PAGING_PRIORITY enumeration and PNMI_CALLBACK prototype to headers
svn path=/trunk/; revision=35103
2008-08-04 15:48:46 +00:00
|
|
|
}
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2008-08-23 16:30:14 +00:00
|
|
|
PEPROCESS
|
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoGetRequestorProcess(IN PIRP Irp)
|
|
|
|
{
|
2008-08-23 16:30:14 +00:00
|
|
|
/* Return the requestor process */
|
2010-08-16 20:18:25 +00:00
|
|
|
if (Irp->Tail.Overlay.Thread)
|
|
|
|
{
|
2012-08-01 07:54:37 +00:00
|
|
|
if (Irp->ApcEnvironment == OriginalApcEnvironment)
|
|
|
|
{
|
|
|
|
return Irp->Tail.Overlay.Thread->ThreadsProcess;
|
|
|
|
}
|
|
|
|
else if (Irp->ApcEnvironment == AttachedApcEnvironment)
|
|
|
|
{
|
|
|
|
return (PEPROCESS)Irp->Tail.Overlay.Thread->Tcb.ApcState.Process;
|
|
|
|
}
|
2010-08-16 20:18:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
|
|
|
ULONG
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoGetRequestorProcessId(IN PIRP Irp)
|
|
|
|
{
|
2010-08-16 20:18:25 +00:00
|
|
|
PEPROCESS Process;
|
|
|
|
|
2008-08-23 16:30:14 +00:00
|
|
|
/* Return the requestor process' id */
|
2012-08-01 07:54:37 +00:00
|
|
|
Process = IoGetRequestorProcess(Irp);
|
|
|
|
if (Process) return PtrToUlong(Process->UniqueProcessId);
|
2010-08-16 20:18:25 +00:00
|
|
|
|
|
|
|
return 0;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
|
|
|
NTSTATUS
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoGetRequestorSessionId(IN PIRP Irp,
|
|
|
|
OUT PULONG pSessionId)
|
|
|
|
{
|
2010-08-16 20:18:25 +00:00
|
|
|
PEPROCESS Process;
|
|
|
|
|
2006-06-30 04:46:53 +00:00
|
|
|
/* Return the session */
|
2012-08-01 07:54:37 +00:00
|
|
|
if (Irp->Tail.Overlay.Thread)
|
2010-08-16 20:18:25 +00:00
|
|
|
{
|
2012-08-01 07:54:37 +00:00
|
|
|
Process = Irp->Tail.Overlay.Thread->ThreadsProcess;
|
|
|
|
*pSessionId = MmGetSessionId(Process);
|
2010-08-16 20:18:25 +00:00
|
|
|
return STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
*pSessionId = (ULONG)-1;
|
|
|
|
return STATUS_UNSUCCESSFUL;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
PIRP
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoGetTopLevelIrp(VOID)
|
2000-03-06 01:02:30 +00:00
|
|
|
{
|
2008-08-23 16:30:14 +00:00
|
|
|
/* Return the IRP */
|
2005-05-07 00:37:48 +00:00
|
|
|
return (PIRP)PsGetCurrentThread()->TopLevelIrp;
|
2000-03-06 01:02:30 +00:00
|
|
|
}
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 04:46:53 +00:00
|
|
|
IoInitializeIrp(IN PIRP Irp,
|
|
|
|
IN USHORT PacketSize,
|
|
|
|
IN CCHAR StackSize)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
|
|
|
/* Clear it */
|
2006-06-30 04:46:53 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Initializing IRP %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp);
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
RtlZeroMemory(Irp, PacketSize);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Set the Header and other data */
|
|
|
|
Irp->Type = IO_TYPE_IRP;
|
|
|
|
Irp->Size = PacketSize;
|
|
|
|
Irp->StackCount = StackSize;
|
2005-05-07 01:13:04 +00:00
|
|
|
Irp->CurrentLocation = StackSize + 1;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
Irp->ApcEnvironment = KeGetCurrentThread()->ApcStateIndex;
|
|
|
|
Irp->Tail.Overlay.CurrentStackLocation = (PIO_STACK_LOCATION)(Irp + 1) + StackSize;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Initialize the Thread List */
|
|
|
|
InitializeListHead(&Irp->ThreadListEntry);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2003-07-10 15:47:00 +00:00
|
|
|
* @implemented
|
2000-03-06 01:02:30 +00:00
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
BOOLEAN
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2002-04-10 09:58:45 +00:00
|
|
|
IoIsOperationSynchronous(IN PIRP Irp)
|
2000-03-06 01:02:30 +00:00
|
|
|
{
|
2010-12-29 11:12:17 +00:00
|
|
|
BOOLEAN SynchIO;
|
|
|
|
BOOLEAN ForceAsync;
|
|
|
|
|
|
|
|
/* If the IRP requests synchronous paging I/O, if the file object was opened
|
|
|
|
for synchronous I/O, if the IRP_SYNCHRONOUS_API flag is set in the IRP
|
|
|
|
the operation is synchronous */
|
|
|
|
SynchIO = (IoGetCurrentIrpStackLocation(Irp)->FileObject->Flags & FO_SYNCHRONOUS_IO) ||
|
|
|
|
(Irp->Flags & IRP_SYNCHRONOUS_API) || (Irp->Flags & IRP_SYNCHRONOUS_PAGING_IO);
|
|
|
|
|
|
|
|
/* If the IRP requests asynchronous paging I/O, the operation is asynchronous,
|
|
|
|
even if one of the above conditions is true */
|
|
|
|
ForceAsync = (Irp->Flags & IRP_PAGING_IO) && !(Irp->Flags & IRP_SYNCHRONOUS_PAGING_IO);
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Check the flags */
|
2010-12-29 11:12:17 +00:00
|
|
|
if (SynchIO && !ForceAsync)
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
{
|
|
|
|
/* Synch API or Paging I/O is OK, as is Sync File I/O */
|
|
|
|
return TRUE;
|
|
|
|
}
|
2002-04-10 09:58:45 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Otherwise, it is an asynchronous operation. */
|
|
|
|
return FALSE;
|
2000-03-06 01:02:30 +00:00
|
|
|
}
|
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
* @unimplemented
|
2003-07-10 15:47:00 +00:00
|
|
|
*/
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
BOOLEAN
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoIsValidNameGraftingBuffer(IN PIRP Irp,
|
|
|
|
IN PREPARSE_DATA_BUFFER ReparseBuffer)
|
2000-03-26 19:38:32 +00:00
|
|
|
{
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
UNIMPLEMENTED;
|
|
|
|
return FALSE;
|
2000-03-26 19:38:32 +00:00
|
|
|
}
|
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
PIRP
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2006-06-30 04:46:53 +00:00
|
|
|
IoMakeAssociatedIrp(IN PIRP Irp,
|
|
|
|
IN CCHAR StackSize)
|
2000-03-26 19:38:32 +00:00
|
|
|
{
|
2006-06-30 04:46:53 +00:00
|
|
|
PIRP AssocIrp;
|
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Associating IRP %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp);
|
2000-06-12 14:57:10 +00:00
|
|
|
|
2018-12-18 20:35:12 +00:00
|
|
|
/* Allocate the IRP */
|
|
|
|
AssocIrp = IoAllocateIrp(StackSize, FALSE);
|
|
|
|
if (!AssocIrp) return NULL;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
|
2018-12-18 20:35:12 +00:00
|
|
|
/* Set the Flags */
|
|
|
|
AssocIrp->Flags |= IRP_ASSOCIATED_IRP;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
|
2018-12-18 20:35:12 +00:00
|
|
|
/* Set the Thread */
|
|
|
|
AssocIrp->Tail.Overlay.Thread = Irp->Tail.Overlay.Thread;
|
2000-03-26 19:38:32 +00:00
|
|
|
|
2018-12-18 20:35:12 +00:00
|
|
|
/* Associate them */
|
|
|
|
AssocIrp->AssociatedIrp.MasterIrp = Irp;
|
|
|
|
return AssocIrp;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2000-03-26 19:38:32 +00:00
|
|
|
|
2003-07-10 15:47:00 +00:00
|
|
|
/*
|
2003-11-19 20:54:31 +00:00
|
|
|
* @implemented
|
2003-07-10 15:47:00 +00:00
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
2002-04-10 09:58:45 +00:00
|
|
|
IoQueueThreadIrp(IN PIRP Irp)
|
2000-03-26 19:38:32 +00:00
|
|
|
{
|
2006-06-30 04:46:53 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Queueing IRP %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2006-07-02 16:20:10 +00:00
|
|
|
/* Use our inlined routine */
|
|
|
|
IopQueueIrpToThread(Irp);
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2005-03-05 11:27:15 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
2005-05-09 01:38:29 +00:00
|
|
|
* Reference: Chris Cant's "Writing WDM Device Drivers"
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoReuseIrp(IN OUT PIRP Irp,
|
|
|
|
IN NTSTATUS Status)
|
|
|
|
{
|
|
|
|
UCHAR AllocationFlags;
|
2006-06-30 04:46:53 +00:00
|
|
|
IOTRACE(IO_IRP_DEBUG,
|
|
|
|
"%s - Reusing IRP %p\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
Irp);
|
|
|
|
|
|
|
|
/* Make sure it's OK to reuse it */
|
|
|
|
ASSERT(!Irp->CancelRoutine);
|
|
|
|
ASSERT(IsListEmpty(&Irp->ThreadListEntry));
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Get the old flags */
|
|
|
|
AllocationFlags = Irp->AllocationFlags;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Reinitialize the IRP */
|
|
|
|
IoInitializeIrp(Irp, Irp->Size, Irp->StackCount);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/* Duplicate the data */
|
|
|
|
Irp->IoStatus.Status = Status;
|
|
|
|
Irp->AllocationFlags = AllocationFlags;
|
2003-11-19 20:54:31 +00:00
|
|
|
}
|
|
|
|
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
|
|
|
VOID
|
2006-06-29 23:01:09 +00:00
|
|
|
NTAPI
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
IoSetTopLevelIrp(IN PIRP Irp)
|
|
|
|
{
|
2006-06-30 04:46:53 +00:00
|
|
|
/* Set the IRP */
|
2010-01-13 22:35:43 +00:00
|
|
|
PsGetCurrentThread()->TopLevelIrp = (ULONG_PTR)Irp;
|
IO Manager Cleanup continues:
- Removed many extra files that expanded the I/O Manager too much. We usually stick with the standard of
one object/class per file, like io/device.c or io/controller.c, so it was very confusing to have some
objects split up in 5 or 6 different files, some containing only one api. Additionally, even a third
system was used, were objects were bunched up together by class. This mess was so bad that NtCreateFile,
IopCreateFile, IoCreateFile, IopDeleteFile, NtDeleteFile and NtWriteFile were in 5 different files (as an
example).
- Cleaned up some IRP code and fixed a couple of bugs, mainly:
- Write I/O Type in IRP
- Write proper IRP Flags where they shoudl be used (Will help for completing requests when i clean up that code)
- Do *NOT* zero out buffers or data that shouldn't be zeroed. Scsiport actually dependen on this incorrect
behaviour. Code should never depend on a buffer being zeroed!
- Remove a lot of duplicated code and helper/alternate functions that weren't really useful.
- Free MDL and IRP on some failures where we didn't
- Alphabetized some of the large io files for easier lookup of functions. This and the deletions have resulted
in a completely bloated diff file. I will provide a cleaned up diff on request by manually downloading the
old revision and copy/pasting the new code directly above it. The functions which we touched are:
- IoAllocateIrp
- IoBuild[A]SyncronousFsdRequest
- IoBuildDeviceIoControlRequest
- IoInitializeIrp
- IoPageRead, IoSynchronousPageWrite
svn path=/trunk/; revision=14837
2005-04-28 00:54:59 +00:00
|
|
|
}
|
2010-10-27 22:58:23 +00:00
|
|
|
|
|
|
|
#if defined (_WIN64)
|
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
IoIs32bitProcess(
|
|
|
|
IN PIRP Irp OPTIONAL)
|
|
|
|
{
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
UNIMPLEMENTED;
|
2010-10-27 22:58:23 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
#endif
|