windows-nt/Source/XPSP1/NT/public/internal/net/inc/afd.h

1337 lines
53 KiB
C
Raw Normal View History

2020-09-26 03:20:57 -05:00
/*++
Copyright (c) Microsoft Corporation. All rights reserved.
Module Name:
Afd.h
Abstract:
Contains structures and declarations for AFD. AFD stands for the
Ancillary Function Driver. This driver enhances the functionality
of TDI so that it is a sufficiently rich interface to support
user-mode sockets and XTI DLLs.
Author:
David Treadwell (davidtr) 20-Feb-1992
Revision History:
--*/
#ifndef _AFD_
#define _AFD_
//
// If WINSOCK2.H has not been included, then just embed the definition
// of the WSABUF and QOS structures here. This makes building AFD.SYS
// much easier.
//
#ifndef _WINSOCK2API_
typedef struct _WSABUF {
ULONG len;
PCHAR buf;
} WSABUF, *LPWSABUF;
#include <qos.h>
typedef struct _QualityOfService
{
FLOWSPEC SendingFlowspec; /* the flow spec for data sending */
FLOWSPEC ReceivingFlowspec; /* the flow spec for data receiving */
WSABUF ProviderSpecific; /* additional provider specific stuff */
} QOS, *LPQOS;
#define MSG_TRUNC 0x0100
#define MSG_CTRUNC 0x0200
#define MSG_BCAST 0x0400
#define MSG_MCAST 0x0800
#endif
#define AFD_DEVICE_NAME L"\\Device\\Afd"
//
// Endpoint flags computed based on Winsock2 provider flags
// and socket type
//
typedef struct _AFD_ENDPOINT_FLAGS {
union {
struct {
BOOLEAN ConnectionLess :1;
BOOLEAN :3; // This spacing makes strcutures
// much more readable (hex) in the
// debugger and has no effect
// on the generated code as long
// as number of flags is less than
// 8 (we still take up full 32 bits
// because of aligment requiremens
// of most other fields)
BOOLEAN MessageMode :1;
BOOLEAN :3;
BOOLEAN Raw :1;
BOOLEAN :3;
BOOLEAN Multipoint :1;
BOOLEAN :3;
BOOLEAN C_Root :1;
BOOLEAN :3;
BOOLEAN D_Root :1;
BOOLEAN :3;
};
ULONG EndpointFlags; // Flags are as fine as bit fields,
// but create problems when we need
// to cast them to boolean.
};
#define AFD_ENDPOINT_FLAG_CONNECTIONLESS 0x00000001
#define AFD_ENDPOINT_FLAG_MESSAGEMODE 0x00000010
#define AFD_ENDPOINT_FLAG_RAW 0x00000100
//
// Old AFD_ENDPOINT_TYPE mappings. Flags make things clearer at
// at the TDI level and after all Winsock2 switched to provider flags
// instead of socket type anyway (ATM for example needs connection oriented
// raw sockets, which can only be reflected by SOCK_RAW+SOCK_STREAM combination
// which does not exists).
//
#define AfdEndpointTypeStream 0
#define AfdEndpointTypeDatagram (AFD_ENDPOINT_FLAG_CONNECTIONLESS|\
AFD_ENDPOINT_FLAG_MESSAGEMODE)
#define AfdEndpointTypeRaw (AFD_ENDPOINT_FLAG_CONNECTIONLESS|\
AFD_ENDPOINT_FLAG_MESSAGEMODE|\
AFD_ENDPOINT_FLAG_RAW)
#define AfdEndpointTypeSequencedPacket (AFD_ENDPOINT_FLAG_MESSAGEMODE)
#define AfdEndpointTypeReliableMessage (AFD_ENDPOINT_FLAG_MESSAGEMODE)
//
// New multipoint semantics
//
#define AFD_ENDPOINT_FLAG_MULTIPOINT 0x00001000
#define AFD_ENDPOINT_FLAG_CROOT 0x00010000
#define AFD_ENDPOINT_FLAG_DROOT 0x00100000
#define AFD_ENDPOINT_VALID_FLAGS 0x00111111
} AFD_ENDPOINT_FLAGS;
//
// Structures used on NtCreateFile() for AFD.
//
typedef struct _AFD_OPEN_PACKET {
AFD_ENDPOINT_FLAGS __f;
#define afdConnectionLess __f.ConnectionLess
#define afdMessageMode __f.MessageMode
#define afdRaw __f.Raw
#define afdMultipoint __f.Multipoint
#define afdC_Root __f.C_Root
#define afdD_Root __f.D_Root
#define afdEndpointFlags __f.EndpointFlags
LONG GroupID;
ULONG TransportDeviceNameLength;
WCHAR TransportDeviceName[1];
} AFD_OPEN_PACKET, *PAFD_OPEN_PACKET;
// *** the XX is to ensure natural alignment of the open packet part
// of the EA buffer
#define AfdOpenPacket "AfdOpenPacketXX"
#define AFD_OPEN_PACKET_NAME_LENGTH (sizeof(AfdOpenPacket) - 1)
//
// The input structure for IOCTL_AFD_BIND
//
typedef struct _AFD_BIND_INFO {
ULONG ShareAccess;
#define AFD_NORMALADDRUSE 0 // Do not reuse address if
// already in use but allow
// subsequent reuse by others
// (this is a default)
#define AFD_REUSEADDRESS 1 // Reuse address if necessary
#define AFD_WILDCARDADDRESS 2 // Address is a wildcard, no checking
// can be performed by winsock layer.
#define AFD_EXCLUSIVEADDRUSE 3 // Do not allow reuse of this
// address (admin only).
TRANSPORT_ADDRESS Address;
} AFD_BIND_INFO, *PAFD_BIND_INFO;
//
// The output strucuture is TDI_ADDRESS_INFO
// The address handle is returned via IoStatus->Information
//
//
// The input structure for IOCTL_AFD_START_LISTEN.
//
typedef struct _AFD_LISTEN_INFO {
BOOLEAN SanActive;
ULONG MaximumConnectionQueue;
BOOLEAN UseDelayedAcceptance;
} AFD_LISTEN_INFO, *PAFD_LISTEN_INFO;
//
// The output structure for IOCTL_AFD_WAIT_FOR_LISTEN.
//
typedef struct _AFD_LISTEN_RESPONSE_INFO {
LONG Sequence;
TRANSPORT_ADDRESS RemoteAddress;
} AFD_LISTEN_RESPONSE_INFO, *PAFD_LISTEN_RESPONSE_INFO;
//
// The input structure for IOCTL_AFD_ACCEPT.
//
typedef struct _AFD_ACCEPT_INFO {
BOOLEAN SanActive;
LONG Sequence;
HANDLE AcceptHandle;
} AFD_ACCEPT_INFO, *PAFD_ACCEPT_INFO;
typedef struct _AFD_SUPER_ACCEPT_INFO {
BOOLEAN SanActive;
BOOLEAN FixAddressAlignment;
HANDLE AcceptHandle;
ULONG ReceiveDataLength;
ULONG LocalAddressLength;
ULONG RemoteAddressLength;
} AFD_SUPER_ACCEPT_INFO, *PAFD_SUPER_ACCEPT_INFO;
//
// The input structure for IOCTL_AFD_DEFER_ACCEPT.
//
typedef struct _AFD_DEFER_ACCEPT_INFO {
LONG Sequence;
BOOLEAN Reject;
} AFD_DEFER_ACCEPT_INFO, *PAFD_DEFER_ACCEPT_INFO;
//
// Flags and input structure for IOCTL_AFD_PARTIAL_DISCONNECT.
//
#define AFD_PARTIAL_DISCONNECT_SEND 0x01
#define AFD_PARTIAL_DISCONNECT_RECEIVE 0x02
#define AFD_ABORTIVE_DISCONNECT 0x4
#define AFD_UNCONNECT_DATAGRAM 0x08
typedef struct _AFD_PARTIAL_DISCONNECT_INFO {
ULONG DisconnectMode;
LARGE_INTEGER Timeout;
} AFD_PARTIAL_DISCONNECT_INFO, *PAFD_PARTIAL_DISCONNECT_INFO;
typedef struct _AFD_SUPER_DISCONNECT_INFO {
ULONG Flags; // Same as TransmitFile
} AFD_SUPER_DISCONNECT_INFO, *PAFD_SUPER_DISCONNECT_INFO;
//
// Structures for IOCTL_AFD_POLL.
//
typedef struct _AFD_POLL_HANDLE_INFO {
HANDLE Handle;
ULONG PollEvents;
NTSTATUS Status;
} AFD_POLL_HANDLE_INFO, *PAFD_POLL_HANDLE_INFO;
typedef struct _AFD_POLL_INFO {
LARGE_INTEGER Timeout;
ULONG NumberOfHandles;
BOOLEAN Unique;
AFD_POLL_HANDLE_INFO Handles[1];
} AFD_POLL_INFO, *PAFD_POLL_INFO;
#define AFD_POLL_RECEIVE_BIT 0 //0001
#define AFD_POLL_RECEIVE (1 << AFD_POLL_RECEIVE_BIT)
#define AFD_POLL_RECEIVE_EXPEDITED_BIT 1 //0002
#define AFD_POLL_RECEIVE_EXPEDITED (1 << AFD_POLL_RECEIVE_EXPEDITED_BIT)
#define AFD_POLL_SEND_BIT 2 //0004
#define AFD_POLL_SEND (1 << AFD_POLL_SEND_BIT)
#define AFD_POLL_DISCONNECT_BIT 3 //0008
#define AFD_POLL_DISCONNECT (1 << AFD_POLL_DISCONNECT_BIT)
#define AFD_POLL_ABORT_BIT 4 //0010
#define AFD_POLL_ABORT (1 << AFD_POLL_ABORT_BIT)
#define AFD_POLL_LOCAL_CLOSE_BIT 5 //0020
#define AFD_POLL_LOCAL_CLOSE (1 << AFD_POLL_LOCAL_CLOSE_BIT)
#define AFD_POLL_CONNECT_BIT 6 //0040
#define AFD_POLL_CONNECT (1 << AFD_POLL_CONNECT_BIT)
#define AFD_POLL_ACCEPT_BIT 7 //0080
#define AFD_POLL_ACCEPT (1 << AFD_POLL_ACCEPT_BIT)
#define AFD_POLL_CONNECT_FAIL_BIT 8 //0100
#define AFD_POLL_CONNECT_FAIL (1 << AFD_POLL_CONNECT_FAIL_BIT)
#define AFD_POLL_QOS_BIT 9 //0200
#define AFD_POLL_QOS (1 << AFD_POLL_QOS_BIT)
#define AFD_POLL_GROUP_QOS_BIT 10 //0400
#define AFD_POLL_GROUP_QOS (1 << AFD_POLL_GROUP_QOS_BIT)
#define AFD_POLL_ROUTING_IF_CHANGE_BIT 11 //0800
#define AFD_POLL_ROUTING_IF_CHANGE (1 << AFD_POLL_ROUTING_IF_CHANGE_BIT)
#define AFD_POLL_ADDRESS_LIST_CHANGE_BIT 12 //1000
#define AFD_POLL_ADDRESS_LIST_CHANGE (1 << AFD_POLL_ADDRESS_LIST_CHANGE_BIT)
#define AFD_NUM_POLL_EVENTS 13
#define AFD_POLL_ALL ((1 << AFD_NUM_POLL_EVENTS) - 1)
#define AFD_POLL_SANCOUNTS_UPDATED 0x80000000
//
// Structure for querying receive information.
//
typedef struct _AFD_RECEIVE_INFORMATION {
ULONG BytesAvailable;
ULONG ExpeditedBytesAvailable;
} AFD_RECEIVE_INFORMATION, *PAFD_RECEIVE_INFORMATION;
//
// Structure for quering the TDI handles for an AFD endpoint.
//
#define AFD_QUERY_ADDRESS_HANDLE 1
#define AFD_QUERY_CONNECTION_HANDLE 2
typedef struct _AFD_HANDLE_INFO {
HANDLE TdiAddressHandle;
HANDLE TdiConnectionHandle;
} AFD_HANDLE_INFO, *PAFD_HANDLE_INFO;
//
// Structure and manifests for setting information in AFD.
//
typedef struct _AFD_INFORMATION {
ULONG InformationType;
union {
BOOLEAN Boolean;
ULONG Ulong;
LARGE_INTEGER LargeInteger;
} Information;
} AFD_INFORMATION, *PAFD_INFORMATION;
#define AFD_INLINE_MODE 0x01
#define AFD_NONBLOCKING_MODE 0x02
#define AFD_MAX_SEND_SIZE 0x03
#define AFD_SENDS_PENDING 0x04
#define AFD_MAX_PATH_SEND_SIZE 0x05
#define AFD_RECEIVE_WINDOW_SIZE 0x06
#define AFD_SEND_WINDOW_SIZE 0x07
#define AFD_CONNECT_TIME 0x08
#define AFD_CIRCULAR_QUEUEING 0x09
#define AFD_GROUP_ID_AND_TYPE 0x0A
#define AFD_GROUP_ID_AND_TYPE 0x0A
#define AFD_REPORT_PORT_UNREACHABLE 0x0B
//
// Structure for the transmit file IOCTL.
//
typedef struct _AFD_TRANSMIT_FILE_INFO {
LARGE_INTEGER Offset;
LARGE_INTEGER WriteLength;
ULONG SendPacketLength;
HANDLE FileHandle;
PVOID Head;
ULONG HeadLength;
PVOID Tail;
ULONG TailLength;
ULONG Flags;
} AFD_TRANSMIT_FILE_INFO, *PAFD_TRANSMIT_FILE_INFO;
//
// Flags for the TransmitFile API.
//
#define AFD_TF_DISCONNECT 0x01
#define AFD_TF_REUSE_SOCKET 0x02
#define AFD_TF_WRITE_BEHIND 0x04
#define AFD_TF_USE_DEFAULT_WORKER 0x00
#define AFD_TF_USE_SYSTEM_THREAD 0x10
#define AFD_TF_USE_KERNEL_APC 0x20
#define AFD_TF_WORKER_KIND_MASK 0x30
//
// Flag definitions for the AfdFlags field in the AFD_SEND_INFO,
// AFD_SEND_DATAGRAM_INFO, AFD_RECV_INFO, and AFD_RECV_DATAGRAM_INFO
// structures.
//
#define AFD_NO_FAST_IO 0x0001 // Always fail Fast IO on this request.
#define AFD_OVERLAPPED 0x0002 // Overlapped operation.
//
// Structure for connected sends.
//
typedef struct _AFD_SEND_INFO {
LPWSABUF BufferArray;
ULONG BufferCount;
ULONG AfdFlags;
ULONG TdiFlags;
} AFD_SEND_INFO, *PAFD_SEND_INFO;
//
// Structure for unconnected datagram sends.
//
typedef struct _AFD_SEND_DATAGRAM_INFO {
LPWSABUF BufferArray;
ULONG BufferCount;
ULONG AfdFlags;
TDI_REQUEST_SEND_DATAGRAM TdiRequest;
TDI_CONNECTION_INFORMATION TdiConnInfo;
} AFD_SEND_DATAGRAM_INFO, *PAFD_SEND_DATAGRAM_INFO;
//
// Structure for connected recvs.
//
typedef struct _AFD_RECV_INFO {
LPWSABUF BufferArray;
ULONG BufferCount;
ULONG AfdFlags;
ULONG TdiFlags;
} AFD_RECV_INFO, *PAFD_RECV_INFO;
//
// Structure for receiving datagrams on unconnected sockets.
//
typedef struct _AFD_RECV_DATAGRAM_INFO {
LPWSABUF BufferArray;
ULONG BufferCount;
ULONG AfdFlags;
ULONG TdiFlags;
PVOID Address;
PULONG AddressLength;
} AFD_RECV_DATAGRAM_INFO, *PAFD_RECV_DATAGRAM_INFO;
//
// Structure for receiving datagram messages.
//
typedef struct _AFD_RECV_MESSAGE_INFO {
AFD_RECV_DATAGRAM_INFO dgi;
PVOID ControlBuffer;
PULONG ControlLength;
PULONG MsgFlags;
} AFD_RECV_MESSAGE_INFO, *PAFD_RECV_MESSAGE_INFO;
#define AFD_MAX_TDI_FAST_ADDRESS 32
//
// Structure for event select.
//
typedef struct _AFD_EVENT_SELECT_INFO {
HANDLE Event;
ULONG PollEvents;
} AFD_EVENT_SELECT_INFO, *PAFD_EVENT_SELECT_INFO;
//
// Output structure for enum network events.
//
typedef struct _AFD_ENUM_NETWORK_EVENTS_INFO {
ULONG PollEvents;
NTSTATUS EventStatus[AFD_NUM_POLL_EVENTS];
} AFD_ENUM_NETWORK_EVENTS_INFO, *PAFD_ENUM_NETWORK_EVENTS_INFO;
//
// Structures for QOS and grouping.
//
typedef struct _AFD_QOS_INFO {
QOS Qos;
BOOLEAN GroupQos;
} AFD_QOS_INFO, *PAFD_QOS_INFO;
//
// Group membership type.
//
typedef enum _AFD_GROUP_TYPE {
GroupTypeNeither = 0,
GroupTypeConstrained = SG_CONSTRAINED_GROUP,
GroupTypeUnconstrained = SG_UNCONSTRAINED_GROUP
} AFD_GROUP_TYPE, *PAFD_GROUP_TYPE;
//
// Note that, for totally slimy reasons, the following
// structure must be exactly eight bytes long (the size
// of a LARGE_INTEGER). See msafd\socket.c and afd\misc.c
// for the gory details.
//
typedef struct _AFD_GROUP_INFO {
LONG GroupID;
AFD_GROUP_TYPE GroupType;
} AFD_GROUP_INFO, *PAFD_GROUP_INFO;
//
// Structure for validating group membership.
//
typedef struct _AFD_VALIDATE_GROUP_INFO {
LONG GroupID;
TRANSPORT_ADDRESS RemoteAddress;
} AFD_VALIDATE_GROUP_INFO, *PAFD_VALIDATE_GROUP_INFO;
//
// Structure for querying connect data on an unaccepted connection.
//
typedef struct _AFD_UNACCEPTED_CONNECT_DATA_INFO {
LONG Sequence;
ULONG ConnectDataLength;
BOOLEAN LengthOnly;
} AFD_UNACCEPTED_CONNECT_DATA_INFO, *PAFD_UNACCEPTED_CONNECT_DATA_INFO;
typedef struct _AFD_TRANSPORT_IOCTL_INFO {
HANDLE Handle;
PVOID InputBuffer;
ULONG InputBufferLength;
ULONG IoControlCode;
ULONG AfdFlags;
ULONG PollEvent;
} AFD_TRANSPORT_IOCTL_INFO, *PAFD_TRANSPORT_IOCTL_INFO;
typedef struct _AFD_CONNECT_JOIN_INFO {
BOOLEAN SanActive;
HANDLE RootEndpoint; // Root endpoint for joins
HANDLE ConnectEndpoint; // Connect/leaf endpoint for async connects
TRANSPORT_ADDRESS RemoteAddress; // Remote address
} AFD_CONNECT_JOIN_INFO, *PAFD_CONNECT_JOIN_INFO;
#ifndef _WINSOCK2API_
typedef struct _TRANSMIT_PACKETS_ELEMENT {
ULONG dwElFlags;
#define TP_MEMORY 1
#define TP_FILE 2
#define TP_EOP 4
ULONG cLength;
union {
struct {
LARGE_INTEGER nFileOffset;
HANDLE hFile;
};
PVOID pBuffer;
};
} TRANSMIT_PACKETS_ELEMENT, *LPTRANSMIT_PACKETS_ELEMENT;
#else
typedef struct _TRANSMIT_PACKETS_ELEMENT TRANSMIT_PACKETS_ELEMENT, *LPTRANSMIT_PACKETS_ELEMENT;
#endif
typedef struct _AFD_TPACKETS_INFO {
LPTRANSMIT_PACKETS_ELEMENT ElementArray;
ULONG ElementCount;
ULONG SendSize;
ULONG Flags;
} AFD_TPACKETS_INFO, *PAFD_TPACKETS_INFO;
//
// AFD IOCTL code definitions.
//
// N.B. To ensure the efficient of the code generated by AFD's
// IOCTL dispatcher, these IOCTL codes should be contiguous
// (no gaps).
//
// N.B. If new IOCTLs are added here, update the lookup table in
// ntos\afd\dispatch.c!
//
#define FSCTL_AFD_BASE FILE_DEVICE_NETWORK
#define _AFD_CONTROL_CODE(request,method) \
((FSCTL_AFD_BASE)<<12 | (request<<2) | method)
#define _AFD_REQUEST(ioctl) \
((((ULONG)(ioctl)) >> 2) & 0x03FF)
#define _AFD_BASE(ioctl) \
((((ULONG)(ioctl)) >> 12) & 0xFFFFF)
#define AFD_BIND 0
#define AFD_CONNECT 1
#define AFD_START_LISTEN 2
#define AFD_WAIT_FOR_LISTEN 3
#define AFD_ACCEPT 4
#define AFD_RECEIVE 5
#define AFD_RECEIVE_DATAGRAM 6
#define AFD_SEND 7
#define AFD_SEND_DATAGRAM 8
#define AFD_POLL 9
#define AFD_PARTIAL_DISCONNECT 10
#define AFD_GET_ADDRESS 11
#define AFD_QUERY_RECEIVE_INFO 12
#define AFD_QUERY_HANDLES 13
#define AFD_SET_INFORMATION 14
#define AFD_GET_REMOTE_ADDRESS 15
#define AFD_GET_CONTEXT 16
#define AFD_SET_CONTEXT 17
#define AFD_SET_CONNECT_DATA 18
#define AFD_SET_CONNECT_OPTIONS 19
#define AFD_SET_DISCONNECT_DATA 20
#define AFD_SET_DISCONNECT_OPTIONS 21
#define AFD_GET_CONNECT_DATA 22
#define AFD_GET_CONNECT_OPTIONS 23
#define AFD_GET_DISCONNECT_DATA 24
#define AFD_GET_DISCONNECT_OPTIONS 25
#define AFD_SIZE_CONNECT_DATA 26
#define AFD_SIZE_CONNECT_OPTIONS 27
#define AFD_SIZE_DISCONNECT_DATA 28
#define AFD_SIZE_DISCONNECT_OPTIONS 29
#define AFD_GET_INFORMATION 30
#define AFD_TRANSMIT_FILE 31
#define AFD_SUPER_ACCEPT 32
#define AFD_EVENT_SELECT 33
#define AFD_ENUM_NETWORK_EVENTS 34
#define AFD_DEFER_ACCEPT 35
#define AFD_WAIT_FOR_LISTEN_LIFO 36
#define AFD_SET_QOS 37
#define AFD_GET_QOS 38
#define AFD_NO_OPERATION 39
#define AFD_VALIDATE_GROUP 40
#define AFD_GET_UNACCEPTED_CONNECT_DATA 41
#define AFD_ROUTING_INTERFACE_QUERY 42
#define AFD_ROUTING_INTERFACE_CHANGE 43
#define AFD_ADDRESS_LIST_QUERY 44
#define AFD_ADDRESS_LIST_CHANGE 45
#define AFD_JOIN_LEAF 46
#define AFD_TRANSPORT_IOCTL 47
#define AFD_TRANSMIT_PACKETS 48
#define AFD_SUPER_CONNECT 49
#define AFD_SUPER_DISCONNECT 50
#define AFD_RECEIVE_MESSAGE 51
//
// SAN switch specific AFD function numbers
//
#define AFD_SWITCH_CEMENT_SAN 52
#define AFD_SWITCH_SET_EVENTS 53
#define AFD_SWITCH_RESET_EVENTS 54
#define AFD_SWITCH_CONNECT_IND 55
#define AFD_SWITCH_CMPL_ACCEPT 56
#define AFD_SWITCH_CMPL_REQUEST 57
#define AFD_SWITCH_CMPL_IO 58
#define AFD_SWITCH_REFRESH_ENDP 59
#define AFD_SWITCH_GET_PHYSICAL_ADDR 60
#define AFD_SWITCH_ACQUIRE_CTX 61
#define AFD_SWITCH_TRANSFER_CTX 62
#define AFD_SWITCH_GET_SERVICE_PID 63
#define AFD_SWITCH_SET_SERVICE_PROCESS 64
#define AFD_SWITCH_PROVIDER_CHANGE 65
#define AFD_SWITCH_ADDRLIST_CHANGE 66
#define AFD_NUM_IOCTLS 67
#define IOCTL_AFD_BIND _AFD_CONTROL_CODE( AFD_BIND, METHOD_NEITHER )
#define IOCTL_AFD_CONNECT _AFD_CONTROL_CODE( AFD_CONNECT, METHOD_NEITHER )
#define IOCTL_AFD_START_LISTEN _AFD_CONTROL_CODE( AFD_START_LISTEN, METHOD_NEITHER )
#define IOCTL_AFD_WAIT_FOR_LISTEN _AFD_CONTROL_CODE( AFD_WAIT_FOR_LISTEN, METHOD_BUFFERED )
#define IOCTL_AFD_ACCEPT _AFD_CONTROL_CODE( AFD_ACCEPT, METHOD_BUFFERED )
#define IOCTL_AFD_RECEIVE _AFD_CONTROL_CODE( AFD_RECEIVE, METHOD_NEITHER )
#define IOCTL_AFD_RECEIVE_DATAGRAM _AFD_CONTROL_CODE( AFD_RECEIVE_DATAGRAM, METHOD_NEITHER )
#define IOCTL_AFD_SEND _AFD_CONTROL_CODE( AFD_SEND, METHOD_NEITHER )
#define IOCTL_AFD_SEND_DATAGRAM _AFD_CONTROL_CODE( AFD_SEND_DATAGRAM, METHOD_NEITHER )
#define IOCTL_AFD_POLL _AFD_CONTROL_CODE( AFD_POLL, METHOD_BUFFERED )
#define IOCTL_AFD_PARTIAL_DISCONNECT _AFD_CONTROL_CODE( AFD_PARTIAL_DISCONNECT, METHOD_NEITHER )
#define IOCTL_AFD_GET_ADDRESS _AFD_CONTROL_CODE( AFD_GET_ADDRESS, METHOD_NEITHER )
#define IOCTL_AFD_QUERY_RECEIVE_INFO _AFD_CONTROL_CODE( AFD_QUERY_RECEIVE_INFO, METHOD_NEITHER )
#define IOCTL_AFD_QUERY_HANDLES _AFD_CONTROL_CODE( AFD_QUERY_HANDLES, METHOD_NEITHER )
#define IOCTL_AFD_SET_INFORMATION _AFD_CONTROL_CODE( AFD_SET_INFORMATION, METHOD_NEITHER )
#define IOCTL_AFD_GET_REMOTE_ADDRESS _AFD_CONTROL_CODE( AFD_GET_REMOTE_ADDRESS, METHOD_NEITHER )
#define IOCTL_AFD_GET_CONTEXT _AFD_CONTROL_CODE( AFD_GET_CONTEXT, METHOD_NEITHER )
#define IOCTL_AFD_SET_CONTEXT _AFD_CONTROL_CODE( AFD_SET_CONTEXT, METHOD_NEITHER )
#define IOCTL_AFD_SET_CONNECT_DATA _AFD_CONTROL_CODE( AFD_SET_CONNECT_DATA, METHOD_NEITHER )
#define IOCTL_AFD_SET_CONNECT_OPTIONS _AFD_CONTROL_CODE( AFD_SET_CONNECT_OPTIONS, METHOD_NEITHER )
#define IOCTL_AFD_SET_DISCONNECT_DATA _AFD_CONTROL_CODE( AFD_SET_DISCONNECT_DATA, METHOD_NEITHER )
#define IOCTL_AFD_SET_DISCONNECT_OPTIONS _AFD_CONTROL_CODE( AFD_SET_DISCONNECT_OPTIONS, METHOD_NEITHER )
#define IOCTL_AFD_GET_CONNECT_DATA _AFD_CONTROL_CODE( AFD_GET_CONNECT_DATA, METHOD_NEITHER )
#define IOCTL_AFD_GET_CONNECT_OPTIONS _AFD_CONTROL_CODE( AFD_GET_CONNECT_OPTIONS, METHOD_NEITHER )
#define IOCTL_AFD_GET_DISCONNECT_DATA _AFD_CONTROL_CODE( AFD_GET_DISCONNECT_DATA, METHOD_NEITHER )
#define IOCTL_AFD_GET_DISCONNECT_OPTIONS _AFD_CONTROL_CODE( AFD_GET_DISCONNECT_OPTIONS, METHOD_NEITHER )
#define IOCTL_AFD_SIZE_CONNECT_DATA _AFD_CONTROL_CODE( AFD_SIZE_CONNECT_DATA, METHOD_NEITHER )
#define IOCTL_AFD_SIZE_CONNECT_OPTIONS _AFD_CONTROL_CODE( AFD_SIZE_CONNECT_OPTIONS, METHOD_NEITHER )
#define IOCTL_AFD_SIZE_DISCONNECT_DATA _AFD_CONTROL_CODE( AFD_SIZE_DISCONNECT_DATA, METHOD_NEITHER )
#define IOCTL_AFD_SIZE_DISCONNECT_OPTIONS _AFD_CONTROL_CODE( AFD_SIZE_DISCONNECT_OPTIONS, METHOD_NEITHER )
#define IOCTL_AFD_GET_INFORMATION _AFD_CONTROL_CODE( AFD_GET_INFORMATION, METHOD_NEITHER )
#define IOCTL_AFD_TRANSMIT_FILE _AFD_CONTROL_CODE( AFD_TRANSMIT_FILE, METHOD_NEITHER )
#define IOCTL_AFD_SUPER_ACCEPT _AFD_CONTROL_CODE( AFD_SUPER_ACCEPT, METHOD_NEITHER )
#define IOCTL_AFD_EVENT_SELECT _AFD_CONTROL_CODE( AFD_EVENT_SELECT, METHOD_NEITHER )
#define IOCTL_AFD_ENUM_NETWORK_EVENTS _AFD_CONTROL_CODE( AFD_ENUM_NETWORK_EVENTS, METHOD_NEITHER )
#define IOCTL_AFD_DEFER_ACCEPT _AFD_CONTROL_CODE( AFD_DEFER_ACCEPT, METHOD_BUFFERED )
#define IOCTL_AFD_WAIT_FOR_LISTEN_LIFO _AFD_CONTROL_CODE( AFD_WAIT_FOR_LISTEN_LIFO, METHOD_BUFFERED )
#define IOCTL_AFD_SET_QOS _AFD_CONTROL_CODE( AFD_SET_QOS, METHOD_BUFFERED )
#define IOCTL_AFD_GET_QOS _AFD_CONTROL_CODE( AFD_GET_QOS, METHOD_BUFFERED )
#define IOCTL_AFD_NO_OPERATION _AFD_CONTROL_CODE( AFD_NO_OPERATION, METHOD_NEITHER )
#define IOCTL_AFD_VALIDATE_GROUP _AFD_CONTROL_CODE( AFD_VALIDATE_GROUP, METHOD_BUFFERED )
#define IOCTL_AFD_GET_UNACCEPTED_CONNECT_DATA _AFD_CONTROL_CODE( AFD_GET_UNACCEPTED_CONNECT_DATA, METHOD_NEITHER )
#define IOCTL_AFD_ROUTING_INTERFACE_QUERY _AFD_CONTROL_CODE( AFD_ROUTING_INTERFACE_QUERY, METHOD_NEITHER )
#define IOCTL_AFD_ROUTING_INTERFACE_CHANGE _AFD_CONTROL_CODE( AFD_ROUTING_INTERFACE_CHANGE, METHOD_BUFFERED )
#define IOCTL_AFD_ADDRESS_LIST_QUERY _AFD_CONTROL_CODE( AFD_ADDRESS_LIST_QUERY, METHOD_NEITHER )
#define IOCTL_AFD_ADDRESS_LIST_CHANGE _AFD_CONTROL_CODE( AFD_ADDRESS_LIST_CHANGE, METHOD_BUFFERED )
#define IOCTL_AFD_JOIN_LEAF _AFD_CONTROL_CODE( AFD_JOIN_LEAF, METHOD_NEITHER )
#define IOCTL_AFD_TRANSPORT_IOCTL _AFD_CONTROL_CODE( AFD_TRANSPORT_IOCTL, METHOD_NEITHER )
#define IOCTL_AFD_TRANSMIT_PACKETS _AFD_CONTROL_CODE( AFD_TRANSMIT_PACKETS, METHOD_NEITHER )
#define IOCTL_AFD_SUPER_CONNECT _AFD_CONTROL_CODE( AFD_SUPER_CONNECT, METHOD_NEITHER )
#define IOCTL_AFD_SUPER_DISCONNECT _AFD_CONTROL_CODE( AFD_SUPER_DISCONNECT, METHOD_NEITHER )
#define IOCTL_AFD_RECEIVE_MESSAGE _AFD_CONTROL_CODE( AFD_RECEIVE_MESSAGE, METHOD_NEITHER )
//
// SAN support
//
//
//
// SAN IOCTL control codes.
//
#define IOCTL_AFD_SWITCH_CEMENT_SAN _AFD_CONTROL_CODE( AFD_SWITCH_CEMENT_SAN, METHOD_NEITHER )
/*++
Ioctl Description:
Changes the AFD endpoint type to SAN to indicate that
it is used for support of user mode SAN providers
Associates switch context with the endpoint.
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - input parameters for the operation (AFD_SWITCH_CONTEXT_INFO)
SocketHandle - handle of the endpoint being changed to SAN
SwitchContext - switch context associated with the endpoint
InputBufferLength - sizeof(AFD_SWITCH_CONTEXT_INFO)
OutputBuffer - NULL (ingored)
OutputBufferLength - 0 (ignored)
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or switch socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or switch socket handle correspond to AFD
endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input buffer is of incorrect size.
other - failed when attempting to access switch socket, input buffer, or switch context.
IoStatus.Information - 0 (ignored)
--*/
#define IOCTL_AFD_SWITCH_SET_EVENTS _AFD_CONTROL_CODE( AFD_SWITCH_SET_EVENTS, METHOD_NEITHER )
/*++
Ioctl Description:
Sets the poll event on the san endpoint to report
to the application via various forms of the select.
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - input parameters for the operation (AFD_SWITCH_EVENT_INFO)
SocketHandle - handle of the SAN endpoint (except
AFD_POLL_EVENT_CONNECT_FAIL which
just needs a bound endpoint).
SwitchContext - switch context associated with endpoint (NULL
for AFD_POLL_EVENT_CONNECT_FAIL) to validate
the handle-endpoint association
EventBit - event bit to set
Status - associated status (for AFD_POLL_EVENT_CONNECT_FAIL)
InputBufferLength - sizeof(AFD_SWITCH_EVENT_INFO)
OutputBuffer - NULL (ignored)
OutputBufferLength - 0 (ignored)
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or switch socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or switch socket handle+context correspond
to AFD endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input buffer is of incorrect size.
other - failed when attempting to access switch socket, input buffer, or switch context.
IoStatus.Information - 0 (ignored)
--*/
#define IOCTL_AFD_SWITCH_RESET_EVENTS _AFD_CONTROL_CODE( AFD_SWITCH_RESET_EVENTS, METHOD_NEITHER )
/*++
Ioctl Description:
Resets the poll event on the san endpoint so that it is no
longer reported to the application via various forms of the select
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - input parameters for the operation (AFD_SWITCH_EVENT_INFO)
SocketHandle - handle of the SAN endpoint
SwitchContext - switch context associated with endpoint
to validate the handle-endpoint association
EventBit - event bit to reset
Status - associated status (ignored)
InputBufferLength - sizeof(AFD_SWITCH_EVENT_INFO)
OutputBuffer - NULL (ignored)
OutputBufferLength - 0 (ignored)
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or switch socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or switch socket handle+context correspond
to AFD endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input buffer is of incorrect size.
other - failed when attempting to access switch socket, input buffer, or switch context.
IoStatus.Information - 0 (ignored)
--*/
#define IOCTL_AFD_SWITCH_CONNECT_IND _AFD_CONTROL_CODE( AFD_SWITCH_CONNECT_IND, METHOD_OUT_DIRECT )
/*++
Ioctl Description:
Implements connect indication from SAN provider.
Picks up the accept from the listening endpoint queue
or queues the indication an signals the application to come
down with an accept.
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - input parameters for the operation (AFD_SWITCH_CONNECT_INFO):
ListenHandle - handle of the listening endpoint
RemoteAddress - remote and local addresses associated
with indication incoming connection
InputBufferLength - sizeof(AFD_SWITCH_CONNECT_INFO)+addresses
OutputBuffer - output parameters for the operation (AFD_SWITCH_ACCEPT_INFO):
AcceptHandle - handle of the accepting endpoint
ReceiveLength - length of the receive buffer supplied by
the application in AcceptEx
OutputBufferLength - sizeof (AFD_SWITCH_ACCEPT_INFO)
Return Value:
STATUS_PENDING - request was queued waiting for corresponding transfer request
from the current socket context owner process.
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or listen socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or listen socket handle correspond
to AFD endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input or output buffers are of incorrect size.
STATUS_CANCELLED - connection indication was cancelled (thread exited or
accepting and/or listening socket closed)
other - failed when attempting to access listening socket, input or output buffers
IoStatus.Information - sizeof (AFD_SWITCH_ACCEPT_INFO) in case of success.
--*/
#define IOCTL_AFD_SWITCH_CMPL_ACCEPT _AFD_CONTROL_CODE( AFD_SWITCH_CMPL_ACCEPT, METHOD_NEITHER )
/*++
Ioctl Description:
Completes the acceptance of SAN connection
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - input parameters for the operation (AFD_SWITCH_CONTEXT_INFO)
SocketHandle - handle of the accepting endpoint
SwitchContext - switch context associated with the endpoint
InputBufferLength - sizeof(AFD_SWITCH_CONTEXT_INFO)
OutputBuffer - data to copy into the AcceptEx receive buffer
OutputBufferLength - size of received data
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or switch socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or switch socket handle+context correspond
to AFD endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input buffer is of incorrect size.
STATUS_LOCAL_DISCONNECT - accept was aborted by the application.
other - failed when attempting to access accepte socket, input/output buffers,
or switch context.
IoStatus.Information - Number of bytes copied into application's receive buffer.
--*/
#define IOCTL_AFD_SWITCH_CMPL_REQUEST _AFD_CONTROL_CODE( AFD_SWITCH_CMPL_REQUEST, METHOD_NEITHER )
/*++
Ioctl Description:
Completes the redirected read/write request processed by SAN provider
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - input parameters for the operation (AFD_SWITCH_REQUEST_INFO)
SocketHandle - SAN endpoint on which to complete the request
SwitchContext - switch context associated with endpoint
to validate the handle-endpoint association
RequestContext - value that identifies the request to complete
RequestStatus - status with which to complete the request (
STATUS_PENDING has special meaning, request
is not completed - merely data is copied)
DataOffset - offset in the request buffer to read/write the data
InputBufferLength - sizeof (AFD_SWITCH_REQUEST_INFO)
OutputBuffer - switch buffer to read/write data
OutputBufferLength - length of the buffer
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or switch socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or switch socket handle+context correspond
to AFD endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input buffer is of incorrect size.
STATUS_CANCELLED - request to be completed has already been cancelled
other - failed when attempting to access SAN endpoint,
input buffer or output buffers.
IoStatus.Information - number of bytes copied from/to switch buffer.
--*/
#define IOCTL_AFD_SWITCH_CMPL_IO _AFD_CONTROL_CODE( AFD_SWITCH_CMPL_IO, METHOD_NEITHER )
/*++
Ioctl Description:
Simulates async IO completion for the switch.
Arguments:
Handle - SAN socket handle on which to complete the IO.
InputBuffer - input parameters for the operation (IO_STATUS_BLOCK)
Status - final operation status
Information - associated information (number of bytes
transferred to/from request buffer(s))
InputBufferLength - sizeof (IO_STATUS_BLOCK)
OutputBuffer - NULL (ignored)
OutputBufferLength - 0 (ignored)
Return Value:
IoStatus.Status:
STATUS_INVALID_PARAMETER - input buffer is of invalid size.
other - status of the IO operation or failure code when attempting to
access input buffer.
IoStatus.Information - information from the input buffer
--*/
#define IOCTL_AFD_SWITCH_REFRESH_ENDP _AFD_CONTROL_CODE( AFD_SWITCH_REFRESH_ENDP, METHOD_NEITHER )
/*++
Ioctl Description:
Refreshes endpoint so it can be used again in AcceptEx
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - input parameters for the operation (AFD_SWITCH_CONTEXT_INFO)
SocketHandle - Socket to refresh
SwitchContext - switch context associated with endpoint
to validate the handle-endpoint association
InputBufferLength - sizeof (AFD_SWITCH_CONTEXT_INFO)
OutputBuffer - NULL (ignored)
OutputBufferLength - 0 (ignored)
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or switch socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or switch socket handle+context correspond
to AFD endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input buffer is of incorrect size.
other - failed when attempting to access SAN endpoint,
input buffer buffer.
IoStatus.Information - 0 (ignored)
--*/
#define IOCTL_AFD_SWITCH_GET_PHYSICAL_ADDR _AFD_CONTROL_CODE( AFD_SWITCH_GET_PHYSICAL_ADDR, METHOD_NEITHER )
/*++
Ioctl Description:
Returns physical address corresponding to provided virtual address.
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - user mode virtual address
InputBufferLength - access mode
OutputBuffer - Buffer to place physical address into.
OutputBufferLength - sizeof (PHYSICAL_ADDRESS)
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle is not AFD file object handle
STATUS_INVALID_HANDLE - helper handle corresponds to AFD endpoint of incorrect
type.
STATUS_BUFFER_TOO_SMALL - output buffer is of incorrect size.
STATUS_INVALID_PARAMETER - invalid access mode.
other - failed when attempting to access SAN endpoint,
input buffer buffer.
IoStatus.Information - sizeof(PHYSICAL_ADDRESS).
--*/
#define IOCTL_AFD_SWITCH_ACQUIRE_CTX _AFD_CONTROL_CODE( AFD_SWITCH_ACQUIRE_CTX, METHOD_NEITHER )
/*++
Ioctl Description:
Requests transfer of the socket context to the current process.
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - input parameters for the operation (AFD_SWITCH_ACQUIRE_CTX_INFO)
SocketHandle - SAN endpoint on which to complete the request
SwitchContext - switch context to be associated with endpoint
when context transfered to the current process.
SocketCtxBuf - buffer to receive current socket context from
another process
SocketCtxBufSize - size of the buffer
InputBufferLength - sizeof (AFD_SWITCH_ACQUIRE_CTX_INFO)
OutputBuffer - buffer to receive data buffered on the socket in another process
and not yet delivered to the applicaiton
OutputBufferLength - length of the receive buffer
Return Value:
STATUS_PENDING - request was queued waiting for corresponding transfer request
from the current socket context owner process.
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or switch socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or switch socket handle correspond
to AFD endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input buffer is of incorrect size.
other - failed when attempting to access SAN endpoint,
input buffer or output buffers.
IoStatus.Information - number of bytes copied to receive buffer.
--*/
#define IOCTL_AFD_SWITCH_TRANSFER_CTX _AFD_CONTROL_CODE( AFD_SWITCH_TRANSFER_CTX, METHOD_NEITHER )
/*++
Ioctl Description:
Requests AFD to transfer endpoint into another process context
Arguments:
InputBuffer - input parameters for the operation (AFD_SWITCH_TRANSFER_CTX_INFO)
SocketHandle - Socket to transfer
SwitchContext - switch context associated with endpoint
to validate the handle-endpoint association
RequestContext - value that identifies corresponding acquire request,
NULL if this is unsolicited request to transfer to
the service process.
SocketCtxBuf - socket context to copy destination process
acquire request context buffer
SocketCtxSize - size of the context buffer to copy
RcvBufferArray - array of buffered data to transfer to
destination process acquire request
RcvBufferCount - number of elements in the array.
InputBufferLength - sizeof (AFD_SWITCH_TRANSFER_CTX_INFO)
OutputBuffer - NULL (ignored)
OutputBufferLength - 0 (ignored)
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle or switch socket handle are not
AFD file object handles
STATUS_INVALID_HANDLE - helper handle or switch socket handle+context correspond
to AFD endpoint of incorrect type/state.
STATUS_INVALID_PARAMETER - input buffer is of incorrect size.
other - failed when attempting to access SAN endpoint,
input buffer buffer.
IoStatus.Information - number of bytes copied from RcvBufferArray.
--*/
#define IOCTL_AFD_SWITCH_GET_SERVICE_PID _AFD_CONTROL_CODE( AFD_SWITCH_GET_SERVICE_PID, METHOD_NEITHER )
/*++
Ioctl Description:
Returns PID of the service process used for intermediate socket duplication.
Arguments:
Handle - helper endpoint handle for the process.
InputBuffer - NULL, ignored
InputBufferLength - 0, ignored
OutputBuffer - NULL, ignored
OutputBufferLength - 0, ignored
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle is not AFD file object handle
STATUS_INVALID_HANDLE - helper handle corresponds to AFD endpoint of incorrect
type.
IoStatus.Information - pid of the service process.
--*/
#define IOCTL_AFD_SWITCH_SET_SERVICE_PROCESS _AFD_CONTROL_CODE( AFD_SWITCH_SET_SERVICE_PROCESS, METHOD_NEITHER )
/*++
Ioctl Description:
Notifies AFD that this process will be used for handle duplication services
Arguments:
Handle - helper endpoint handle for the service process.
InputBuffer - NULL, ignored
InputBufferLength - 0, ignored
OutputBuffer - NULL, ignored
OutputBufferLength - 0, ignored
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle is not AFD file object handle
STATUS_INVALID_HANDLE - helper handle corresponds to AFD endpoint of incorrect
type.
STATUS_ACCESS_DENIED - helper endpoint is not for the service process.
IoStatus.Information - 0, ignored.
--*/
#define IOCTL_AFD_SWITCH_PROVIDER_CHANGE _AFD_CONTROL_CODE( AFD_SWITCH_PROVIDER_CHANGE, METHOD_NEITHER )
/*++
Ioctl Description:
Notifies interested processes of SAN provider addition/deletion/change.
Arguments:
Handle - helper endpoint handle for the service process.
InputBuffer - NULL, ignored
InputBufferLength - 0, ignored
OutputBuffer - NULL, ignored
OutputBufferLength - 0, ignored
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle is not AFD file object handle
STATUS_INVALID_HANDLE - helper handle corresponds to AFD endpoint of incorrect
type.
STATUS_ACCESS_DENIED - helper endpoint is not for the service process.
IoStatus.Information - 0, ignored.
--*/
#define IOCTL_AFD_SWITCH_ADDRLIST_CHANGE _AFD_CONTROL_CODE( AFD_SWITCH_ADDRLIST_CHANGE, METHOD_BUFFERED )
/*++
Ioctl Description:
SAN specific version of address list change notifications.
Capture provider installation/removal in addition to plain
address list changes.
Arguments:
Handle - helper endpoint handle for the service process.
InputBuffer - Input parameters for the operation (AFD_TRANSPORT_IOCTL_INFO):
AfdFlags - operation flags (e.g. AFD_OVERLAPPED)
Handle - unused
PollEvent - unused
IoControlCode - IOCTL_AFD_ADDRESS_LIST_CHANGE
InputBuffer - pointer to address family (AF_INET)
InputBufferLength - sizeof (USHORT)
InputBufferLength - sizeof (AFD_TRANSPORT_IOCTL_INFO)
OutputBuffer - NULL, ignored
OutputBufferLength - 0, ignored
Return Value:
IoStatus.Status:
STATUS_SUCCESS - operation succeeded.
STATUS_OBJECT_TYPE_MISMATCH - helper handle is not AFD file object handle
STATUS_INVALID_HANDLE - helper handle corresponds to AFD endpoint of incorrect
type.
IoStatus.Information - 0 - regular address list change
otherwise, seq number of provider list change.
--*/
// Open packet that identifies SAN helper endpoint used
// for communication between SAN switch and AFD.
// This is EA name
//
#define AfdSwitchOpenPacket "AfdSwOpenPacket"
#define AFD_SWITCH_OPEN_PACKET_NAME_LENGTH (sizeof(AfdSwitchOpenPacket)-1)
//
// Data passed in the open packet
// This is EA value
//
typedef struct _AFD_SWITCH_OPEN_PACKET {
HANDLE CompletionPort; // Completion port notify SAN switch
// of SAN io completions
HANDLE CompletionEvent;// Completion event to distinguish IO issued
// by SAN switch from application IO.
} AFD_SWITCH_OPEN_PACKET, *PAFD_SWITCH_OPEN_PACKET;
typedef struct _AFD_SWITCH_CONTEXT {
LONG EventsActive; // Poll events activated by switch
LONG RcvCount; // Count of polls for receive
LONG ExpCount; // Count of polls for expedited
LONG SndCount; // Count of polls for send
BOOLEAN SelectFlag; // TRUE if app has done any form of select
} AFD_SWITCH_CONTEXT, *PAFD_SWITCH_CONTEXT;
//
// Information for associating AFD endpoint with SAN provider
//
typedef struct _AFD_SWITCH_CONTEXT_INFO {
HANDLE SocketHandle; // Handle to associate with SAN provider
PAFD_SWITCH_CONTEXT SwitchContext; // Opaque context value maintained for the switch
} AFD_SWITCH_CONTEXT_INFO, *PAFD_SWITCH_CONTEXT_INFO;
//
// Information for connection indication from SAN provider to AFD
//
typedef struct _AFD_SWITCH_CONNECT_INFO {
HANDLE ListenHandle; // Listening socket handle
PAFD_SWITCH_CONTEXT SwitchContext;
TRANSPORT_ADDRESS RemoteAddress; // Address of the remote peer wishing
// to connect
} AFD_SWITCH_CONNECT_INFO, *PAFD_SWITCH_CONNECT_INFO;
//
// Information returned by the AFD to switch in response
// to connection indication
//
typedef struct _AFD_SWITCH_ACCEPT_INFO {
HANDLE AcceptHandle; // Socket handle to use to accept connection
ULONG ReceiveLength; // Length of the initial receive buffer (for AcceptEx)
} AFD_SWITCH_ACCEPT_INFO, *PAFD_SWITCH_ACCEPT_INFO;
//
// Information passed by the switch to signal network events on the
// endpoint (socket)
//
typedef struct _AFD_SWITCH_EVENT_INFO {
HANDLE SocketHandle; // Socket handle on which to signal
PAFD_SWITCH_CONTEXT SwitchContext; // Switch context associated with the socket
ULONG EventBit; // Event bit to set/reset (AFD_POLL_xxx_BIT constants)
NTSTATUS Status; // Status code associated with the event (this
// is used for AFD_POLL_CONNECT_FAIL_BIT)
} AFD_SWITCH_EVENT_INFO, *PAFD_SWITCH_EVENT_INFO;
//
// Information passed by the switch to retreive parameters/complete
// redirected read/write request
//
typedef struct _AFD_SWITCH_REQUEST_INFO {
HANDLE SocketHandle; // Socket handle on which request us active
PAFD_SWITCH_CONTEXT SwitchContext; // Switch context associated with the socket
PVOID RequestContext; // Request context that identifies it
NTSTATUS RequestStatus; // Completion status of the request (STATUS_PENDING
// indicates that request should NOT be completed yet)
ULONG DataOffset; // Offset from which to start copying data from/to
// application's buffer
} AFD_SWITCH_REQUEST_INFO, *PAFD_SWITCH_REQUEST_INFO;
//
// Access type (read access or write access) that's needed for an app buffer
// whose physical address is requested thru AfdSanFastGetPhysicalAddr
//
#define MEM_READ_ACCESS 1
#define MEM_WRITE_ACCESS 2
//
// Information passed between processes when socket is duplicated.
//
typedef struct _AFD_SWITCH_ACQUIRE_CTX_INFO {
HANDLE SocketHandle; // Socket handle which needs to be transferred
PAFD_SWITCH_CONTEXT SwitchContext; // Switch context to be associated with the socket
PVOID SocketCtxBuf; // Socket context buffer
ULONG SocketCtxBufSize; // Socket context buffer size
} AFD_SWITCH_ACQUIRE_CTX_INFO, *PAFD_SWITCH_ACQUIRE_CTX_INFO;
typedef struct _AFD_SWITCH_TRANSFER_CTX_INFO {
HANDLE SocketHandle; // Socket handle which needs to be transferred
PAFD_SWITCH_CONTEXT SwitchContext; // Switch context associated with the socket
PVOID RequestContext; // Value that identifies corresponding acquire request
PVOID SocketCtxBuf; // Socket context buffer
ULONG SocketCtxBufSize; // Socket context buffer size
LPWSABUF RcvBufferArray; // Receive buffers to copy to destination process
ULONG RcvBufferCount; // Number of receive buffers
NTSTATUS Status; // Status of transfer opertaion.
} AFD_SWITCH_TRANSFER_CTX_INFO, *PAFD_SWITCH_TRANSFER_CTX_INFO;
//
// Request from AFD to switch (passed via completion port)
//
#define AFD_SWITCH_REQUEST_CLOSE 0
/*++
Request Description:
All references to the socket have been closed in all processes, safe
to destroy the SAN provider socket and connection
Arguments (NtRemoveIoCompletion return parameters):
Key - switch context associated with the socket
ApcContext - AFD_SWITCH_MAKE_REQUEST_CONTEXT(0, AFD_SWITCH_REQUEST_CLOSE)
IoStatus.Status - STATUS_SUCCESS (ignored)
IoStatus.Information - 0 (ignored)
--*/
#define AFD_SWITCH_REQUEST_READ 1
/*++
Request Description:
Read request arrived from the application via IO subsystem interface.
Arguments (NtRemoveIoCompletion return parameters):
Key - switch context associated with the socket
ApcContext - AFD_SWITCH_MAKE_REQUEST_CONTEXT(RequestId, AFD_SWITCH_REQUEST_READ)
IoStatus.Status - STATUS_SUCCESS (ignored)
IoStatus.Information - size of the receive buffer supplied by the application
--*/
#define AFD_SWITCH_REQUEST_WRITE 2
/*++
Request Description:
Write request arrived from the application via IO subsystem interface.
Arguments (NtRemoveIoCompletion return parameters):
Key - switch context associated with the socket
ApcContext - AFD_SWITCH_MAKE_REQUEST_CONTEXT(RequestId, AFD_SWITCH_REQUEST_WRITE)
IoStatus.Status - STATUS_SUCCESS (ignored)
IoStatus.Information - size of the send data supplied by the application
--*/
#define AFD_SWITCH_REQUEST_TFCTX 3
/*++
Request Description:
Another process requests ownership of the socket.
Arguments (NtRemoveIoCompletion return parameters):
Key - switch context associated with the socket
ApcContext - AFD_SWITCH_MAKE_REQUEST_CONTEXT(RequestId, AFD_SWITCH_REQUEST_TFCTX)
IoStatus.Status - STATUS_SUCCESS (ignored)
IoStatus.Information - PID of the process requesting ownership.
--*/
#define AFD_SWITCH_REQUEST_CHCTX 4
/*++
Request Description:
Relationship between socket handle and switch context has become invalid
(application must have closed the original socket and using duplicated handle)
Arguments (NtRemoveIoCompletion return parameters):
Key - switch context associated with the socket
ApcContext - AFD_SWITCH_MAKE_REQUEST_CONTEXT(0, AFD_SWITCH_REQUEST_CHCTX)
IoStatus.Status - STATUS_SUCCESS (ignored)
IoStatus.Information - Handle currently used by the application.
--*/
#define AFD_SWITCH_REQUEST_AQCTX 5
/*++
Request Description:
Request to service process to acquire ownership of the socket
Arguments (NtRemoveIoCompletion return parameters):
Key - NULL
ApcContext - AFD_SWITCH_MAKE_REQUEST_CONTEXT(0, AFD_SWITCH_REQUEST_AQCTX)
IoStatus.Status - STATUS_SUCCESS (ignored)
IoStatus.Information - Handle of the socket to be acquired.
--*/
#define AFD_SWITCH_REQUEST_CLSOC 6
/*++
Request Description:
Request to service process to close the socket
Arguments (NtRemoveIoCompletion return parameters):
Key - switch context associated with the socket
ApcContext - AFD_SWITCH_MAKE_REQUEST_CONTEXT(0, AFD_SWITCH_REQUEST_CLSOC)
IoStatus.Status - STATUS_SUCCESS (ignored)
IoStatus.Information - 0.
--*/
#define AFD_SWITCH_REQUEST_ID_SHIFT 3
#define AFD_SWITCH_REQUEST_TYPE_MASK \
((1<<AFD_SWITCH_REQUEST_ID_SHIFT)-1)
#define AFD_SWITCH_MAKE_REQUEST_CONTEXT(_id,_type) \
UlongToPtr(((_id)<<AFD_SWITCH_REQUEST_ID_SHIFT)+(_type))
//
// Retrives request type from the request context
//
#define AFD_SWITCH_REQUEST_TYPE(_RequestContext) \
(((ULONG_PTR)(_RequestContext))&AFD_SWITCH_REQUEST_TYPE_MASK)
#endif // ndef _AFD_