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

365 lines
9.4 KiB
C

/*++
Copyright (c) 1998-2001 Microsoft Corporation
Module Name:
ultdi.h
Abstract:
This module defines the interface to the TDI/MUX/SSL component.
Author:
Keith Moore (keithmo) 12-Jun-1998
Revision History:
--*/
#ifndef _ULTDI_H_
#define _ULTDI_H_
#ifdef __cplusplus
extern "C" {
#endif
//
// Opaque structure pointers. These are defined (privately) in ULTDIP.H.
//
typedef struct _UL_ENDPOINT *PUL_ENDPOINT;
typedef struct _UL_CONNECTION *PUL_CONNECTION;
//
// Routine invoked after an incoming TCP/MUX connection has been
// received (but not yet accepted).
//
// Arguments:
//
// pListeningContext - Supplies an uninterpreted context value
// as passed to the UlCreateListeningEndpoint() API.
//
// pConnection - Supplies the connection being established.
//
// pRemoteAddress - Supplies the remote (client-side) address
// requesting the connection.
//
// RemoteAddressLength - Supplies the total byte length of the
// pRemoteAddress structure.
//
// ppConnectionContext - Receives a pointer to an uninterpreted
// context value to be associated with the new connection if
// accepted. If the new connection is not accepted, this
// parameter is ignored.
//
// Return Value:
//
// BOOLEAN - TRUE if the connection was accepted, FALSE if not.
//
typedef
BOOLEAN
(*PUL_CONNECTION_REQUEST)(
IN PVOID pListeningContext,
IN PUL_CONNECTION pConnection,
IN PTRANSPORT_ADDRESS pRemoteAddress,
IN ULONG RemoteAddressLength,
OUT PVOID *ppConnectionContext
);
//
// Routine invoked after an incoming TCP/MUX connection has been fully
// accepted.
//
// This routine is also invoked if an incoming connection was not accepted
// *after* PUL_CONNECTION_REQUEST returned TRUE. In other words, if
// PUL_CONNECTION_REQUEST indicated that the connection should be accepted
// but a fatal error occurred later, then PUL_CONNECTION_COMPLETE is
// invoked.
//
// Arguments:
//
// pListeningContext - Supplies an uninterpreted context value
// as passed to the UlCreateListeningEndpoint() API.
//
// pConnectionContext - Supplies the uninterpreted context value
// as returned by PUL_CONNECTION_REQUEST.
//
// Status - Supplie the completion status. If this value is
// STATUS_SUCCESS, then the connection is now fully accepted.
// Otherwise, the connection has been aborted.
//
typedef
VOID
(*PUL_CONNECTION_COMPLETE)(
IN PVOID pListeningContext,
IN PVOID pConnectionContext,
IN NTSTATUS Status
);
//
// Routine invoked after an established TCP/MUX connection has been
// disconnected by the remote (client) side.
//
// Arguments:
//
// pListeningContext - Supplies an uninterpreted context value
// as passed to the UlCreateListeningEndpoint() API.
//
// pConnectionContext - Supplies an uninterpreted context value
// as returned from the PUL_CONNECTION_REQUEST callback.
//
// Status - Supplies the termination status.
//
// CODEWORK:
//
// This indication is not currently invoked when the local
// machine initiates an abortive disconnect. Faking an indication
// during a local abort would probably be a Good Thing.
//
typedef
VOID
(*PUL_CONNECTION_DISCONNECT)(
IN PVOID pListeningContext,
IN PVOID pConnectionContext,
IN NTSTATUS Status
);
//
// Routine invoked when a graceful disconnect requested by the client
// is complete. The client may want to drain the indicated data on the
// tdi connection to get the above indication.
//
typedef
VOID
(*PUL_CONNECTION_DISCONNECT_COMPLETE)(
IN PVOID pListeningContext,
IN PVOID pConnectionContext
);
//
// Routine invoked just before the internal state for a connection
// is destroyed. This is the last chance to cleanup before the
// connection fully disappears.
//
// Arguments:
//
// pListeningContext - Supplies an uninterpreted context value
// as passed to the UlCreateListeningEndpoint() API.
//
// pConnectionContext - Supplies an uninterpreted context value
// as returned from the PUL_CONNECTION_REQUEST callback.
//
typedef
VOID
(*PUL_CONNECTION_DESTROYED)(
IN PVOID pListeningContext,
IN PVOID pConnectionContext
);
//
// Routine invoked after data has been received on an established
// TCP/MUX connection.
//
// Arguments:
//
// pListeningContext - Supplies an uninterpreted context value
// as passed to the UlCreateListeningEndpoint() API.
//
// pConnectionContext - Supplies an uninterpreted context value
// as returned from the PUL_CONNECTION_REQUEST callback.
//
// pBuffer - Supplies a pointer to the received data.
//
// IndicatedLength - Supplies the length of the received data
// available in pBuffer.
//
// pTakenLength - Receives the number of bytes consumed by
// the receive handler.
//
// Return Value:
//
// NTSTATUS - The status of the consumed data. The behavior of
// the TDI/MUX component is dependent on the return value
// and the value set in *pTakenLength, and is defined as
// follows:
//
// STATUS_SUCCESS, *pTakenLength == IndicatedLength -
// All indicated data was consumed by the receive
// handler. Additional incoming data will cause
// subsequent receive indications.
//
// STATUS_SUCCESS, *pTakenLength < IndicatedLength -
// Part of the indicated data was consumed by the
// receive handler. The network transport will
// buffer data and no further indications will be
// made until UlReceiveData() is called.
//
// STATUS_MORE_PROCESSING_REQUIRED - Part of the
// indicated data was consumed by the receive handler.
// A subsequent receive indication will be made
// when additional data is available. The subsequent
// indication will include the unconsumed data from
// the current indication plus any additional data
// received.
//
// Any other status - Indicates a fatal error in the
// receive handler. The connection will be aborted.
//
// *pTakenLength > IndicatedLength - This is an error
// condition and should never occur.
//
//
// Public (within UL.SYS) entrypoints.
//
NTSTATUS
UlInitializeTdi(
VOID
);
VOID
UlTerminateTdi(
VOID
);
VOID
UlWaitForEndpointDrain(
VOID
);
ULONG
UlpComputeHttpRawConnectionLength(
IN PVOID pConnectionContext
);
ULONG
UlpGenerateHttpRawConnectionInfo(
IN PVOID pContext,
IN PUCHAR pKernelBuffer,
IN PVOID pUserBuffer,
IN ULONG OutputBufferLength,
IN PUCHAR pBuffer,
IN ULONG InitialLength
);
NTSTATUS
UlCreateListeningEndpoint(
IN PTRANSPORT_ADDRESS pLocalAddress,
IN ULONG LocalAddressLength,
IN BOOLEAN Secure,
IN ULONG InitialBacklog,
IN PUL_CONNECTION_REQUEST pConnectionRequestHandler,
IN PUL_CONNECTION_COMPLETE pConnectionCompleteHandler,
IN PUL_CONNECTION_DISCONNECT pConnectionDisconnectHandler,
IN PUL_CONNECTION_DISCONNECT_COMPLETE pConnectionDisconnectCompleteHandler,
IN PUL_CONNECTION_DESTROYED pConnectionDestroyedHandler,
IN PUL_DATA_RECEIVE pDataReceiveHandler,
IN PVOID pListeningContext,
OUT PUL_ENDPOINT *ppListeningEndpoint
);
NTSTATUS
UlCloseListeningEndpoint(
IN PUL_ENDPOINT pListeningEndpoint,
IN PUL_COMPLETION_ROUTINE pCompletionRoutine,
IN PVOID pCompletionContext
);
NTSTATUS
UlCloseConnection(
IN PVOID pObject,
IN BOOLEAN AbortiveDisconnect,
IN PUL_COMPLETION_ROUTINE pCompletionRoutine,
IN PVOID pCompletionContext
);
NTSTATUS
UlSendData(
IN PUL_CONNECTION pConnection,
IN PMDL pMdlChain,
IN ULONG Length,
IN PUL_COMPLETION_ROUTINE pCompletionRoutine,
IN PVOID pCompletionContext,
IN PIRP pOwnIrp,
IN PUL_IRP_CONTEXT pOwnIrpContext,
IN BOOLEAN InitiateDisconnect
);
NTSTATUS
UlReceiveData(
IN PVOID pConnectionContext,
IN PVOID pBuffer,
IN ULONG BufferLength,
IN PUL_COMPLETION_ROUTINE pCompletionRoutine,
IN PVOID pCompletionContext
);
NTSTATUS
UlAddSiteToEndpointList(
IN PWSTR pSiteUrl
);
NTSTATUS
UlRemoveSiteFromEndpointList(
IN PWSTR pSiteUrl
);
VOID
UlReferenceConnection(
IN PVOID pObject
REFERENCE_DEBUG_FORMAL_PARAMS
);
VOID
UlDereferenceConnection(
IN PVOID pObject
REFERENCE_DEBUG_FORMAL_PARAMS
);
#define REFERENCE_CONNECTION( pconn ) \
UlReferenceConnection( \
(pconn) \
REFERENCE_DEBUG_ACTUAL_PARAMS \
)
#define DEREFERENCE_CONNECTION( pconn ) \
UlDereferenceConnection( \
(pconn) \
REFERENCE_DEBUG_ACTUAL_PARAMS \
)
//
// Prototype for TCP Send routine if Fast Send is possible.
//
typedef
NTSTATUS
(*PUL_TCPSEND_DISPATCH) (
IN PIRP Irp,
IN PIO_STACK_LOCATION IrpSp
);
#ifdef __cplusplus
}; // extern "C"
#endif
#endif // _ULTDI_H_