2 * Copyright (C) the Wine project
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
23 #endif /* defined(__cplusplus) */
32 #define SO_CONNDATA 0x7000
33 #define SO_CONNOPT 0x7001
34 #define SO_DISCDATA 0x7002
35 #define SO_DISCOPT 0x7003
36 #define SO_CONNDATALEN 0x7004
37 #define SO_CONNOPTLEN 0x7005
38 #define SO_DISCDATALEN 0x7006
39 #define SO_DISCOPTLEN 0x7007
41 #define WS_SO_CONNDATA 0x7000
42 #define WS_SO_CONNOPT 0x7001
43 #define WS_SO_DISCDATA 0x7002
44 #define WS_SO_DISCOPT 0x7003
45 #define WS_SO_CONNDATALEN 0x7004
46 #define WS_SO_CONNOPTLEN 0x7005
47 #define WS_SO_DISCDATALEN 0x7006
48 #define WS_SO_DISCOPTLEN 0x7007
52 #define SO_OPENTYPE 0x7008
54 #define WS_SO_OPENTYPE 0x7008
58 #define SO_SYNCHRONOUS_ALERT 0x10
59 #define SO_SYNCHRONOUS_NONALERT 0x20
61 #define WS_SO_SYNCHRONOUS_ALERT 0x10
62 #define WS_SO_SYNCHRONOUS_NONALERT 0x20
66 #define SO_MAXDG 0x7009
67 #define SO_MAXPATHDG 0x700A
68 #define SO_UPDATE_ACCEPT_CONTEXT 0x700B
69 #define SO_CONNECT_TIME 0x700C
70 #define SO_UPDATE_CONNECT_CONTEXT 0x7010
72 #define WS_SO_MAXDG 0x7009
73 #define WS_SO_MAXPATHDG 0x700A
74 #define WS_SO_UPDATE_ACCEPT_CONTEXT 0x700B
75 #define WS_SO_CONNECT_TIME 0x700C
76 #define WS_SO_UPDATE_CONNECT_CONTEXT 0x7010
80 #define TCP_BSDURGENT 0x7000
82 #define WS_TCP_BSDURGENT 0x7000
86 #define SIO_UDP_CONNRESET _WSAIOW(IOC_VENDOR,12)
87 #define SIO_SET_COMPATIBILITY_MODE _WSAIOW(IOC_VENDOR,300)
89 #define WS_SIO_UDP_CONNRESET _WSAIOW(WS_IOC_VENDOR,12)
90 #define WS_SIO_SET_COMPATIBILITY_MODE _WSAIOW(WS_IOC_VENDOR,300)
93 #define DE_REUSE_SOCKET TF_REUSE_SOCKET
96 #define MSG_TRUNC 0x0100
97 #define MSG_CTRUNC 0x0200
98 #define MSG_BCAST 0x0400
99 #define MSG_MCAST 0x0800
101 #define WS_MSG_TRUNC 0x0100
102 #define WS_MSG_CTRUNC 0x0200
103 #define WS_MSG_BCAST 0x0400
104 #define WS_MSG_MCAST 0x0800
107 #define TF_DISCONNECT 0x01
108 #define TF_REUSE_SOCKET 0x02
109 #define TF_WRITE_BEHIND 0x04
110 #define TF_USE_DEFAULT_WORKER 0x00
111 #define TF_USE_SYSTEM_THREAD 0x10
112 #define TF_USE_KERNEL_APC 0x20
114 #define TP_DISCONNECT TF_DISCONNECT
115 #define TP_REUSE_SOCKET TF_REUSE_SOCKET
116 #define TP_USE_DEFAULT_WORKER TF_USE_DEFAULT_WORKER
117 #define TP_USE_SYSTEM_THREAD TF_USE_SYSTEM_THREAD
118 #define TP_USE_KERNEL_APC TF_USE_KERNEL_APC
120 #define TP_ELEMENT_MEMORY 1
121 #define TP_ELEMENT_FILE 2
122 #define TP_ELEMENT_EOP 4
124 #define WSAID_ACCEPTEX \
125 {0xb5367df1,0xcbac,0x11cf,{0x95,0xca,0x00,0x80,0x5f,0x48,0xa1,0x92}}
126 #define WSAID_CONNECTEX \
127 {0x25a207b9,0xddf3,0x4660,{0x8e,0xe9,0x76,0xe5,0x8c,0x74,0x06,0x3e}}
128 #define WSAID_DISCONNECTEX \
129 {0x7fda2e11,0x8630,0x436f,{0xa0,0x31,0xf5,0x36,0xa6,0xee,0xc1,0x57}}
130 #define WSAID_GETACCEPTEXSOCKADDRS \
131 {0xb5367df2,0xcbac,0x11cf,{0x95,0xca,0x00,0x80,0x5f,0x48,0xa1,0x92}}
132 #define WSAID_TRANSMITFILE \
133 {0xb5367df0,0xcbac,0x11cf,{0x95,0xca,0x00,0x80,0x5f,0x48,0xa1,0x92}}
134 #define WSAID_TRANSMITPACKETS \
135 {0xd9689da0,0x1f90,0x11d3,{0x99,0x71,0x00,0xc0,0x4f,0x68,0xc8,0x76}}
136 #define WSAID_WSARECVMSG \
137 {0xf689d7c8,0x6f1f,0x436b,{0x8a,0x53,0xe5,0x4f,0xe3,0x51,0xc3,0x22}}
138 #define WSAID_WSASENDMSG \
139 {0xa441e712,0x754f,0x43ca,{0x84,0xa7,0x0d,0xee,0x44,0xcf,0x60,0x6d}}
141 typedef struct _TRANSMIT_FILE_BUFFERS
{
146 } TRANSMIT_FILE_BUFFERS
, *PTRANSMIT_FILE_BUFFERS
, *LPTRANSMIT_FILE_BUFFERS
;
148 typedef struct _TRANSMIT_PACKETS_ELEMENT
{
153 LARGE_INTEGER nFileOffset
;
158 } TRANSMIT_PACKETS_ELEMENT
, *PTRANSMIT_PACKETS_ELEMENT
, *LPTRANSMIT_PACKETS_ELEMENT
;
160 typedef struct _WSACMSGHDR
{
164 /* followed by UCHAR cmsg_data[] */
165 } WSACMSGHDR
, *PWSACMSGHDR
, *LPWSACMSGHDR
;
167 typedef enum _NLA_BLOB_DATA_TYPE
{
169 NLA_INTERFACE
, /* interface name, type and speed */
170 NLA_802_1X_LOCATION
, /* wireless network info */
171 NLA_CONNECTIVITY
, /* status on network connectivity */
172 NLA_ICS
/* internet connection sharing */
173 } NLA_BLOB_DATA_TYPE
;
175 typedef enum _NLA_CONNECTIVITY_TYPE
{
176 NLA_NETWORK_AD_HOC
, /* private network */
177 NLA_NETWORK_MANAGED
, /* network managed by domain */
178 NLA_NETWORK_UNMANAGED
,
180 } NLA_CONNECTIVITY_TYPE
;
182 typedef enum _NLA_INTERNET
{
183 NLA_INTERNET_UNKNOWN
, /* can't determine if connected or not */
184 NLA_INTERNET_NO
, /* not connected to internet */
185 NLA_INTERNET_YES
/* connected to internet */
188 /* this structure is returned in the lpBlob field during calls to WSALookupServiceNext */
189 typedef struct _NLA_BLOB
{
190 /* the header defines the size of the current record and if there is a next record */
192 NLA_BLOB_DATA_TYPE type
;
194 DWORD nextOffset
; /* if it's zero there are no more blobs */
197 /* the following union interpretation depends on the header.type value
198 * from the struct above.
199 * the header.dwSize will be the size of all data, specially useful when
200 * the last struct field is size [1] */
212 /* NLA_802_1X_LOCATION */
217 /* NLA_CONNECTIVITY */
219 NLA_CONNECTIVITY_TYPE type
;
220 NLA_INTERNET internet
;
229 WCHAR machineName
[256];
230 WCHAR sharedAdapterName
[256];
234 } NLA_BLOB
, *PNLA_BLOB
;
236 typedef BOOL (WINAPI
* LPFN_ACCEPTEX
)(SOCKET
, SOCKET
, PVOID
, DWORD
, DWORD
, DWORD
, LPDWORD
, LPOVERLAPPED
);
237 typedef BOOL (WINAPI
* LPFN_CONNECTEX
)(SOCKET
, const struct WS(sockaddr
) *, int, PVOID
, DWORD
, LPDWORD
, LPOVERLAPPED
);
238 typedef BOOL (WINAPI
* LPFN_DISCONNECTEX
)(SOCKET
, LPOVERLAPPED
, DWORD
, DWORD
);
239 typedef VOID (WINAPI
* LPFN_GETACCEPTEXSOCKADDRS
)(PVOID
, DWORD
, DWORD
, DWORD
, struct WS(sockaddr
) **, LPINT
, struct WS(sockaddr
) **, LPINT
);
240 typedef BOOL (WINAPI
* LPFN_TRANSMITFILE
)(SOCKET
, HANDLE
, DWORD
, DWORD
, LPOVERLAPPED
, LPTRANSMIT_FILE_BUFFERS
, DWORD
);
241 typedef BOOL (WINAPI
* LPFN_TRANSMITPACKETS
)(SOCKET
, LPTRANSMIT_PACKETS_ELEMENT
, DWORD
, DWORD
, LPOVERLAPPED
, DWORD
);
242 typedef INT (WINAPI
* LPFN_WSARECVMSG
)(SOCKET
, LPWSAMSG
, LPDWORD
, LPWSAOVERLAPPED
, LPWSAOVERLAPPED_COMPLETION_ROUTINE
);
243 typedef INT (WINAPI
* LPFN_WSASENDMSG
)(SOCKET
, LPWSAMSG
, DWORD
, LPDWORD
, LPWSAOVERLAPPED
, LPWSAOVERLAPPED_COMPLETION_ROUTINE
);
245 BOOL WINAPI
AcceptEx(SOCKET
, SOCKET
, PVOID
, DWORD
, DWORD
, DWORD
, LPDWORD
, LPOVERLAPPED
);
246 VOID WINAPI
GetAcceptExSockaddrs(PVOID
, DWORD
, DWORD
, DWORD
, struct WS(sockaddr
) **, LPINT
, struct WS(sockaddr
) **, LPINT
);
247 BOOL WINAPI
TransmitFile(SOCKET
, HANDLE
, DWORD
, DWORD
, LPOVERLAPPED
, LPTRANSMIT_FILE_BUFFERS
, DWORD
);
248 INT WINAPI
WSARecvEx(SOCKET
, char *, INT
, INT
*);
256 #endif /* _MSWSOCK_ */