windows-nt/Source/XPSP1/NT/inetsrv/iis/iisrearc/ul/drv/close.cxx
2020-09-26 16:20:57 +08:00

211 lines
4.3 KiB
C++

/*++
Copyright (c) 1998-2001 Microsoft Corporation
Module Name:
close.cxx
Abstract:
This module contains code for cleanup and close IRPs.
Author:
Keith Moore (keithmo) 10-Jun-1998
Revision History:
--*/
#include "precomp.h"
#ifdef ALLOC_PRAGMA
#pragma alloc_text( PAGE, UlClose )
#endif // ALLOC_PRAGMA
#if 0
NOT PAGEABLE -- UlCleanup
#endif
//
// Public functions.
//
/***************************************************************************++
Routine Description:
This is the routine that handles Cleanup IRPs in UL. Cleanup IRPs
are issued after the last handle to the file object is closed.
Arguments:
pDeviceObject - Supplies a pointer to the target device object.
pIrp - Supplies a pointer to IO request packet.
Return Value:
NTSTATUS - Completion status.
--***************************************************************************/
NTSTATUS
UlCleanup(
IN PDEVICE_OBJECT pDeviceObject,
IN PIRP pIrp
)
{
NTSTATUS status;
PIO_STACK_LOCATION pIrpSp;
UL_ENTER_DRIVER( "UlCleanup", pIrp );
//
// Snag the current IRP stack pointer.
//
pIrpSp = IoGetCurrentIrpStackLocation( pIrp );
IF_DEBUG( OPEN_CLOSE )
{
KdPrint((
"UlCleanup: cleanup on file object %lx\n",
pIrpSp->FileObject
));
}
//
// app pool or control channel?
//
if (pDeviceObject == g_pUlAppPoolDeviceObject &&
IS_APP_POOL( pIrpSp->FileObject ))
{
//
// app pool, let's detach this process from the app pool
//
status = UlDetachProcessFromAppPool(
GET_APP_POOL_PROCESS(pIrpSp->FileObject)
);
MARK_INVALID_APP_POOL( pIrpSp->FileObject );
}
else if (pDeviceObject == g_pUlFilterDeviceObject &&
IS_FILTER_PROCESS( pIrpSp->FileObject ))
{
//
// filter channel
//
status = UlDetachFilterProcess(
GET_FILTER_PROCESS(pIrpSp->FileObject)
);
MARK_INVALID_FILTER_CHANNEL( pIrpSp->FileObject );
}
else if (IS_CONTROL_CHANNEL( pIrpSp->FileObject ))
{
status = UlCloseControlChannel(
GET_CONTROL_CHANNEL(pIrpSp->FileObject)
);
MARK_INVALID_CONTROL_CHANNEL( pIrpSp->FileObject );
}
else
{
status = STATUS_INVALID_DEVICE_REQUEST;
}
pIrp->IoStatus.Status = status;
UlCompleteRequest( pIrp, g_UlPriorityBoost );
UL_LEAVE_DRIVER( "UlCleanup" );
RETURN(status);
} // UlCleanup
/***************************************************************************++
Routine Description:
This is the routine that handles Close IRPs in UL. Close IRPs are
issued after the last reference to the file object is removed.
Arguments:
pDeviceObject - Supplies a pointer to the target device object.
pIrp - Supplies a pointer to IO request packet.
Return Value:
NTSTATUS - Completion status.
--***************************************************************************/
NTSTATUS
UlClose(
IN PDEVICE_OBJECT pDeviceObject,
IN PIRP pIrp
)
{
NTSTATUS status;
PIO_STACK_LOCATION pIrpSp;
UNREFERENCED_PARAMETER( pDeviceObject );
//
// Sanity check.
//
PAGED_CODE();
UL_ENTER_DRIVER( "UlClose", pIrp );
status = STATUS_SUCCESS;
//
// Snag the current IRP stack pointer.
//
pIrpSp = IoGetCurrentIrpStackLocation( pIrp );
//
// If it's an App Pool or filter channel we have to delete
// the associated object.
//
if (pDeviceObject == g_pUlAppPoolDeviceObject &&
IS_EX_APP_POOL( pIrpSp->FileObject ))
{
UlFreeAppPoolProcess(GET_APP_POOL_PROCESS(pIrpSp->FileObject));
}
else if (pDeviceObject == g_pUlFilterDeviceObject &&
IS_EX_FILTER_PROCESS( pIrpSp->FileObject ))
{
UlFreeFilterProcess(GET_FILTER_PROCESS(pIrpSp->FileObject));
}
IF_DEBUG( OPEN_CLOSE )
{
KdPrint((
"UlClose: closing file object %lx\n",
pIrpSp->FileObject
));
}
pIrp->IoStatus.Status = status;
UlCompleteRequest( pIrp, g_UlPriorityBoost );
UL_LEAVE_DRIVER( "UlClose" );
RETURN(status);
} // UlClose