mirror of
https://github.com/reactos/reactos.git
synced 2025-02-24 09:25:10 +00:00
- Distinguish between cleanup and close properly
- On cleanup, we cancel all requests - On close, we remove the address file from the list, free the port and listener (if present), then free the address file itself svn path=/trunk/; revision=40367
This commit is contained in:
parent
a2e1f4928f
commit
4c4d83fa6e
1 changed files with 16 additions and 43 deletions
|
@ -139,11 +139,11 @@ VOID ControlChannelFree(
|
|||
}
|
||||
|
||||
|
||||
VOID DeleteAddress(PADDRESS_FILE AddrFile)
|
||||
NTSTATUS FileCloseAddress(PTDI_REQUEST Request)
|
||||
/*
|
||||
* FUNCTION: Deletes an address file object
|
||||
* FUNCTION: Closes an address file object
|
||||
* ARGUMENTS:
|
||||
* AddrFile = Pointer to address file object to delete
|
||||
* AddrFile = Pointer to address file object to close
|
||||
*/
|
||||
{
|
||||
KIRQL OldIrql;
|
||||
|
@ -151,16 +151,16 @@ VOID DeleteAddress(PADDRESS_FILE AddrFile)
|
|||
PLIST_ENTRY NextEntry;
|
||||
PDATAGRAM_SEND_REQUEST SendRequest;
|
||||
PDATAGRAM_RECEIVE_REQUEST ReceiveRequest;
|
||||
PADDRESS_FILE AddrFile = Request->Handle.AddressHandle;
|
||||
|
||||
TI_DbgPrint(MID_TRACE, ("Called.\n"));
|
||||
|
||||
/* Remove address file from the global list */
|
||||
TcpipAcquireSpinLock(&AddressFileListLock, &OldIrql);
|
||||
RemoveEntryList(&AddrFile->ListEntry);
|
||||
TcpipReleaseSpinLock(&AddressFileListLock, OldIrql);
|
||||
|
||||
TcpipAcquireSpinLock(&AddrFile->Lock, &OldIrql);
|
||||
|
||||
/* Set address file object exclusive to us */
|
||||
AF_SET_BUSY(AddrFile);
|
||||
AF_CLR_VALID(AddrFile);
|
||||
|
||||
/* FIXME: Kill TCP connections on this address file object */
|
||||
|
||||
/* Return pending requests with error */
|
||||
|
@ -197,9 +197,9 @@ VOID DeleteAddress(PADDRESS_FILE AddrFile)
|
|||
|
||||
TcpipReleaseSpinLock(&AddrFile->Lock, OldIrql);
|
||||
|
||||
(*AddrFile->Free)(AddrFile);
|
||||
|
||||
TI_DbgPrint(MAX_TRACE, ("Leaving.\n"));
|
||||
|
||||
return STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
|
||||
|
@ -339,7 +339,7 @@ NTSTATUS FileOpenAddress(
|
|||
* RETURNS:
|
||||
* Status of operation
|
||||
*/
|
||||
NTSTATUS FileCloseAddress(
|
||||
NTSTATUS FileFreeAddress(
|
||||
PTDI_REQUEST Request)
|
||||
{
|
||||
KIRQL OldIrql;
|
||||
|
@ -350,13 +350,10 @@ NTSTATUS FileCloseAddress(
|
|||
|
||||
AddrFile = Request->Handle.AddressHandle;
|
||||
|
||||
TcpipAcquireSpinLock(&AddrFile->Lock, &OldIrql);
|
||||
|
||||
/* Set address file object exclusive to us */
|
||||
AF_SET_BUSY(AddrFile);
|
||||
AF_CLR_VALID(AddrFile);
|
||||
|
||||
TcpipReleaseSpinLock(&AddrFile->Lock, OldIrql);
|
||||
/* Remove address file from the global list */
|
||||
TcpipAcquireSpinLock(&AddressFileListLock, &OldIrql);
|
||||
RemoveEntryList(&AddrFile->ListEntry);
|
||||
TcpipReleaseSpinLock(&AddressFileListLock, OldIrql);
|
||||
|
||||
/* Protocol specific handling */
|
||||
switch (AddrFile->Protocol) {
|
||||
|
@ -372,33 +369,9 @@ NTSTATUS FileCloseAddress(
|
|||
UDPFreePort( AddrFile->Port );
|
||||
break;
|
||||
}
|
||||
|
||||
TI_DbgPrint(MAX_TRACE, ("Leaving.\n"));
|
||||
|
||||
return Status;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* FUNCTION: Closes an address file object
|
||||
* ARGUMENTS:
|
||||
* Request = Pointer to TDI request structure for this request
|
||||
* RETURNS:
|
||||
* Status of operation
|
||||
*/
|
||||
NTSTATUS FileFreeAddress(
|
||||
PTDI_REQUEST Request)
|
||||
{
|
||||
PADDRESS_FILE AddrFile;
|
||||
NTSTATUS Status = STATUS_SUCCESS;
|
||||
|
||||
AddrFile = Request->Handle.AddressHandle;
|
||||
|
||||
TI_DbgPrint(MID_TRACE, ("Called.\n"));
|
||||
|
||||
DeleteAddress(AddrFile);
|
||||
|
||||
TI_DbgPrint(MAX_TRACE, ("Leaving.\n"));
|
||||
(*AddrFile->Free)(AddrFile);
|
||||
|
||||
return Status;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue