mirror of
https://github.com/reactos/reactos.git
synced 2025-01-03 21:09:19 +00:00
490fbfb2c5
Names need decoration (stdcall) in order to be linked. When using the wsk.h header functions exported therein should be WSKAPI (which enforces the stdcall calling convention). Linking would later fail because stdcall functions are named differently in the object code.
622 lines
16 KiB
C
622 lines
16 KiB
C
/*
|
|
* wsk.h
|
|
*
|
|
* Windows Sockets Kernel-Mode Interface
|
|
*
|
|
* This file is part of the ReactOS DDK package.
|
|
*
|
|
* Contributors:
|
|
* Timo Kreuzer (timo.kreuzer@reactos.org)
|
|
*
|
|
* THIS SOFTWARE IS NOT COPYRIGHTED
|
|
*
|
|
* This source code is offered for use in the public domain. You may
|
|
* use, modify or distribute it freely.
|
|
*
|
|
* This code is distributed in the hope that it will be useful but
|
|
* WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
|
|
* DISCLAIMED. This includes but is not limited to warranties of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
*
|
|
*/
|
|
#pragma once
|
|
#define _WSK_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <netioddk.h>
|
|
#include <ws2def.h>
|
|
#include <mswsockdef.h>
|
|
|
|
extern CONST NPIID NPI_WSK_INTERFACE_ID;
|
|
|
|
#define WSKAPI NTAPI
|
|
|
|
#define MAKE_WSK_VERSION(Mj, Mn) ((USHORT)((Mj) << 8) | (USHORT)((Mn) & 0xff))
|
|
#define WSK_MAJOR_VERSION(V) ((UCHAR)((V) >> 8))
|
|
#define WSK_MINOR_VERSION(V) ((UCHAR)(V))
|
|
#define WSK_FLAG_AT_DISPATCH_LEVEL 0x00000008
|
|
#define WSK_FLAG_RELEASE_ASAP 0x00000002
|
|
#define WSK_FLAG_ENTIRE_MESSAGE 0x00000004
|
|
#define WSK_FLAG_ABORTIVE 0x00000001
|
|
#define WSK_FLAG_BASIC_SOCKET 0x00000000
|
|
#define WSK_FLAG_LISTEN_SOCKET 0x00000001
|
|
#define WSK_FLAG_CONNECTION_SOCKET 0x00000002
|
|
#define WSK_FLAG_DATAGRAM_SOCKET 0x00000004
|
|
#define WSK_TRANSPORT_LIST_QUERY 2
|
|
#define WSK_TRANSPORT_LIST_CHANGE 3
|
|
#define WSK_CACHE_SD 4
|
|
#define WSK_RELEASE_SD 5
|
|
#define WSK_TDI_DEVICENAME_MAPPING 6
|
|
#define WSK_SET_STATIC_EVENT_CALLBACKS 7
|
|
#define WSK_TDI_BEHAVIOR 8
|
|
#define WSK_TDI_BEHAVIOR_BYPASS_TDI 0x00000001
|
|
#define SO_WSK_SECURITY (WSK_SO_BASE+1)
|
|
#define SO_WSK_EVENT_CALLBACK (WSK_SO_BASE+2)
|
|
#define WSK_EVENT_RECEIVE_FROM 0x00000100
|
|
#define WSK_EVENT_ACCEPT 0x00000200
|
|
#define WSK_EVENT_SEND_BACKLOG 0x00000010
|
|
#define WSK_EVENT_RECEIVE 0x00000040
|
|
#define WSK_EVENT_DISCONNECT 0x00000080
|
|
#define WSK_EVENT_DISABLE 0x80000000
|
|
#define SIO_WSK_SET_REMOTE_ADDRESS _WSAIOW(IOC_WSK,0x1)
|
|
#define SIO_WSK_REGISTER_EXTENSION _WSAIORW(IOC_WSK,0x2)
|
|
#define SIO_WSK_QUERY_IDEAL_SEND_BACKLOG _WSAIOR(IOC_WSK,0x3)
|
|
#define SIO_WSK_QUERY_RECEIVE_BACKLOG _WSAIOR(IOC_WSK,0x4)
|
|
#define SIO_WSK_QUERY_INSPECT_ID _WSAIOR(IOC_WSK,0x5)
|
|
#define SIO_WSK_SET_SENDTO_ADDRESS _WSAIOW(IOC_WSK,0x6)
|
|
#define WSK_FLAG_NODELAY 0x00000002
|
|
#define WSK_FLAG_WAITALL 0x00000002
|
|
#define WSK_FLAG_DRAIN 0x00000004
|
|
#define WSK_NO_WAIT 0
|
|
#define WSK_INFINITE_WAIT 0xffffffff
|
|
|
|
typedef enum
|
|
{
|
|
WskInspectReject,
|
|
WskInspectAccept,
|
|
WskInspectPend,
|
|
WskInspectMax
|
|
} WSK_INSPECT_ACTION, *PWSK_INSPECT_ACTION;
|
|
|
|
typedef enum
|
|
{
|
|
WskSetOption,
|
|
WskGetOption,
|
|
WskIoctl,
|
|
WskControlMax
|
|
} WSK_CONTROL_SOCKET_TYPE, *PWSK_CONTROL_SOCKET_TYPE;
|
|
|
|
typedef PVOID PWSK_CLIENT;
|
|
|
|
typedef struct _WSK_SOCKET
|
|
{
|
|
const VOID *Dispatch;
|
|
} WSK_SOCKET, *PWSK_SOCKET;
|
|
|
|
typedef struct _WSK_BUF
|
|
{
|
|
PMDL Mdl;
|
|
ULONG Offset;
|
|
SIZE_T Length;
|
|
} WSK_BUF, *PWSK_BUF;
|
|
|
|
typedef struct _WSK_INSPECT_ID
|
|
{
|
|
ULONG_PTR Key;
|
|
ULONG SerialNumber;
|
|
} WSK_INSPECT_ID, *PWSK_INSPECT_ID;
|
|
|
|
typedef struct _WSK_DATAGRAM_INDICATION
|
|
{
|
|
struct _WSK_DATAGRAM_INDICATION *Next;
|
|
WSK_BUF Buffer;
|
|
_Field_size_bytes_(ControlInfoLength) PCMSGHDR ControlInfo;
|
|
ULONG ControlInfoLength;
|
|
PSOCKADDR RemoteAddress;
|
|
} WSK_DATAGRAM_INDICATION, *PWSK_DATAGRAM_INDICATION;
|
|
|
|
typedef
|
|
_Must_inspect_result_
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_RECEIVE_FROM_EVENT)(
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_ ULONG Flags,
|
|
_In_opt_ PWSK_DATAGRAM_INDICATION DataIndication);
|
|
|
|
typedef struct _WSK_DATA_INDICATION
|
|
{
|
|
struct _WSK_DATA_INDICATION *Next;
|
|
WSK_BUF Buffer;
|
|
} WSK_DATA_INDICATION, *PWSK_DATA_INDICATION;
|
|
|
|
typedef
|
|
_Must_inspect_result_
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_RECEIVE_EVENT)(
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_ ULONG Flags,
|
|
_In_opt_ PWSK_DATA_INDICATION DataIndication,
|
|
_In_ SIZE_T BytesIndicated,
|
|
_Inout_ SIZE_T *BytesAccepted);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_DISCONNECT_EVENT)(
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_ ULONG Flags);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_SEND_BACKLOG_EVENT)(
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_ SIZE_T IdealBacklogSize);
|
|
|
|
typedef struct _WSK_CLIENT_CONNECTION_DISPATCH
|
|
{
|
|
PFN_WSK_RECEIVE_EVENT WskReceiveEvent;
|
|
PFN_WSK_DISCONNECT_EVENT WskDisconnectEvent;
|
|
PFN_WSK_SEND_BACKLOG_EVENT WskSendBacklogEvent;
|
|
} WSK_CLIENT_CONNECTION_DISPATCH, *PWSK_CLIENT_CONNECTION_DISPATCH;
|
|
|
|
typedef
|
|
_Must_inspect_result_
|
|
_At_(AcceptSocket, __drv_aliasesMem)
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_ACCEPT_EVENT)(
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_ ULONG Flags,
|
|
_In_ PSOCKADDR LocalAddress,
|
|
_In_ PSOCKADDR RemoteAddress,
|
|
_In_opt_ PWSK_SOCKET AcceptSocket,
|
|
_Outptr_result_maybenull_ PVOID *AcceptSocketContext,
|
|
_Outptr_result_maybenull_ const WSK_CLIENT_CONNECTION_DISPATCH **AcceptSocketDispatch);
|
|
|
|
typedef
|
|
_At_(Irp->IoStatus.Information, __drv_allocatesMem(Mem))
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_SOCKET_CONNECT)(
|
|
_In_ PWSK_CLIENT Client,
|
|
_In_ USHORT SocketType,
|
|
_In_ ULONG Protocol,
|
|
_In_ PSOCKADDR LocalAddress,
|
|
_In_ PSOCKADDR RemoteAddress,
|
|
_Reserved_ ULONG Flags,
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_opt_ const WSK_CLIENT_CONNECTION_DISPATCH *Dispatch,
|
|
_In_opt_ PEPROCESS OwningProcess,
|
|
_In_opt_ PETHREAD OwningThread,
|
|
_In_opt_ PSECURITY_DESCRIPTOR SecurityDescriptor,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_CONTROL_SOCKET)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ WSK_CONTROL_SOCKET_TYPE RequestType,
|
|
_In_ ULONG ControlCode,
|
|
_In_ ULONG Level,
|
|
_In_ SIZE_T InputSize,
|
|
_In_reads_bytes_opt_(InputSize) PVOID InputBuffer,
|
|
_In_ SIZE_T OutputSize,
|
|
_Out_writes_bytes_opt_(OutputSize) PVOID OutputBuffer,
|
|
_Out_opt_ SIZE_T *OutputSizeReturned,
|
|
_Inout_opt_ PIRP Irp);
|
|
|
|
typedef
|
|
_At_(Socket, __drv_freesMem(Mem))
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_CLOSE_SOCKET)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef struct _WSK_PROVIDER_BASIC_DISPATCH
|
|
{
|
|
PFN_WSK_CONTROL_SOCKET WskControlSocket;
|
|
PFN_WSK_CLOSE_SOCKET WskCloseSocket;
|
|
} WSK_PROVIDER_BASIC_DISPATCH, *PWSK_PROVIDER_BASIC_DISPATCH;
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_BIND) (
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PSOCKADDR LocalAddress,
|
|
_Reserved_ ULONG Flags,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
_At_(Irp->IoStatus.Information, __drv_allocatesMem(Mem))
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_ACCEPT)(
|
|
_In_ PWSK_SOCKET ListenSocket,
|
|
_Reserved_ ULONG Flags,
|
|
_In_opt_ PVOID AcceptSocketContext,
|
|
_In_opt_ const WSK_CLIENT_CONNECTION_DISPATCH *AcceptSocketDispatch,
|
|
_Out_opt_ PSOCKADDR LocalAddress,
|
|
_Out_opt_ PSOCKADDR RemoteAddress,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_INSPECT_COMPLETE)(
|
|
_In_ PWSK_SOCKET ListenSocket,
|
|
_In_ PWSK_INSPECT_ID InspectID,
|
|
_In_ WSK_INSPECT_ACTION Action,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_GET_LOCAL_ADDRESS)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_Out_ PSOCKADDR LocalAddress,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef struct _WSK_PROVIDER_LISTEN_DISPATCH
|
|
{
|
|
#ifdef __cplusplus
|
|
WSK_PROVIDER_BASIC_DISPATCH Basic;
|
|
#else
|
|
WSK_PROVIDER_BASIC_DISPATCH;
|
|
#endif
|
|
PFN_WSK_BIND WskBind;
|
|
PFN_WSK_ACCEPT WskAccept;
|
|
PFN_WSK_INSPECT_COMPLETE WskInspectComplete;
|
|
PFN_WSK_GET_LOCAL_ADDRESS WskGetLocalAddress;
|
|
} WSK_PROVIDER_LISTEN_DISPATCH, *PWSK_PROVIDER_LISTEN_DISPATCH;
|
|
|
|
#if (NTDDI_VERSION >= NTDDI_WIN8)
|
|
typedef struct _WSK_BUF_LIST {
|
|
struct _WSK_BUF_LIST *Next;
|
|
WSK_BUF Buffer;
|
|
} WSK_BUF_LIST, *PWSK_BUF_LIST;
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_SEND_MESSAGES)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PWSK_BUF_LIST BufferList,
|
|
_Reserved_ ULONG Flags,
|
|
_In_opt_ PSOCKADDR RemoteAddress,
|
|
_In_ ULONG ControlInfoLength,
|
|
_In_reads_bytes_opt_(ControlInfoLength) PCMSGHDR ControlInfo,
|
|
_Inout_ PIRP Irp);
|
|
#endif /* (NTDDI_VERSION >= NTDDI_WIN8) */
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_CONNECT) (
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PSOCKADDR RemoteAddress,
|
|
_Reserved_ ULONG Flags,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_GET_REMOTE_ADDRESS)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_Out_ PSOCKADDR RemoteAddress,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_SEND)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PWSK_BUF Buffer,
|
|
_In_ ULONG Flags,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_RECEIVE)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PWSK_BUF Buffer,
|
|
_In_ ULONG Flags,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_DISCONNECT)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_opt_ PWSK_BUF Buffer,
|
|
_In_ ULONG Flags,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_RELEASE_DATA_INDICATION_LIST)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PWSK_DATA_INDICATION DataIndication);
|
|
|
|
typedef struct _WSK_PROVIDER_CONNECTION_DISPATCH
|
|
{
|
|
#ifdef __cplusplus
|
|
WSK_PROVIDER_BASIC_DISPATCH Basic;
|
|
#else
|
|
WSK_PROVIDER_BASIC_DISPATCH;
|
|
#endif
|
|
PFN_WSK_BIND WskBind;
|
|
PFN_WSK_CONNECT WskConnect;
|
|
PFN_WSK_GET_LOCAL_ADDRESS WskGetLocalAddress;
|
|
PFN_WSK_GET_REMOTE_ADDRESS WskGetRemoteAddress;
|
|
PFN_WSK_SEND WskSend;
|
|
PFN_WSK_RECEIVE WskReceive;
|
|
PFN_WSK_DISCONNECT WskDisconnect;
|
|
PFN_WSK_RELEASE_DATA_INDICATION_LIST WskRelease;
|
|
} WSK_PROVIDER_CONNECTION_DISPATCH, *PWSK_PROVIDER_CONNECTION_DISPATCH;
|
|
|
|
typedef
|
|
_Must_inspect_result_
|
|
WSK_INSPECT_ACTION
|
|
(WSKAPI * PFN_WSK_INSPECT_EVENT)(
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_ PSOCKADDR LocalAddress,
|
|
_In_ PSOCKADDR RemoteAddress,
|
|
_In_opt_ PWSK_INSPECT_ID InspectID);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_ABORT_EVENT) (
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_ PWSK_INSPECT_ID InspectID);
|
|
|
|
typedef
|
|
_At_(Irp->IoStatus.Information, __drv_allocatesMem(Mem))
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_SOCKET)(
|
|
_In_ PWSK_CLIENT Client,
|
|
_In_ ADDRESS_FAMILY AddressFamily,
|
|
_In_ USHORT SocketType,
|
|
_In_ ULONG Protocol,
|
|
_In_ ULONG Flags,
|
|
_In_opt_ PVOID SocketContext,
|
|
_In_opt_ const VOID *Dispatch,
|
|
_In_opt_ PEPROCESS OwningProcess,
|
|
_In_opt_ PETHREAD OwningThread,
|
|
_In_opt_ PSECURITY_DESCRIPTOR SecurityDescriptor,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef struct _WSK_TDI_MAP
|
|
{
|
|
USHORT SocketType;
|
|
ADDRESS_FAMILY AddressFamily;
|
|
ULONG Protocol;
|
|
PCWSTR TdiDeviceName;
|
|
} WSK_TDI_MAP, *PWSK_TDI_MAP;
|
|
|
|
typedef struct _WSK_TDI_MAP_INFO
|
|
{
|
|
const ULONG ElementCount;
|
|
_Field_size_(ElementCount) const WSK_TDI_MAP *Map;
|
|
} WSK_TDI_MAP_INFO, *PWSK_TDI_MAP_INFO;
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_CONTROL_CLIENT)(
|
|
_In_ PWSK_CLIENT Client,
|
|
_In_ ULONG ControlCode,
|
|
_In_ SIZE_T InputSize,
|
|
_In_reads_bytes_opt_(InputSize) PVOID InputBuffer,
|
|
_In_ SIZE_T OutputSize,
|
|
_Out_writes_bytes_opt_(OutputSize) PVOID OutputBuffer,
|
|
_Out_opt_ SIZE_T *OutputSizeReturned,
|
|
_Inout_opt_ PIRP Irp);
|
|
|
|
#if (NTDDI_VERSION >= NTDDI_WIN7)
|
|
|
|
typedef
|
|
_At_(*Result, __drv_allocatesMem(Mem))
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_GET_ADDRESS_INFO)(
|
|
_In_ PWSK_CLIENT Client,
|
|
_In_opt_ PUNICODE_STRING NodeName,
|
|
_In_opt_ PUNICODE_STRING ServiceName,
|
|
_In_opt_ ULONG NameSpace,
|
|
_In_opt_ GUID *Provider,
|
|
_In_opt_ PADDRINFOEXW Hints,
|
|
_Outptr_ PADDRINFOEXW *Result,
|
|
_In_opt_ PEPROCESS OwningProcess,
|
|
_In_opt_ PETHREAD OwningThread,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_GET_NAME_INFO)(
|
|
_In_ PWSK_CLIENT Client,
|
|
_In_ PSOCKADDR SockAddr,
|
|
_In_ ULONG SockAddrLength,
|
|
_Out_opt_ PUNICODE_STRING NodeName,
|
|
_Out_opt_ PUNICODE_STRING ServiceName,
|
|
_In_ ULONG Flags,
|
|
_In_opt_ PEPROCESS OwningProcess,
|
|
_In_opt_ PETHREAD OwningThread,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
_At_(AddrInfo, __drv_freesMem(Mem))
|
|
VOID
|
|
(WSKAPI * PFN_WSK_FREE_ADDRESS_INFO)(
|
|
_In_ PWSK_CLIENT Client,
|
|
_In_ PADDRINFOEXW AddrInfo);
|
|
|
|
#endif /* if (NTDDI_VERSION >= NTDDI_WIN7) */
|
|
|
|
typedef struct _WSK_EVENT_CALLBACK_CONTROL
|
|
{
|
|
PNPIID NpiId;
|
|
ULONG EventMask;
|
|
} WSK_EVENT_CALLBACK_CONTROL, *PWSK_EVENT_CALLBACK_CONTROL;
|
|
|
|
typedef struct _WSK_EXTENSION_CONTROL_IN
|
|
{
|
|
PNPIID NpiId;
|
|
PVOID ClientContext;
|
|
const VOID* ClientDispatch;
|
|
} WSK_EXTENSION_CONTROL_IN, *PWSK_EXTENSION_CONTROL_IN;
|
|
|
|
typedef struct _WSK_EXTENSION_CONTROL_OUT
|
|
{
|
|
PVOID ProviderContext;
|
|
const VOID* ProviderDispatch;
|
|
} WSK_EXTENSION_CONTROL_OUT, *PWSK_EXTENSION_CONTROL_OUT;
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_SEND_TO)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PWSK_BUF Buffer,
|
|
_Reserved_ ULONG Flags,
|
|
_In_opt_ PSOCKADDR RemoteAddress,
|
|
_In_ ULONG ControlInfoLength,
|
|
_In_reads_bytes_opt_(ControlInfoLength) PCMSGHDR ControlInfo,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_RECEIVE_FROM)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PWSK_BUF Buffer,
|
|
_Reserved_ ULONG Flags,
|
|
_Out_opt_ PSOCKADDR RemoteAddress,
|
|
_Inout_ PULONG ControlLength,
|
|
_Out_writes_bytes_opt_(*ControlLength) PCMSGHDR ControlInfo,
|
|
_Out_opt_ PULONG ControlFlags,
|
|
_Inout_ PIRP Irp);
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_RELEASE_DATAGRAM_INDICATION_LIST)(
|
|
_In_ PWSK_SOCKET Socket,
|
|
_In_ PWSK_DATAGRAM_INDICATION DatagramIndication);
|
|
|
|
typedef struct _WSK_PROVIDER_DATAGRAM_DISPATCH
|
|
{
|
|
#ifdef __cplusplus
|
|
WSK_PROVIDER_BASIC_DISPATCH Basic;
|
|
#else
|
|
WSK_PROVIDER_BASIC_DISPATCH;
|
|
#endif
|
|
PFN_WSK_BIND WskBind;
|
|
PFN_WSK_SEND_TO WskSendTo;
|
|
PFN_WSK_RECEIVE_FROM WskReceiveFrom;
|
|
PFN_WSK_RELEASE_DATAGRAM_INDICATION_LIST WskRelease;
|
|
PFN_WSK_GET_LOCAL_ADDRESS WskGetLocalAddress;
|
|
#if (NTDDI_VERSION >= NTDDI_WIN8)
|
|
PFN_WSK_SEND_MESSAGES WskSendMessages;
|
|
#endif
|
|
} WSK_PROVIDER_DATAGRAM_DISPATCH, *PWSK_PROVIDER_DATAGRAM_DISPATCH;
|
|
|
|
typedef
|
|
NTSTATUS
|
|
(WSKAPI * PFN_WSK_CLIENT_EVENT)(
|
|
_In_opt_ PVOID ClientContext,
|
|
_In_ ULONG EventType,
|
|
_In_reads_bytes_opt_(InformationLength) PVOID Information,
|
|
_In_ SIZE_T InformationLength);
|
|
|
|
typedef struct _WSK_CLIENT_DISPATCH
|
|
{
|
|
USHORT Version;
|
|
USHORT Reserved;
|
|
PFN_WSK_CLIENT_EVENT WskClientEvent;
|
|
} WSK_CLIENT_DISPATCH, *PWSK_CLIENT_DISPATCH;
|
|
|
|
typedef struct _WSK_CLIENT_LISTEN_DISPATCH
|
|
{
|
|
PFN_WSK_ACCEPT_EVENT WskAcceptEvent;
|
|
PFN_WSK_INSPECT_EVENT WskInspectEvent;
|
|
PFN_WSK_ABORT_EVENT WskAbortEvent;
|
|
} WSK_CLIENT_LISTEN_DISPATCH, *PWSK_CLIENT_LISTEN_DISPATCH;
|
|
|
|
typedef struct _WSK_CLIENT_DATAGRAM_DISPATCH
|
|
{
|
|
PFN_WSK_RECEIVE_FROM_EVENT WskReceiveFromEvent;
|
|
} WSK_CLIENT_DATAGRAM_DISPATCH, *PWSK_CLIENT_DATAGRAM_DISPATCH;
|
|
|
|
typedef struct _WSK_PROVIDER_DISPATCH
|
|
{
|
|
USHORT Version;
|
|
USHORT Reserved;
|
|
PFN_WSK_SOCKET WskSocket;
|
|
PFN_WSK_SOCKET_CONNECT WskSocketConnect;
|
|
PFN_WSK_CONTROL_CLIENT WskControlClient;
|
|
#if (NTDDI_VERSION >= NTDDI_WIN7)
|
|
PFN_WSK_GET_ADDRESS_INFO WskGetAddressInfo;
|
|
PFN_WSK_FREE_ADDRESS_INFO WskFreeAddressInfo;
|
|
PFN_WSK_GET_NAME_INFO WskGetNameInfo;
|
|
#endif
|
|
} WSK_PROVIDER_DISPATCH, *PWSK_PROVIDER_DISPATCH;
|
|
|
|
|
|
typedef struct _WSK_CLIENT_NPI
|
|
{
|
|
PVOID ClientContext;
|
|
const WSK_CLIENT_DISPATCH *Dispatch;
|
|
} WSK_CLIENT_NPI, *PWSK_CLIENT_NPI;
|
|
|
|
typedef struct _WSK_PROVIDER_NPI
|
|
{
|
|
PWSK_CLIENT Client;
|
|
const WSK_PROVIDER_DISPATCH *Dispatch;
|
|
} WSK_PROVIDER_NPI, *PWSK_PROVIDER_NPI;
|
|
|
|
typedef struct _WSK_REGISTRATION
|
|
{
|
|
ULONGLONG ReservedRegistrationState;
|
|
PVOID ReservedRegistrationContext;
|
|
KSPIN_LOCK ReservedRegistrationLock;
|
|
} WSK_REGISTRATION, *PWSK_REGISTRATION;
|
|
|
|
typedef struct _WSK_PROVIDER_CHARACTERISTICS
|
|
{
|
|
USHORT HighestVersion;
|
|
USHORT LowestVersion;
|
|
} WSK_PROVIDER_CHARACTERISTICS, *PWSK_PROVIDER_CHARACTERISTICS;
|
|
|
|
typedef struct _WSK_TRANSPORT
|
|
{
|
|
USHORT Version;
|
|
USHORT SocketType;
|
|
ULONG Protocol;
|
|
ADDRESS_FAMILY AddressFamily;
|
|
GUID ProviderId;
|
|
} WSK_TRANSPORT, *PWSK_TRANSPORT;
|
|
|
|
_Must_inspect_result_
|
|
NTSTATUS
|
|
WSKAPI
|
|
WskRegister(
|
|
_In_ PWSK_CLIENT_NPI WskClientNpi,
|
|
_Out_ PWSK_REGISTRATION WskRegistration);
|
|
|
|
_Must_inspect_result_
|
|
NTSTATUS
|
|
WSKAPI
|
|
WskCaptureProviderNPI(
|
|
_In_ PWSK_REGISTRATION WskRegistration,
|
|
_In_ ULONG WaitTimeout,
|
|
_Out_ PWSK_PROVIDER_NPI WskProviderNpi);
|
|
|
|
VOID
|
|
WSKAPI
|
|
WskReleaseProviderNPI(
|
|
_In_ PWSK_REGISTRATION WskRegistration);
|
|
|
|
_Must_inspect_result_
|
|
NTSTATUS
|
|
WSKAPI
|
|
WskQueryProviderCharacteristics(
|
|
_In_ PWSK_REGISTRATION WskRegistration,
|
|
_Out_ PWSK_PROVIDER_CHARACTERISTICS WskProviderCharacteristics);
|
|
|
|
VOID
|
|
WSKAPI
|
|
WskDeregister(
|
|
_In_ PWSK_REGISTRATION WskRegistration);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
|